:root {
  --fb-verde: #314f3b;
  --fb-verde-scuro: #243626;
  --fb-verde-chiaro: #e5f0df;
  --fb-crema: #f3ead8;
  --fb-sfondo: #fbfaf6;
  --fb-ocra: #d99b3d;
  --fb-testo: #26332b;
  --fb-bordo: #d8cdb6;

  --cassiopeia-color-primary: #314f3b;
  --cassiopeia-color-link: #314f3b;
  --cassiopeia-color-hover: #d99b3d;
}

body {
  background: var(--fb-sfondo);
  color: var(--fb-testo);
}

a {
  color: var(--fb-verde);
}

a:hover {
  color: var(--fb-ocra);
}

/* Contenitore generale */
.site-grid,
.container-component,
.container-main {
  max-width: 1180px;
}

/* Area contenuto */
.com-content-article,
.blog,
.category-list,
.com-content-category-blog {
  background: #ffffff;
  border-radius: 22px;
  padding: 30px;
  box-shadow: 0 10px 30px rgba(49, 79, 59, 0.08);
}

/* Titoli generali */
h1,
h2,
h3 {
  color: var(--fb-verde-scuro);
}

/* Header / menu */
.container-header {
  background: linear-gradient(135deg, var(--fb-verde-scuro) 0%, var(--fb-verde) 100%);
  box-shadow: 0 6px 20px rgba(36, 54, 38, 0.18);
}

.container-header .navbar-brand,
.container-header .navbar-brand a,
.container-header .site-description {
  color: var(--fb-crema);
}

.container-header .mod-menu > li > a,
.container-header .mod-menu > li > span {
  color: #ffffff;
  font-weight: 700;
}

.container-header .mod-menu > li > a:hover,
.container-header .mod-menu > li.active > a {
  color: var(--fb-ocra);
}

/* Dropdown menu */
.metismenu.mod-menu .mm-collapse {
  background: var(--fb-verde-scuro);
  border-radius: 0 0 14px 14px;
}

.metismenu.mod-menu .mm-collapse a {
  color: #ffffff;
}

.metismenu.mod-menu .mm-collapse a:hover {
  color: var(--fb-ocra);
}

/* Breadcrumb */
.breadcrumb,
.mod-breadcrumbs,
.breadcrumb-item {
  display: none !important;
}

/* Dettagli articolo Joomla */
.article-info,
dl.article-info,
dt.article-info-term,
dd.hits,
.icons,
.com-content-article__navigation {
  display: none !important;
}

/* Tabelle/lista categoria Joomla */
.category-list table,
.category-list .table {
  background: #ffffff;
}

.category-list th,
.category-list td {
  border-color: var(--fb-bordo);
}

/* Pulsanti */
.btn,
button,
input[type="submit"],
.readmore a {
  background: var(--fb-verde);
  color: #ffffff !important;
  border: none;
  border-radius: 999px;
  padding: 11px 20px;
  font-weight: 800;
  text-decoration: none;
}

.btn:hover,
button:hover,
input[type="submit"]:hover,
.readmore a:hover {
  background: var(--fb-ocra);
  color: #1f241d !important;
  text-decoration: none;
}

/* Footer */
.container-footer,
.site-footer,
.footer {
  background: var(--fb-verde-scuro);
  color: var(--fb-crema);
}

.container-footer a,
.site-footer a,
.footer a {
  color: var(--fb-crema);
}

.container-footer a:hover,
.site-footer a:hover,
.footer a:hover {
  color: var(--fb-ocra);
}

/* Articoli categoria / blog */
.blog-item,
.items-leading > div,
.items-row > div {
  background: #f6f8f2;
  border: 1px solid var(--fb-bordo);
  border-radius: 18px;
  padding: 22px;
  margin-bottom: 22px;
}

.blog-item h2,
.items-leading h2,
.items-row h2 {
  margin-top: 0;
}

/* Immagini negli articoli */
.com-content-article img,
.blog img {
  border-radius: 14px;
}

/* Mobile */
@media (max-width: 760px) {
  .com-content-article,
  .blog,
  .category-list,
  .com-content-category-blog {
    padding: 20px;
    border-radius: 16px;
  }

  .container-header .navbar-brand {
    font-size: 1.15rem;
  }
}
/* =========================================================
   Header personalizzato - La Strada Verso il Cane
   ========================================================= */

/* Nasconde il brand/logo standard di Cassiopeia */
.container-header .navbar-brand {
  display: none !important;
}

/* Annulla eventuali vecchie regole date alla prima riga header */
.container-header .grid-child:first-child {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  display: block !important;
  overflow: visible !important;
}

/* Card superiore */
.fb-site-header-shell {
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px 22px;
  background: #fbfaf6;
  border-radius: 0 0 24px 24px;
  border: 1px solid rgba(216, 205, 182, 0.75);
  border-top: none;
}

/* Layout interno */
.fb-site-header {
  display: grid;
  grid-template-columns: 230px 1fr 110px;
  gap: 28px;
  align-items: center;
}

/* Logo principale */
.fb-site-logo img {
  display: block;
  width: 230px;
  max-width: 100%;
  height: auto;
}

/* Testi centrali */
.fb-site-title {
  text-align: left;
}

