/* ============================================================
   ANGELARIUS · BLOG · foglio di stile UNICO (template)
   ------------------------------------------------------------
   Tutto il design del blog vive qui. Per modifiche future:
   1) i colori, i font e le misure base stanno nelle variabili
      ":root" qui sotto: cambiate li' e cambia tutto il blog.
   2) i "mattoni" (header, articolo, riquadro CTA, footer, card)
      sono raggruppati e commentati piu' in basso.
   Palette araldica coerente col sito: navy + verde (azione) + oro
   (accento metallico sui fondi scuri). Niente font esterni: solo
   font di sistema (veloce e rispettoso della privacy).
   ============================================================ */

:root{
  /* --- Colori --- */
  --b-navy:#14223F;       /* fondo scuro principale (header, footer, CTA) */
  --b-navy-2:#0E1A33;     /* navy piu' profondo */
  --b-panel:#1C2E50;      /* pannelli su fondo scuro */
  --b-ink:#15213B;        /* titoli su fondo chiaro */
  --b-text:#36425A;       /* testo dei paragrafi */
  --b-velo:#5E6A80;       /* testo secondario, meta */
  --b-paper:#FBFCFE;      /* fondo pagina chiaro */
  --b-paper-2:#F2F6FC;    /* fondo alternato chiaro */
  --b-line:#DAE3EF;       /* linee e bordi */
  --b-green:#1A8F50;      /* azione/accento su chiaro */
  --b-green-2:#3CB371;    /* verde chiaro per gradienti */
  --b-green-h:#14773F;    /* verde hover */
  --b-gold:#E0B354;       /* accento metallico su scuro */
  --b-gold-2:#EBC97A;     /* oro chiaro */
  --b-chiaro:#E7EDF7;     /* testo su scuro */
  --b-chiaro-velo:#AEBBD2;/* testo secondario su scuro */

  /* --- Tipografia --- */
  --b-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --b-serif:'Iowan Old Style','Palatino Linotype',Palatino,Georgia,'Times New Roman',serif;

  /* --- Misure --- */
  --b-wrap:1080px;        /* larghezza massima generale */
  --b-read:38rem;         /* larghezza di lettura dell'articolo */
  --b-radius:16px;
  --b-shadow:0 24px 48px -30px rgba(14,26,51,.40);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--b-navy-2);font-size:108%}
body{margin:0;background:var(--b-paper);color:var(--b-text);
  font:400 1.25rem/1.7 var(--b-serif);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--b-green);text-decoration:underline;text-decoration-thickness:.07em;text-underline-offset:.14em}
a:hover{color:var(--b-green-h)}
:focus-visible{outline:2px solid var(--b-green);outline-offset:3px;border-radius:4px}

/* ----- Contenitori ----- */
.b-wrap{width:min(var(--b-wrap),92vw);margin-inline:auto}
.b-read{width:min(var(--b-read),92vw);margin-inline:auto}

/* ============================================================
   HEADER (barra in alto, navy con filo d'oro). Il marchio
   riporta alla HOME del sito. Riconoscibile, identico ovunque.
   ============================================================ */
.b-top{position:sticky;top:0;z-index:50;background:var(--b-navy);
  border-bottom:1px solid rgba(224,179,84,.28);
  box-shadow:0 2px 0 rgba(224,179,84,.10),0 10px 30px -20px rgba(0,0,0,.6)}
.b-top-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.9rem 0}
.b-brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--b-chiaro)}
.b-brand .b-stemma{width:32px;height:32px;flex:none;display:grid;place-items:center;
  border:1.5px solid var(--b-gold);border-radius:9px;background:rgba(224,179,84,.10);
  color:var(--b-gold-2);font:800 1.15rem/1 var(--b-sans)}
.b-brand b{font:800 1.06rem/1 var(--b-sans);letter-spacing:.18em;color:var(--b-chiaro)}
.b-brand small{display:block;margin-top:.18rem;font:700 .7rem/1 var(--b-sans);
  letter-spacing:.22em;color:var(--b-gold-2);text-transform:uppercase}
.b-top a.b-home{font:700 1rem var(--b-sans);color:var(--b-chiaro-velo);text-decoration:none;
  border:1px solid rgba(174,187,210,.35);border-radius:10px;padding:.55rem .9rem;white-space:nowrap}
