/**
 * CEV Style Profile: ATLEG — Éditorial
 *
 * Overrides appliqués quand le profil "ATLEG" est sélectionné dans l'admin.
 * Chargé après cev-widgets.css — ne contient que les différences.
 */

/* =============================================
   Variables
   ============================================= */
:root {
    --cev-container: 1240px;
    --cev-section-py: 96px;
    --cev-shadow-hover: 0 12px 32px rgba(4, 97, 29, .14), 0 2px 8px rgba(0, 0, 0, .06);
}

/* =============================================
   Section header
   ============================================= */
.cev-section-label {
    font-weight: 700;
    letter-spacing: .14em;
}

.cev-section-h2 {
    font-size: clamp(38px, 5vw, 54px);
    line-height: 1.15;
    letter-spacing: -.01em;
    margin-bottom: 20px;
}

.cev-section-h2 em {
    font-style: italic;
    font-size: clamp(40px, 5.4vw, 58px);
}

.cev-section-intro {
    font-size: 19px;
    max-width: 640px;
}

/* =============================================
   Buttons
   ============================================= */
.cev-btn {
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 16px 32px;
    transition: all .25s ease;
}

.cev-btn:hover {
    transform: translateY(-3px);
}

.cev-btn:active {
    transform: translateY(-1px);
}

.cev-btn--primary:hover {
    box-shadow: 0 12px 28px rgba(81, 176, 72, .45);
}

.cev-btn--outline:hover {
    box-shadow: 0 12px 28px rgba(4, 97, 29, .32);
}

/* =============================================
   Badge pill
   ============================================= */
.cev-badge-pill {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-color: rgba(255, 255, 255, .35);
}

/* =============================================
   Hero
   ============================================= */
.cev-hero-title {
    font-weight: 600;
    font-size: clamp(42px, 5.6vw, 62px);
    letter-spacing: -.015em;
    text-shadow: 0 2px 20px rgba(0, 0, 0, .35);
}

.cev-hero-title em {
    color: #b8f0a8;
    font-style: italic;
    font-weight: 700;
}

.cev-hero-desc {
    text-shadow: 0 1px 12px rgba(0, 0, 0, .3);
}

/* =============================================
   Services grid
   ============================================= */
.cev-service-card {
    border-color: rgba(4, 97, 29, .10);
}

.cev-service-card:hover {
    border-color: rgba(81, 176, 72, .45);
}

.cev-service-body h3 {
    font-size: 26px;
    line-height: 1.25;
}

.cev-service-body p {
    font-size: 15px;
}

.cev-service-tag {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.cev-service-icon-fab {
    width: 56px;
    height: 56px;
    box-shadow: 0 8px 22px rgba(4, 97, 29, .4);
}

.cev-service-link {
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* =============================================
   Process steps
   ============================================= */
.cev-step-num {
    background: var(--cev-secondary);
    width: 48px;
    height: 48px;
    font-size: 22px;
    font-family: var(--cev-serif);
    box-shadow: 0 8px 18px rgba(81, 176, 72, .4);
}

.cev-step-title {
    font-size: 22px;
}

.cev-step-card:hover {
    transform: translateY(-4px);
}

/* =============================================
   Stats counter
   ============================================= */
.cev-stat-num {
    font-size: clamp(48px, 6vw, 72px);
    font-weight: 700;
}

/* =============================================
   CTA Banner
   ============================================= */
.cev-cta-title {
    font-weight: 600;
    font-size: clamp(36px, 5vw, 52px);
}

.cev-cta-desc {
    font-size: 18px;
}

/* =============================================
   Featured split
   ============================================= */
@media (min-width: 768px) {
    .cev-featured-grid {
        gap: 72px;
    }
}

.cev-featured-image img {
    border-radius: 24px;
    box-shadow: 0 30px 60px -22px rgba(4, 97, 29, .4);
}

.cev-feature-list li {
    font-size: 16px;
    font-weight: 500;
    padding: 14px 0;
    border-bottom: 1px solid rgba(4, 97, 29, .08);
}

.cev-check {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--cev-light);
}

/* =============================================
   Icon cards
   ============================================= */
.cev-icon-card {
    border-color: rgba(4, 97, 29, .10);
}

.cev-icon-card:hover {
    border-color: rgba(81, 176, 72, .4);
}

.cev-icon-card h3 {
    font-size: 24px;
    line-height: 1.3;
}

.cev-icon-card p {
    font-size: 15px;
}

/* =============================================
   Big number
   ============================================= */
.cev-bignumber-num {
    font-weight: 600;
}

.cev-bignumber-ref {
    letter-spacing: .18em;
}

/* =============================================
   Animations
   ============================================= */
.cev-animate {
    transition-duration: .7s;
    transition-timing-function: ease;
}

/* =============================================
   Responsive — mobile (<=479px)
   ============================================= */
@media (max-width: 479px) {
    :root {
        --cev-section-py: 64px;
    }

    .cev-hero {
        padding-top: 56px;
        padding-bottom: 56px;
    }

    .cev-hero-title {
        font-size: clamp(28px, 7vw, 42px);
    }

    .cev-section-h2 {
        font-size: clamp(28px, 4vw, 38px);
    }

    .cev-btn {
        padding: 14px 24px;
    }
}