.fb-site-title .fb-site-kicker {
  margin: 0 0 5px;
  color: #d99b3d;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.fb-site-main-title {
  margin: 0 0 7px;
  color: #243626;
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1.05;
  font-weight: 900;
}

.fb-site-title p {
  margin: 0;
  color: #4d3928;
  font-size: 1.15rem;
  font-weight: 700;
}

/* Logo ENCI */
.fb-site-badge {
  text-align: right;
}

.fb-site-badge img {
  width: 95px;
  max-width: 100%;
  height: auto;
  opacity: 0.95;
}

/* Barra menu */
.container-header .container-nav {
  max-width: 1180px;
  margin: 0 auto;
  padding: 9px 12px 11px;
}

.container-header .mod-menu {
  gap: 6px;
  flex-wrap: wrap;
}

.container-header .mod-menu > li > a,
.container-header .mod-menu > li > span {
  padding: 12px 11px;
  border-radius: 999px;
  color: #ffffff !important;
  font-weight: 800;
}

.container-header .mod-menu > li > a:hover,
.container-header .mod-menu > li.active > a,
.container-header .mod-menu > li.current > a {
  background: #d99b3d;
  color: #1f241d !important;
}

/* Mobile */
@media (max-width: 760px) {
  .fb-site-header-shell {
    padding: 16px;
    border-radius: 0 0 18px 18px;
  }

  .fb-site-header {
    grid-template-columns: 1fr;
    gap: 16px;
    text-align: center;
  }

  .fb-site-logo img {
    width: 240px;
    margin: 0 auto;
  }

  .fb-site-title {
    text-align: center;
  }

  .fb-site-main-title {
    font-size: 1.85rem;
  }

  .fb-site-title p {
    font-size: 1rem;
  }

  .fb-site-badge {
    text-align: center;
  }

  .fb-site-badge img {
    width: 85px;
  }
}
/* =========================================================
   Rifinitura header/menu dopo nuovo logo
   ========================================================= */

/* Header leggermente più compatto */
.fb-site-header-shell {
  padding: 14px 22px !important;
  border-radius: 0 0 22px 22px !important;
}

/* Logo principale un po' meno dominante */
.fb-site-header {
  grid-template-columns: 190px 1fr 95px !important;
  gap: 24px !important;
}

.fb-site-logo img {
  width: 190px !important;
}

.fb-site-badge img {
  width: 88px !important;
}

/* Titolo un po' più raffinato */
.fb-site-main-title {
  font-size: clamp(1.7rem, 2.7vw, 2.65rem) !important;
  letter-spacing: 0.01em;
}

.fb-site-title .fb-site-kicker {
  font-size: 0.95rem !important;
}

.fb-site-title p {
  font-size: 1.05rem !important;
}

/* Menu su una riga quando possibile */
.container-header .container-nav {
  max-width: 1180px;
  padding: 8px 10px 10px !important;
}

.container-header .mod-menu {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px !important;
  flex-wrap: wrap;
}

.container-header .mod-menu > li > a,
.container-header .mod-menu > li > span {
  padding: 10px 9px !important;
  font-size: 0.96rem;
  line-height: 1.15;
}

/* Voce attiva più elegante */
.container-header .mod-menu > li.active > a,
.container-header .mod-menu > li.current > a,
.container-header .mod-menu > li > a:hover {
  background: #d99b3d !important;
  color: #1f241d !important;
  box-shadow: 0 4px 12px rgba(217, 155, 61, 0.22);
}

/* Riduce lo spazio sopra il contenuto */
.site-grid {
  padding-top: 26px !important;
}

/* Mobile: logo meno enorme */
@media (max-width: 760px) {
  .fb-site-logo img {
    width: 210px !important;
  }

  .fb-site-header {
    grid-template-columns: 1fr !important;
  }

  .fb-site-main-title {
    font-size: 1.65rem !important;
  }

  .container-header .mod-menu {
    justify-content: center;
  }

  .container-header .mod-menu > li > a,
  .container-header .mod-menu > li > span {
    font-size: 0.95rem;
    padding: 9px 10px !important;
  }
}
/* Menu principale più compatto e su una riga */
.container-header .mod-menu {
  justify-content: center;
  gap: 10px !important;
}

.container-header .mod-menu > li > a,
.container-header .mod-menu > li > span {
  padding: 10px 12px !important;
  font-size: 0.98rem;
  white-space: nowrap;
}

/* Un filo meno spazio sotto il menu */
.container-header .container-nav {
  padding-bottom: 8px !important;
}
/* =========================================================
   FIX FINALE MENU HEADER - una riga desktop
   ========================================================= */

.container-header .container-nav {
  max-width: 1180px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 8px 26px 12px !important;
}

.container-header .mod-menu {
  width: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 0 !important;
}

.container-header .mod-menu > li {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.container-header .mod-menu > li > a,
.container-header .mod-menu > li > span {
  padding: 10px 10px !important;
  font-size: 0.94rem !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
}

/* Da tablet in giù lasciamo andare a capo */
@media (max-width: 980px) {
  .container-header .mod-menu {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 6px !important;
  }

  .container-header .mod-menu > li > a,
  .container-header .mod-menu > li > span {
    font-size: 0.92rem !important;
    padding: 9px 10px !important;
  }
}