.b-top a.b-home:hover{color:var(--b-chiaro);border-color:var(--b-gold-2)}

/* ============================================================
   ARTICOLO
   ============================================================ */
.b-post{padding:clamp(2rem,5vw,3.4rem) 0 1rem}
.b-cat{display:inline-block;font:700 .95rem var(--b-sans);letter-spacing:.14em;
  text-transform:uppercase;color:var(--b-green);margin-bottom:1rem}
.b-title{font:800 clamp(2.1rem,5.2vw,3.4rem)/1.08 var(--b-sans);color:var(--b-ink);
  letter-spacing:-.02em;margin:0 0 1rem;text-wrap:balance}
.b-meta{color:var(--b-velo);font:600 1rem var(--b-sans);letter-spacing:.01em;
  display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin-bottom:1.4rem}
.b-meta span{display:inline-flex;align-items:center;gap:.4rem}
.b-lede{font:400 1.45rem/1.55 var(--b-serif);color:var(--b-ink);margin:0 0 1.6rem;text-wrap:pretty}
.b-hero{margin:1.2rem 0 2rem;border-radius:var(--b-radius);overflow:hidden;
  border:1px solid var(--b-line);box-shadow:var(--b-shadow)}
.b-hero img{width:100%;aspect-ratio:16/9;object-fit:cover}

/* corpo testo dell'articolo */
.b-body{font-size:1.27rem}
.b-body > p:first-of-type::first-letter{float:left;font:800 4.2rem/.78 var(--b-sans);
  color:var(--b-green);margin:.34rem .7rem 0 0}
.b-body h2{font:800 clamp(1.7rem,3.4vw,2.2rem)/1.18 var(--b-sans);color:var(--b-ink);
  margin:2.4rem 0 .9rem;padding-top:.4rem}
.b-body h2::after{content:"";display:block;width:2.6rem;height:.2rem;margin-top:.55rem;
  background:linear-gradient(90deg,var(--b-green),var(--b-green-2));border-radius:2px}
.b-body h3{font:700 1.32rem/1.3 var(--b-sans);color:var(--b-ink);margin:1.8rem 0 .6rem}
.b-body p{margin:0 0 1.15rem;text-wrap:pretty}
.b-body ul,.b-body ol{margin:0 0 1.3rem;padding-left:1.3rem}
.b-body li{margin:.5rem 0;padding-left:.2rem}
.b-body li::marker{color:var(--b-green)}
.b-body strong{color:var(--b-ink);font-weight:700}
.b-body a{font-weight:600}

/* citazione / inciso evidenziato */
.b-quote{margin:2rem 0;padding:1.2rem 1.5rem;border-left:4px solid var(--b-green);
  background:var(--b-paper-2);border-radius:0 12px 12px 0;
  font:600 1.35rem/1.5 var(--b-serif);color:var(--b-ink)}

/* riquadro nota/checklist su fondo chiaro */
.b-note{margin:2rem 0;padding:1.4rem 1.6rem;background:var(--b-paper-2);
  border:1px solid var(--b-line);border-radius:var(--b-radius)}
.b-note h3{margin-top:0}

/* ============================================================
   CTA finale (riquadro navy che riporta al sito). Cambiare qui
   il testo/bottoni per tutti gli articoli che lo riusano.
   ============================================================ */
.b-cta{margin:3rem 0 1rem;padding:clamp(1.8rem,4vw,2.8rem);border-radius:var(--b-radius);
  background:radial-gradient(120% 140% at 0% 0%,var(--b-panel),var(--b-navy) 60%,var(--b-navy-2));
  border:1px solid rgba(224,179,84,.28);box-shadow:var(--b-shadow);color:var(--b-chiaro)}
