/* =========================================================
   Due Emme Recinzioni - Pagina Prodotti
   Classi scoped con prefisso .dem-prod- per non collidere col template X5.
   Questo file e' caricato SOLO in prodotti.html.
   Tutte le override del template sono scoped a body.dueemme-prodotti-body
   => valgono ESCLUSIVAMENTE su prodotti.html.
   ========================================================= */

/* ---- FIX CONTENITORE PADRE -----------------------------------------
   pcss/prodotti.css trasforma #imContent in una griglia X5 da ~108
   micro-colonne (serve a posizionare le celle native imCell_N). Il
   contenuto ricostruito a mano NON e' un figlio-griglia X5: senza
   neutralizzare quella griglia le <section> finiscono in una colonnina
   da ~10px (contenuto schiacciato a sinistra, hero ~300px).
   Qui si forza l'intera catena di contenitori a tutta larghezza.
   -------------------------------------------------------------------- */
body.dueemme-prodotti-body #imPageExtContainer,
body.dueemme-prodotti-body #imPageIntContainer {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
}
body.dueemme-prodotti-body #imContentGraphics {
    display: none !important;
}
body.dueemme-prodotti-body #imContent {
    display: block !important;
    grid-column: 1 / 4 !important;
    grid-row: 2 / 3 !important;
    justify-self: stretch !important;
    align-self: stretch !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    float: none !important;
    position: relative !important;
}
body.dueemme-prodotti-body #imContent > .dem-prod {
    width: 100% !important;
    max-width: none !important;
    float: none !important;
}

.dem-prod {
    font-family: 'Roboto', 'Segoe UI', system-ui, sans-serif;
    color: #333;
    line-height: 1.6;
    box-sizing: border-box;
    width: 100%;
}
.dem-prod *,
.dem-prod *::before,
.dem-prod *::after { box-sizing: border-box; }

