/* ===============================================================
   eps-child / components.css
   Componenti riusabili: bottoni, card base, badge, container helper.
   =============================================================== */

/* ---------------------------------------------------------------
   Container helper (per blocchi non avvolti dal .container parent)
   --------------------------------------------------------------- */
.eps-wrap {
    max-width: var(--eps-container);
    margin-inline: auto;
    padding-inline: var(--eps-pad);
}

/* ---------------------------------------------------------------
   BOTTONI
   --------------------------------------------------------------- */
.eps-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 0.55rem;
    font-family: var(--eps-font-head);
    font-weight: 600; font-size: 1rem; line-height: 1;
    padding: 0.95rem 1.6rem;
    border-radius: var(--eps-radius-sm);
    border: 1.5px solid transparent;
    text-decoration: none !important;
    cursor: pointer;
    transition: transform var(--eps-t), background var(--eps-t), box-shadow var(--eps-t), color var(--eps-t);
}
.eps-btn:hover { transform: translateY(-2px); }

.eps-btn.--primary { background: var(--eps-blue); color: #fff !important; box-shadow: 0 6px 18px rgba(31,78,121,0.28); }
.eps-btn.--primary:hover { background: var(--eps-blue-dark); }

.eps-btn.--wa { background: #25D366; color: #0B3D26 !important; }
.eps-btn.--wa:hover { background: #1FBE5B; }

.eps-btn.--ghost { background: transparent; color: var(--eps-blue) !important; border-color: var(--eps-blue); }
.eps-btn.--ghost:hover { background: var(--eps-blue); color: #fff !important; }

.eps-btn.--light { background: #fff; color: var(--eps-slate) !important; border-color: var(--eps-line); }
.eps-btn.--light:hover { border-color: var(--eps-blue); color: var(--eps-blue) !important; }

/* Su sfondi scuri */
.eps-section.--ink .eps-btn.--ghost,
.eps-section.--slate .eps-btn.--ghost { color: #fff !important; border-color: rgba(255,255,255,0.5); }
.eps-section.--ink .eps-btn.--ghost:hover,
.eps-section.--slate .eps-btn.--ghost:hover { background: #fff; color: var(--eps-slate) !important; }

.eps-btn-row { display: flex; flex-wrap: wrap; gap: 0.8rem; align-items: center; }

/* ---------------------------------------------------------------
   CARD BASE
   --------------------------------------------------------------- */
.eps-card {
    background: #fff;
    border: 1px solid var(--eps-line);
    border-radius: var(--eps-radius);
    padding: clamp(1.5rem, 2.5vw, 2.1rem);
    box-shadow: var(--eps-shadow-sm);
    transition: transform var(--eps-t), box-shadow var(--eps-t), border-color var(--eps-t);
}
.eps-card:hover { transform: translateY(-3px); box-shadow: var(--eps-shadow); border-color: rgba(31,78,121,0.3); }
.eps-card h3 { margin-top: 0; }

/* Badge / pill */
.eps-badge {
    display: inline-flex; align-items: center; gap: 0.4rem;
    font-family: var(--eps-font-head); font-size: 0.78rem; font-weight: 600;
    letter-spacing: 0.04em;
    padding: 0.35rem 0.7rem;
    border-radius: 100px;
    background: var(--eps-stone); color: var(--eps-blue);
}

/* Icona tonda (per contatti/feature) */
.eps-icon-round {
    display: inline-flex; align-items: center; justify-content: center;
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(31,78,121,0.09); color: var(--eps-blue);
    flex: 0 0 auto;
}
.eps-icon-round svg { width: 24px; height: 24px; }