.b-cta .b-cat{color:var(--b-gold-2)}
.b-cta h2{font:800 clamp(1.7rem,3.6vw,2.3rem)/1.15 var(--b-sans);color:#fbfcfe;margin:.2rem 0 .7rem}
.b-cta p{font:400 1.22rem/1.55 var(--b-serif);color:var(--b-chiaro-velo);margin:0 0 1.4rem;max-width:48ch}
.b-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.b-btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:1rem 1.7rem;border-radius:12px;font:700 1.15rem var(--b-sans);text-decoration:none;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,background .2s ease,border-color .2s ease}
.b-btn:active{transform:scale(.985)}
.b-btn-green{background:var(--b-green);color:#fbfcfe;box-shadow:0 14px 30px -12px rgba(26,143,80,.6)}
.b-btn-green:hover{background:var(--b-green-h);color:#fbfcfe}
.b-btn-ghost{border-color:rgba(231,237,247,.5);color:var(--b-chiaro)}
.b-btn-ghost:hover{border-color:var(--b-gold-2);color:#fbfcfe;background:rgba(231,237,247,.06)}

/* ============================================================
   FOOTER (navy). Link alla home del sito.
   ============================================================ */
.b-foot{margin-top:3rem;background:var(--b-navy-2);color:var(--b-chiaro-velo);
  border-top:1px solid rgba(224,179,84,.18);padding:2.6rem 0}
.b-foot-in{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.b-foot a{color:var(--b-chiaro);text-decoration:none}
.b-foot a:hover{color:var(--b-gold-2);text-decoration:underline}
.b-foot .b-mini{font:600 .98rem var(--b-sans);color:var(--b-chiaro-velo)}
/* Blocco NAP (Nome, recapiti, zona): identico su tutte le pagine, per coerenza SEO locale */
.b-foot-nap{display:grid;grid-template-columns:1fr auto;gap:1.2rem 2.4rem;align-items:start}
.b-foot-brand{display:flex;flex-direction:column;gap:.3rem}
.b-foot-brand b{font:800 1.05rem/1 var(--b-sans);letter-spacing:.16em;color:var(--b-chiaro)}
.b-nap{font:600 1rem/1.7 var(--b-sans);font-style:normal;color:var(--b-chiaro-velo);text-align:right}
.b-nap a{color:var(--b-chiaro)}
.b-foot-links{grid-column:1/-1;font:600 .98rem var(--b-sans);color:var(--b-chiaro-velo);
  padding-top:1rem;border-top:1px solid rgba(174,187,210,.16)}
@media (max-width:640px){
  .b-foot-nap{grid-template-columns:1fr}
  .b-nap{text-align:left}
}

/* ============================================================
   PAGINA INDICE DEL BLOG (lista articoli)
   ============================================================ */
.b-intro{padding:clamp(2.4rem,6vw,4rem) 0 1rem;text-align:center}
.b-intro h1{font:800 clamp(2.4rem,6vw,3.8rem)/1.05 var(--b-sans);color:var(--b-ink);
  letter-spacing:-.02em;margin:.4rem 0 .8rem;text-wrap:balance}
.b-intro p{font:400 1.35rem/1.55 var(--b-serif);color:var(--b-velo);max-width:54ch;margin:0 auto}
.b-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:1.6rem;padding:2.4rem 0 1rem}
.b-card{display:flex;flex-direction:column;background:#fbfcfe;border:1px solid var(--b-line);
  border-radius:var(--b-radius);overflow:hidden;box-shadow:0 18px 40px -34px rgba(14,26,51,.5);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;text-decoration:none}
.b-card:hover{transform:translateY(-4px);border-color:rgba(26,143,80,.4);
  box-shadow:0 26px 50px -30px rgba(14,26,51,.55)}
.b-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--b-paper-2)}
.b-card-img img{width:100%;height:100%;object-fit:cover}
.b-card-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.b-card .b-cat{margin-bottom:.6rem}
.b-card h2{font:800 1.5rem/1.2 var(--b-sans);color:var(--b-ink);margin:0 0 .6rem}
.b-card p{font:400 1.12rem/1.5 var(--b-serif);color:var(--b-text);margin:0 0 1.1rem}
.b-card .b-more{margin-top:auto;font:700 1.02rem var(--b-sans);color:var(--b-green)}
.b-card:hover .b-more{color:var(--b-green-h)}

/* ----- responsive ----- */
@media (max-width:640px){
  body{font-size:1.18rem}
  .b-body{font-size:1.18rem}
  .b-body > p:first-of-type::first-letter{font-size:3.4rem}
  .b-brand small{letter-spacing:.18em}
  .b-foot-in{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto !important;transition:none !important}}