/* contenuto centrato di ogni sezione */
.dem-prod-wrap {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ---- 1. HERO ---- */
.dem-prod-hero {
    width: 100%;
    background: linear-gradient(135deg, #5f8f3a 0%, #7fa34c 100%);
    color: #fff;
    padding: 64px 0;
    text-align: center;
}
.dem-prod-hero-title {
    font-size: 34px;
    font-weight: 700;
    margin: 0 0 12px;
    line-height: 1.2;
}
.dem-prod-hero-sub {
    font-size: 18px;
    opacity: 0.96;
    margin: 0 auto;
    max-width: 720px;
}

/* ---- 2. INTRO ---- */
.dem-prod-intro {
    padding: 48px 0 12px;
}
.dem-prod-intro p {
    font-size: 16.5px;
    margin: 0 0 16px;
}
.dem-prod-intro-tech {
    background: #f4f6f0;
    border-left: 4px solid #7FA34C;
    padding: 16px 20px;
    border-radius: 8px;
    font-size: 15.5px;
}

/* ---- Titoli sezione ---- */
.dem-prod-h2 {
    font-size: 26px;
    font-weight: 700;
    color: #37474F;
    text-align: center;
    margin: 0 0 6px;
}
.dem-prod-section-sub {
    text-align: center;
    color: #666;
    margin: 0 0 26px;
    font-size: 15.5px;
}

/* ---- Griglie card ---- */
.dem-prod-grid {
    display: grid;
    gap: 26px;
    margin-top: 26px;
}
.dem-prod-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.dem-prod-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.dem-prod-card {
    background: #fff;
    border: 1px solid rgba(95, 143, 58, .18);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .06);
    display: flex;
    flex-direction: column;
}
.dem-prod-card img {
    width: 100%;
    max-width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    border-radius: 18px 18px 0 0;
}
.dem-prod-card-body {
    padding: 22px 24px 26px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.dem-prod-card-body h3 {
    font-size: 20px;
    color: #37474F;
    margin: 0 0 10px;
}
.dem-prod-card-body p {
    font-size: 15px;
    color: #555;
    margin: 0 0 16px;
}

/* ---- Specifiche ---- */
.dem-prod-specs {
    list-style: none;
    margin: auto 0 0;
    padding: 0;
    border-top: 1px solid #eee;
}
.dem-prod-specs li {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid #f0f0f0;
    font-size: 14.5px;
}
.dem-prod-specs li:last-child { border-bottom: none; }
.dem-prod-specs li span { color: #888; }
.dem-prod-specs li strong { color: #37474F; }

/* ---- Sezione sistema / configurazioni ---- */
.dem-prod-system { padding: 48px 0; }
.dem-prod-config { padding: 12px 0 48px; background: #fafafa; }
.dem-prod-config-note {
    text-align: center;
    margin: 30px 0 0;
    font-size: 15px;
    color: #555;
}
.dem-prod-config-note a { color: #5f8f3a; font-weight: 600; }

/* ---- Bottoni ---- */
.dem-prod-btn {
    display: inline-block;
    padding: 12px 24px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    text-align: center;
    transition: background-color .2s ease, transform .15s ease;
}
.dem-prod-btn:hover { transform: translateY(-1px); }
.dem-prod-btn-outline {
    border: 2px solid #7FA34C;
    color: #5a7a35;
    background: #fff;
    margin-top: auto;
}
.dem-prod-btn-outline:hover { background: #7FA34C; color: #fff; }
.dem-prod-btn-primary { background: #5f8f3a; color: #fff; }
.dem-prod-btn-primary:hover { background: #4d7530; color: #fff; }
.dem-prod-btn-dark { background: #37474F; color: #fff; }
.dem-prod-btn-dark:hover { background: #263238; color: #fff; }

/* ---- 5. VANTAGGI ---- */
.dem-prod-benefits { padding: 48px 0; }
.dem-prod-benefits-list {
    list-style: none;
    margin: 26px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}
.dem-prod-benefits-list li {
    background: #fff;
    border: 1px solid rgba(95, 143, 58, .18);
    border-radius: 14px;
    padding: 20px 22px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .04);
}
.dem-prod-benefits-list li strong {
    display: block;
    color: #37474F;
    font-size: 16px;
    margin-bottom: 6px;
}
.dem-prod-benefits-list li span {
    font-size: 14px;
    color: #666;
}

/* ---- 6. UTILIZZI ---- */
.dem-prod-uses { padding: 12px 0 56px; background: #fafafa; }
.dem-prod-uses-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 26px;
}
.dem-prod-use {
    background: #37474F;
    color: #fff;
    text-align: center;
    padding: 18px 14px;
    border-radius: 12px;
    font-size: 15.5px;
    font-weight: 600;
}

/* ---- 7. CTA FINALE ---- */
.dem-prod-cta {
    background: linear-gradient(135deg, #37474F 0%, #263238 100%);
    color: #fff;
    padding: 56px 0;
    text-align: center;
}
.dem-prod-cta-title {
    font-size: 25px;
    font-weight: 700;
    margin: 0 auto 26px;
    color: #fff;
    max-width: 760px;
    line-height: 1.3;
}
.dem-prod-cta-buttons {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}
.dem-prod-cta .dem-prod-btn-primary { background: #7daa4d; }
.dem-prod-cta .dem-prod-btn-primary:hover { background: #5f8f3a; }
.dem-prod-cta .dem-prod-btn-dark {
    background: #fff;
    color: #37474F;
}
.dem-prod-cta .dem-prod-btn-dark:hover { background: #e8e8e8; color: #37474F; }

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
    .dem-prod-grid-2,
    .dem-prod-grid-3 { grid-template-columns: 1fr; }
    .dem-prod-benefits-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .dem-prod-uses-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .dem-prod-hero { padding: 48px 0; }
    .dem-prod-hero-title { font-size: 28px; }
}
@media (max-width: 600px) {
    .dem-prod-wrap { padding: 0 16px; }
    .dem-prod-hero { padding: 40px 0; }
    .dem-prod-hero-title { font-size: 24px; }
    .dem-prod-hero-sub { font-size: 15.5px; }
    .dem-prod-h2 { font-size: 22px; }
    .dem-prod-system,
    .dem-prod-benefits { padding: 36px 0; }
    .dem-prod-benefits-list { grid-template-columns: 1fr; }
    .dem-prod-uses-grid { grid-template-columns: 1fr; }
    .dem-prod-cta-title { font-size: 21px; }
    .dem-prod-cta-buttons { flex-direction: column; }
    .dem-prod-cta-buttons .dem-prod-btn { width: 100%; }
    /* spazio extra per non far coprire la CTA finale dalla barra CTA flottante */
    .dem-prod-cta { padding-bottom: 96px; }
}
