/**
 * Article (blog) — grafica coerente con la front page.
 * File: web/themes/custom/woo_onepage/assets/css/article-frontpage.css
 *
 * Allegato dal template page--node--article.html.twig tramite la libreria
 * "woo_onepage/article-frontpage" (vedi snippet in handoff/README.md).
 *
 * Usa gli stessi token (palette avorio/oro, Josefin Sans + Cormorant) del
 * mockup della home, scoping tutto sotto .article-page per non interferire
 * col resto del tema.
 */

@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@300;400;600&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

.article-page {
  --ivory:   #faf6f0;
  --ivory-3: #ece4d8;
  --dark:    #5c3d1e;
  --dark-2:  #3d2310;
  --gold:    #bd7a1e;
  --gold-l:  #d4941f;
  --teal:    #4a9e8e;
  --text:    #2e2015;
  --text-m:  #6a5a48;
  --text-l:  #9a8a78;
  --border:  rgba(94, 64, 30, .12);
  --sans:    'Josefin Sans', Helvetica, sans-serif;
  --serif:   'Cormorant Garamond', Georgia, serif;

  background: var(--ivory);
  color: var(--text);
  font-family: var(--serif);
}
.article-page img { display: block; max-width: 100%; }

/* ── HERO DI TESTATA ─────────────────────────────────────── */
.article-hero {
  position: relative;
  height: 72vh;
  min-height: 520px;
  max-height: 760px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.article-hero-bg,
.article-hero-bg img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.article-hero-bg--empty {
  background:
    linear-gradient(135deg, #6a5036 0%, #3d2310 100%),
    repeating-linear-gradient(45deg, transparent, transparent 28px, rgba(255, 255, 255, .04) 28px, rgba(255, 255, 255, .04) 29px);
}
.article-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(30, 15, 5, .15) 0%,
    rgba(30, 15, 5, .30) 45%,
    rgba(20, 10, 2, .86) 100%
  );
}
.article-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 40px 64px;
}
.article-breadcrumb,
.article-breadcrumb a {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255, 245, 230, .6);
  text-decoration: none;
}
.article-breadcrumb { margin-bottom: 28px; }
.article-breadcrumb a:hover { color: var(--gold-l); }
.article-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}
.article-tag {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold-l);
  border: 1px solid rgba(212, 148, 31, .55);
  padding: 4px 10px;
}
.article-date {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255, 245, 230, .65);
}
.article-title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 56px;
  line-height: 1.08;
  color: #fff;
  max-width: 880px;
  text-wrap: balance;
  margin: 0;
}
.article-subtitle {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.5;
  color: rgba(255, 245, 230, .82);
  margin: 20px 0 0;
  max-width: 680px;
}

/* ── CORPO (CKEditor) ────────────────────────────────────── */
.article-body {
  max-width: 720px;
  margin: 0 auto;
  padding: 72px 40px 40px;
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.75;
  color: var(--text);
}
.article-body > p:first-of-type {
  font-size: 24px;
  line-height: 1.6;
  color: var(--dark);
}
.article-body p { margin: 0 0 28px; }
.article-body h2 {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 26px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  margin: 56px 0 20px;
}
.article-body h3 {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 26px;
  color: var(--dark);
  margin: 44px 0 14px;
}
.article-body a {
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(189, 122, 30, .4);
  transition: border-color .2s;
}
.article-body a:hover { border-color: var(--gold); }
.article-body strong { font-weight: 600; color: var(--dark); }

/* liste */
.article-body ul,
.article-body ol { margin: 0 0 28px; padding-left: 4px; list-style: none; }
.article-body ol { counter-reset: li; }
.article-body li { padding: 8px 0 8px 28px; position: relative; }
.article-body ul li::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 17px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
}
.article-body ol li { counter-increment: li; }
.article-body ol li::before {
  content: counter(li);
  position: absolute;
  left: 0;
  top: 8px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 1px;
}

/* citazione */
.article-body blockquote {
  margin: 44px 0;
  padding: 4px 0 4px 32px;
  border-left: 2px solid var(--gold);
  font-family: var(--serif);
  font-style: italic;
  font-size: 27px;
  line-height: 1.5;
  color: var(--dark);
}
.article-body blockquote cite {
  display: block;
  margin-top: 14px;
  font-style: normal;
  font-size: 12px;
  font-family: var(--sans);
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-l);
}

/* ── IMMAGINI NEL CORPO (allineamenti CKEditor) ──────────── */
.article-body figure,
.article-body .text-align-center,
.article-body img { margin: 44px auto; }
.article-body figure img { width: 100%; }
.article-body figcaption {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: .5px;
  color: var(--text-l);
  margin-top: 12px;
  line-height: 1.5;
  padding-left: 16px;
  border-left: 2px solid var(--border);
}

/* CKEditor "align left/right" → testo che scorre attorno */
.article-body .align-left,
.article-body figure.align-left {
  float: left;
  width: 300px;
  margin: 8px 36px 24px 0;
}
.article-body .align-right,
.article-body figure.align-right {
  float: right;
  width: 300px;
  margin: 8px 0 24px 36px;
}

/* CKEditor immagine "full width" (data-align="center" + larghezza piena)
   esce dalla colonna di testo per le immagini grandi */
.article-body figure.align-center.image_resized,
.article-body figure.image-style-full,
.article-body .image-full {
  width: 100vw;
  position: relative;
  left: 50%;
  margin-left: -50vw;
  max-width: 100vw;
}
.article-body figure.align-center.image_resized figcaption,
.article-body figure.image-style-full figcaption {
  max-width: 720px;
  margin: 16px auto 0;
  padding: 0 40px;
  border-left: none;
  text-align: center;
}

/* ── FIRMA AUTORE ────────────────────────────────────────── */
.article-end {
  max-width: 720px;
  margin: 0 auto;
  padding: 8px 40px 16px;
}
.article-end-rule {
  height: 1px;
  background: var(--border);
  margin-bottom: 28px;
}
.article-sign {
  display: flex;
  align-items: center;
  gap: 16px;
}
.article-sign-mark {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--gold);
  flex-shrink: 0;
}
.article-sign-text {
  font-family: var(--serif);
  font-style: italic;
  font-size: 17px;
  color: var(--text-m);
}
.article-sign-text strong {
  display: block;
  font-style: normal;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  margin-bottom: 2px;
}

/* ── CTA verso strumenti / shop ──────────────────────────── */
.article-cta {
  margin-top: 72px;
  background: var(--dark-2);
  padding: 72px 40px;
  text-align: center;
}
.article-cta .label {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold-l);
  margin-bottom: 16px;
}
.article-cta h2 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 36px;
  color: #fff;
  line-height: 1.25;
  max-width: 640px;
  margin: 0 auto 14px;
  text-wrap: balance;
}
.article-cta p {
  font-family: var(--serif);
  font-size: 19px;
  font-style: italic;
  color: rgba(255, 245, 228, .6);
  max-width: 560px;
  margin: 0 auto 36px;
}
.article-cta-btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.article-cta .btn-primary,
.article-cta .btn-outline {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 15px 34px;
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s;
}
.article-cta .btn-primary { background: var(--gold); color: #fff; border: none; }
.article-cta .btn-primary:hover { background: var(--gold-l); }
.article-cta .btn-outline {
  background: transparent;
  color: rgba(255, 245, 230, .9);
  border: 1px solid rgba(255, 245, 230, .4);
}
.article-cta .btn-outline:hover { border-color: rgba(255, 245, 230, .8); color: #fff; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .article-hero { height: auto; min-height: 0; max-height: none; }
  .article-hero-inner { padding: 200px 24px 40px; }
  .article-title { font-size: 34px; }
  .article-subtitle { font-size: 18px; }

  .article-body { padding: 48px 24px 32px; font-size: 18px; }
  .article-body > p:first-of-type { font-size: 21px; }
  .article-body blockquote { font-size: 22px; padding-left: 22px; }
  .article-body .align-left,
  .article-body .align-right,
  .article-body figure.align-left,
  .article-body figure.align-right { float: none; width: 100%; margin: 32px 0; }

  .article-end { padding: 8px 24px 16px; }
  .article-cta { padding: 56px 24px; }
  .article-cta h2 { font-size: 27px; }
}
