/* ═══════════════════════════════════════════════════════════
   CYCLIQUE — BATTERIES69
   Page vitrine batteries cycliques / décharge profonde
   Chargé après global.css
═══════════════════════════════════════════════════════════ */

body, html { max-width: 100%; overflow-x: hidden; }

.skip-link {
    position: absolute;
    left: -999px;
    top: 0;
    background: var(--accent);
    color: #0a0a12;
    padding: .75rem 1rem;
    z-index: 9999;
}
.skip-link:focus { left: 1rem; top: 1rem; }

.cy-hero {
    position: relative;
    min-height: calc(100vh - 74px);
    padding: clamp(4rem, 8vw, 7rem) 0 clamp(3.8rem, 7vw, 6rem);
    overflow: hidden;
    isolation: isolate;
    background:
        radial-gradient(ellipse 68% 58% at 12% 16%, rgba(251,223,0,.08), transparent 60%),
        radial-gradient(ellipse 64% 60% at 86% 40%, rgba(139,108,248,.13), transparent 62%),
        var(--bg-deep);
}

#cy-canvas,
#cy-canvas-cta {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    opacity: .28;
    pointer-events: none;
}

.cy-hero::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 180px;
    background: linear-gradient(to bottom, transparent, var(--bg-deep));
    z-index: 1;
    pointer-events: none;
}

.cy-orb {
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    filter: blur(1px);
    z-index: 0;
}
.cy-orb-one {
    width: 420px;
    height: 420px;
    right: -110px;
    top: 16%;
    background: radial-gradient(circle, rgba(251,223,0,.14), transparent 68%);
    animation: cyFloat 9s ease-in-out infinite;
}
.cy-orb-two {
    width: 340px;
    height: 340px;
    left: -140px;
    bottom: 6%;
    background: radial-gradient(circle, rgba(139,108,248,.18), transparent 70%);
    animation: cyFloat 11s ease-in-out infinite reverse;
}
@keyframes cyFloat {
    0%, 100% { transform: translate3d(0,0,0) scale(1); }
    50% { transform: translate3d(20px,-18px,0) scale(1.04); }
}

.cy-hero-grid {
    position: relative;
    z-index: 3;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .78fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
}

.cy-hero h1 {
    font-family: var(--font-heading);
    font-weight: 900;
    letter-spacing: -.055em;
    line-height: .92;
    margin: 1.1rem 0 1.4rem;
    font-size: clamp(52px, 8vw, 104px);
    color: var(--text-primary);
}
.cy-hero h1 em,
.section-title em {
    font-style: normal;
    display: inline-block;
    padding: 0 .12em .05em 0;
    background: linear-gradient(135deg, var(--accent), #ffb800 42%, var(--secondary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.cy-hero p {
    max-width: 680px;
    color: var(--text-secondary);
    font-size: clamp(15px, 1.7vw, 18px);
    line-height: 1.75;
    margin: 0 0 2rem;
}

.cy-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}
.cy-actions.center { justify-content: center; }

.cy-keywords {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1.4rem;
}
.cy-keywords span,
.cy-checklist li,
.cy-tech-card,
.cy-use-card,
.cy-brand-card,
.cy-step,
.cy-cta-card {
    border: 1px solid var(--border-card);
    background: rgba(255,255,255,.035);
}

.cy-keywords span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: .48rem .75rem;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.cy-hero-panel {
    position: relative;
    min-height: 480px;
    display: grid;
    place-items: center;
}

.cy-battery-visual {
    width: min(88vw, 370px);
    transform: rotate(-5deg);
    filter: drop-shadow(0 35px 70px rgba(0,0,0,.52));
    position: relative;
    isolation: isolate;
}
.cy-terminal-row {
    position: absolute;
    left: 50%;
    top: -18px;
    width: 54%;
    transform: translateX(-50%);
    display: flex;
    justify-content: space-between;
    z-index: 3;
}
.cy-terminal-row span {
    width: 42px;
    height: 24px;
    border-radius: 10px 10px 5px 5px;
    background: linear-gradient(180deg, #444455, #191925);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
}
.cy-battery-top {
    height: 24px;
    width: 68%;
    margin: 0 auto;
    border-radius: 20px 20px 8px 8px;
    background: linear-gradient(180deg, #292939, #151523);
    border: 1px solid rgba(255,255,255,.08);
}
.cy-battery-body {
    min-height: 320px;
    border-radius: 28px;
    background:
        radial-gradient(ellipse 65% 45% at 22% 18%, rgba(255,255,255,.36), transparent 58%),
        linear-gradient(140deg, rgba(251,223,0,.96), rgba(255,190,18,.90) 42%, rgba(139,108,248,.94) 43%, rgba(31,29,56,.98) 100%);
    border: 1px solid rgba(255,255,255,.12);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 1.45rem;
    color: #090812;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,.16),
        inset -18px 0 42px rgba(0,0,0,.16);
    overflow: hidden;
    position: relative;
}
.cy-battery-body::before {
    content: "";
    position: absolute;
    inset: 12px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.18);
    pointer-events: none;
}
.cy-battery-label {
    display: grid;
    gap: .35rem;
    margin-top: auto;
    margin-bottom: auto;
    position: relative;
    z-index: 1;
}
.cy-battery-label span {
    font-family: var(--font-mono, monospace);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .14em;
}
.cy-battery-label strong {
    color: #090812;
    font-family: var(--font-heading);
    font-size: clamp(58px, 7vw, 92px);
    line-height: .9;
    letter-spacing: 0;
}
.cy-battery-label small {
    color: rgba(9,8,18,.78);
    font-weight: 900;
    letter-spacing: .08em;
}
.cy-energy-gauge {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .45rem;
}
.cy-energy-gauge i {
    height: 12px;
    border-radius: 999px;
    background: rgba(9,8,18,.80);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
}
.cy-energy-gauge i:nth-child(4) {
    background: rgba(255,255,255,.58);
}
.cy-cycle-rings {
    position: absolute;
    right: 1.3rem;
    bottom: 3.15rem;
    display: flex;
    gap: .45rem;
    z-index: 1;
}
.cy-cycle-rings span {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,.55);
    border-left-color: rgba(9,8,18,.72);
    display: block;
}
.cy-battery-glow {
    position: absolute;
    inset: 8%;
    background: radial-gradient(circle, rgba(251,223,0,.25), transparent 66%);
    z-index: -1;
    filter: blur(32px);
}

.cy-checklist {
    position: absolute;
    bottom: 0;
    right: 0;
    display: grid;
    gap: .65rem;
    list-style: none;
    width: min(310px, 90%);
}
.cy-checklist li {
    border-radius: 18px;
    padding: .9rem 1rem;
    backdrop-filter: blur(14px);
}
.cy-checklist strong {
    display: block;
    color: var(--accent);
    line-height: 1.2;
}
.cy-checklist span {
    display: block;
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.35;
    margin-top: .2rem;
}

.cy-section {
    padding: clamp(3.6rem, 7vw, 5.6rem) 0;
    position: relative;
    background: var(--bg-primary);
}
.cy-section:nth-of-type(even) { background: var(--bg-surface); }

.section-header {
    text-align: center;
    max-width: 780px;
    margin: 0 auto 2.5rem;
}
.section-sub {
    color: var(--text-secondary);
    line-height: 1.75;
}

.cy-use-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 1rem;
}
.cy-use-card,
.cy-tech-card,
.cy-brand-card,
.cy-step {
    border-radius: var(--radius-lg);
    padding: 1.35rem;
    transition: var(--transition-smooth);
}
.cy-use-card:hover,
.cy-tech-card:hover,
.cy-brand-card:hover,
.cy-step:hover {
    transform: translateY(-4px);
    border-color: rgba(251,223,0,.24);
    box-shadow: 0 18px 48px rgba(0,0,0,.24);
}
.cy-icon {
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 24px;
    margin-bottom: 1rem;
}
.cy-use-card h3,
.cy-tech-card h3,
.cy-brand-card strong,
.cy-step h3 {
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: 18px;
    line-height: 1.15;
    margin-bottom: .55rem;
}
.cy-use-card p,
.cy-tech-card p,
.cy-brand-card span,
.cy-step p {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
}

.cy-tech {
    overflow: hidden;
}
.cy-tech-grid {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
    gap: clamp(1.5rem, 4vw, 4rem);
    align-items: center;
}
.cy-tech-copy .section-title,
.cy-tech-copy .section-sub,
.cy-tech-copy {
    text-align: left;
}
.cy-tech-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 1rem;
}
.cy-tech-card {
    min-height: 190px;
    background:
        radial-gradient(ellipse at 15% 0%, rgba(251,223,0,.08), transparent 48%),
        rgba(255,255,255,.035);
}

.cy-brand-zone {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(139,108,248,.10), transparent 62%),
        var(--bg-primary);
}
.cy-brand-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 1rem;
}
.cy-brand-card {
    border-radius: 999px;
    padding: 1rem 1.15rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 96px;
}
.cy-brand-card strong {
    margin-bottom: .25rem;
    color: var(--accent);
}

.cy-process {
    padding: clamp(3.6rem, 7vw, 5.6rem) 0;
    background: var(--bg-deep);
}
.cy-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 1rem;
}
.cy-step {
    position: relative;
    overflow: hidden;
}
.cy-step span {
    display: inline-block;
    font-family: var(--font-heading);
    color: var(--accent);
    font-size: 38px;
    font-weight: 900;
    letter-spacing: -.05em;
    margin-bottom: .5rem;
    opacity: .9;
}

.cy-final-cta {
    position: relative;
    overflow: hidden;
    padding: clamp(4rem, 8vw, 6.4rem) 0;
    background:
        radial-gradient(ellipse 70% 80% at 50% 0%, rgba(251,223,0,.10), transparent 62%),
        radial-gradient(ellipse 60% 60% at 88% 80%, rgba(139,108,248,.12), transparent 60%),
        var(--bg-primary);
}
.cy-cta-card {
    position: relative;
    z-index: 1;
    border-radius: var(--radius-xl);
    padding: clamp(2rem, 5vw, 4rem);
    text-align: center;
    backdrop-filter: blur(18px);
}
.cy-cta-card h2 {
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: clamp(32px, 5vw, 62px);
    line-height: .98;
    letter-spacing: -.04em;
    margin: 1rem 0;
}
.cy-cta-card p {
    color: var(--text-secondary);
    max-width: 680px;
    margin: 0 auto 1.7rem;
    line-height: 1.75;
}

#back-to-top {
    position: fixed;
    right: 1.15rem;
    bottom: 1.15rem;
    width: 46px;
    height: 46px;
    border-radius: 999px;
    border: 1px solid var(--border-card);
    background: var(--bg-card);
    color: var(--accent);
    display: grid;
    place-items: center;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px);
    transition: var(--transition-smooth);
    z-index: 450;
}
#back-to-top.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

/* Mode clair spécifique */
html[data-theme="light"] .cy-hero {
    background:
        radial-gradient(ellipse 68% 58% at 12% 16%, rgba(245,179,1,.16), transparent 60%),
        radial-gradient(ellipse 64% 60% at 86% 40%, rgba(122,76,240,.12), transparent 62%),
        #fff8e9 !important;
}
html[data-theme="light"] .cy-battery-body {
    background:
        linear-gradient(135deg, rgba(245,179,1,.96), rgba(255,204,47,.88) 36%, rgba(122,76,240,.88) 37%, rgba(255,255,255,.88) 100%) !important;
}
html[data-theme="light"] .cy-battery-label strong,
html[data-theme="light"] .cy-battery-label span,
html[data-theme="light"] .cy-battery-label small {
    color: #19140c !important;
}
html[data-theme="light"] .cy-energy-gauge i {
    background: rgba(25,20,12,.76) !important;
}
html[data-theme="light"] .cy-energy-gauge i:nth-child(4) {
    background: rgba(255,255,255,.68) !important;
}
html[data-theme="light"] .cy-checklist li,
html[data-theme="light"] .cy-keywords span,
html[data-theme="light"] .cy-use-card,
html[data-theme="light"] .cy-tech-card,
html[data-theme="light"] .cy-brand-card,
html[data-theme="light"] .cy-step,
html[data-theme="light"] .cy-cta-card {
    background: rgba(255,255,255,.76) !important;
    border-color: rgba(66,45,12,.14) !important;
    box-shadow: 0 12px 34px rgba(158,101,0,.10) !important;
}
html[data-theme="light"] .cy-final-cta {
    background:
        radial-gradient(ellipse 70% 80% at 50% 0%, rgba(245,179,1,.16), transparent 62%),
        radial-gradient(ellipse 60% 60% at 88% 80%, rgba(122,76,240,.14), transparent 60%),
        #fff4dd !important;
}

/* Responsive */
@media (max-width: 980px) {
    .cy-hero-grid,
    .cy-tech-grid {
        grid-template-columns: 1fr;
    }
    .cy-hero-panel {
        min-height: 430px;
    }
    .cy-use-grid,
    .cy-brand-grid {
        grid-template-columns: repeat(2, minmax(0,1fr));
    }
    .cy-tech-cards,
    .cy-steps {
        grid-template-columns: 1fr;
    }
    .cy-tech-copy .section-title,
    .cy-tech-copy .section-sub,
    .cy-tech-copy { text-align: center; }
}
@media (max-width: 640px) {
    .cy-hero {
        min-height: auto;
        padding: 3.2rem 0 3.8rem;
    }
    .cy-hero h1 {
        font-size: clamp(46px, 15vw, 68px);
    }
    .cy-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .cy-actions a {
        width: 100%;
        justify-content: center;
    }
    .cy-use-grid,
    .cy-brand-grid {
        grid-template-columns: 1fr;
    }
    .cy-hero-panel {
        min-height: 380px;
    }
    .cy-battery-visual {
        width: min(78vw, 310px);
    }
    .cy-battery-body {
        min-height: 260px;
    }
    .cy-checklist {
        position: relative;
        width: 100%;
        margin-top: 1rem;
    }
    .cy-brand-card {
        border-radius: 20px;
    }
}


/* ═══════════════════════════════════════════════════════════
   REPRISE FINALE : CTA PARTICULES, PRODUITS PHARES, FOOTER
═══════════════════════════════════════════════════════════ */

/* Logos marques discrets */
.brand-logo-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .7rem;
    margin: -1rem auto 2rem;
}
.brand-logo-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: .55rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--border-card);
    background: rgba(255,255,255,.035);
    color: var(--text-secondary);
    font-family: var(--font-heading);
    font-weight: 900;
    letter-spacing: .08em;
    line-height: 1;
    text-transform: uppercase;
    box-shadow: 0 12px 32px rgba(0,0,0,.16);
    opacity: .86;
}
.brand-logo-pill.small {
    min-height: 30px;
    padding: .42rem .7rem;
    font-size: 11px;
    letter-spacing: .07em;
}
.yuasa-word { color: #e7392e; background: rgba(231,57,46,.08); border-color: rgba(231,57,46,.18); }
.steco-word { color: var(--accent); background: var(--accent-soft); border-color: rgba(251,223,0,.18); }
.leoch-word { color: #6fa8ff; background: rgba(111,168,255,.08); border-color: rgba(111,168,255,.18); }
.trojan-word { color: #9ad37b; background: rgba(154,211,123,.08); border-color: rgba(154,211,123,.18); }
.optima-word { color: #ffb000; background: rgba(255,176,0,.09); border-color: rgba(255,176,0,.18); }

.cy-product-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
}
.cy-product-card {
    border: 1px solid var(--border-card);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(ellipse 70% 60% at 15% 0%, rgba(251,223,0,.06), transparent 60%),
        rgba(255,255,255,.035);
    padding: 1.25rem;
    transition: var(--transition-smooth);
    min-height: 310px;
}
.cy-product-card:hover {
    transform: translateY(-4px);
    border-color: rgba(251,223,0,.24);
    box-shadow: 0 18px 48px rgba(0,0,0,.25);
}
.cy-product-head {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: .5rem;
    margin-bottom: 1rem;
}
.cy-product-head .brand-logo-pill {
    flex: 0 1 136px;
    min-height: 42px;
    min-width: 112px;
}
.cy-product-head .brand-logo-pill img {
    max-height: 28px;
    max-width: 118px;
}
.cy-product-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(139,108,248,.10);
    color: #b8a6ff;
    border: 1px solid rgba(139,108,248,.18);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .35rem .55rem;
}
.cy-product-card h3 {
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: 19px;
    line-height: 1.1;
    margin-bottom: .7rem;
}
.cy-product-card p {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
}
.cy-product-card ul {
    margin-top: 1rem;
    display: grid;
    gap: .45rem;
    padding-left: 0;
    list-style: none;
}
.cy-product-card li {
    position: relative;
    padding-left: 1rem;
    color: var(--text-secondary);
    font-size: 12.5px;
    line-height: 1.45;
}
.cy-product-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .6em;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--accent);
}

/* CTA façon chargeurs */
.quote-section-cyclique {
    position: relative;
    overflow: hidden;
    padding: clamp(4rem, 8vw, 6.4rem) 0;
    background:
        radial-gradient(ellipse 72% 75% at 50% 0%, rgba(251,223,0,.10), transparent 62%),
        radial-gradient(ellipse 60% 64% at 90% 85%, rgba(139,108,248,.14), transparent 60%),
        var(--bg-primary);
}
.quote-card-particles {
    position: relative;
    overflow: hidden;
}
.quote-card-particles canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: .32;
    pointer-events: none;
    z-index: 0;
}
.quote-card-particles > *:not(canvas) {
    position: relative;
    z-index: 1;
}
.contact-square-card {
    border: 1px solid var(--border-card);
    border-radius: var(--radius-xl);
    background:
        radial-gradient(ellipse 70% 90% at 8% 0%, rgba(251,223,0,.11), transparent 58%),
        radial-gradient(ellipse 62% 82% at 95% 100%, rgba(139,108,248,.16), transparent 60%),
        rgba(255,255,255,.035);
    box-shadow: 0 30px 100px rgba(0,0,0,.42), 0 0 80px rgba(251,223,0,.06);
    padding: clamp(2rem, 5vw, 4rem);
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(270px, .72fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
    backdrop-filter: blur(18px);
}
.quote-content .section-title {
    text-align: left;
    margin: 1rem 0;
}
.left-sub {
    text-align: left;
    max-width: 720px;
}
.quote-mini-proof {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1rem;
}
.quote-mini-proof span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--border-card);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
    padding: .45rem .7rem;
}
.quote-actions-cyclique {
    display: grid;
    gap: .8rem;
}
.quote-action {
    min-height: 58px;
    display: flex;
    align-items: center;
    gap: .75rem;
    border-radius: 18px;
    border: 1px solid var(--border-card);
    background: rgba(255,255,255,.035);
    color: var(--text-primary);
    text-decoration: none;
    padding: .85rem 1rem;
    transition: var(--transition-bounce);
}
.quote-action span {
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: var(--accent-soft);
    color: var(--accent);
    flex: 0 0 auto;
}
.quote-action strong {
    color: var(--text-primary);
    font-size: 14px;
}
.quote-action:hover {
    transform: translateY(-3px);
    border-color: rgba(251,223,0,.24);
    background: var(--accent-soft);
}
.quote-action-call {
    background: linear-gradient(135deg, var(--accent), #ffca35);
    color: #0a0a12;
    border-color: var(--accent);
    box-shadow: 0 12px 34px rgba(251,223,0,.22);
}
.quote-action-call strong,
.quote-action-call span {
    color: #0a0a12;
}
.quote-action-call span {
    background: rgba(0,0,0,.08);
}

/* Même retour en haut que chargeurs, avec fallback si global non présent */
#back-to-top {
    position: fixed;
    right: 1.15rem;
    bottom: 1.15rem;
    width: 46px;
    height: 46px;
    border-radius: 999px;
    border: 1px solid var(--border-card);
    background: var(--bg-card);
    color: var(--accent);
    display: grid;
    place-items: center;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px);
    transition: var(--transition-smooth);
    z-index: 450;
}
#back-to-top.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
#back-to-top svg {
    width: 22px;
    height: 22px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2.5;
}

/* Footer ancien format, déjà utilisé par les autres pages */
footer {
    background: var(--bg-deep);
    border-top: 1px solid var(--border-subtle);
    padding: 2.2rem 0;
}
.footer-inner {
    width: min(1240px, calc(100% - 2.5rem));
    margin: 0 auto;
    display: grid;
    gap: 1rem;
    place-items: center;
    text-align: center;
}
.footer-logo img {
    height: 44px;
    width: auto;
    max-width: min(178px, 80vw);
    object-fit: contain;
}
.footer-inner p {
    color: var(--text-secondary);
    font-size: 13px;
}
.footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: center;
    justify-content: center;
}
.footer-links a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 13px;
    transition: var(--transition-fast);
}
.footer-links a:hover,
.footer-links a.footer-active {
    color: var(--accent);
}
.footer-linkedin,
.footer-contact-icon {
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid var(--border-card);
    background: rgba(255,255,255,.035);
}
.glow-pulse { color: var(--accent); }
.glow-pulse-blue { color: #4b7cff; }
.glow-pulse-white { color: var(--text-primary); }
.glow-pulse-red { color: #ff4b4b; }

/* Light mode */
html[data-theme="light"] .brand-logo-pill,
html[data-theme="light"] .cy-product-card,
html[data-theme="light"] .contact-square-card,
html[data-theme="light"] .quote-mini-proof span,
html[data-theme="light"] .quote-action {
    background: rgba(255,255,255,.76) !important;
    border-color: rgba(66,45,12,.14) !important;
    box-shadow: 0 12px 34px rgba(158,101,0,.10) !important;
}
html[data-theme="light"] .quote-section-cyclique {
    background:
        radial-gradient(ellipse 72% 75% at 50% 0%, rgba(245,179,1,.16), transparent 62%),
        radial-gradient(ellipse 60% 64% at 90% 85%, rgba(122,76,240,.14), transparent 60%),
        #fff4dd !important;
}
html[data-theme="light"] .quote-card-particles canvas {
    opacity: .32 !important;
    filter: saturate(1.2) contrast(1.05) !important;
}
html[data-theme="light"] .quote-action-call {
    background: linear-gradient(135deg, var(--accent), #ffca35) !important;
}
html[data-theme="light"] .quote-action-call strong,
html[data-theme="light"] .quote-action-call span {
    color: #171108 !important;
}
html[data-theme="light"] .cy-product-chip {
    color: var(--secondary) !important;
    background: var(--secondary-soft) !important;
}
html[data-theme="light"] footer {
    background: #fff5df !important;
    border-top-color: rgba(66,45,12,.10) !important;
}

/* Responsive */
@media (max-width: 1180px) {
    .cy-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 820px) {
    .contact-square-card {
        grid-template-columns: 1fr;
    }
    .quote-content .section-title,
    .left-sub {
        text-align: center;
    }
    .quote-mini-proof {
        justify-content: center;
    }
    .cy-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 560px) {
    .cy-product-grid {
        grid-template-columns: 1fr;
    }
    .quote-action {
        min-height: 54px;
    }
    .footer-inner {
        width: min(100% - 2rem, 1240px);
    }
}


/* ═══════════════════════════════════════════════════════════
   LOGOS MARQUES — imagesWEBP/<marque>.webp avec fallback texte
═══════════════════════════════════════════════════════════ */
.brand-logo-pill {
    gap: .48rem;
}
.brand-logo-pill img {
    display: block;
    max-height: 26px;
    max-width: 118px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 6px 14px rgba(0,0,0,.25));
}
.brand-logo-pill span {
    line-height: 1;
}
.brand-logo-pill:not(.logo-fallback) span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
}
.brand-logo-pill.logo-fallback span {
    position: static;
    width: auto;
    height: auto;
    overflow: visible;
    clip-path: none;
    white-space: nowrap;
}
html[data-theme="light"] .brand-logo-pill img {
    filter: drop-shadow(0 4px 10px rgba(80,50,0,.16));
}


/* ═══════════════════════════════════════════════════════════
   CYCLIQUE — boutons hero visibles
═══════════════════════════════════════════════════════════ */
.cy-actions .btn-primary,
.cy-actions .btn-outline {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: .55rem !important;
    min-height: 50px !important;
    padding: 0 1.25rem !important;
    border-radius: 999px !important;
    text-decoration: none !important;
    font-weight: 900 !important;
    font-size: 14px !important;
    line-height: 1 !important;
    transition: var(--transition-bounce, .35s ease) !important;
    white-space: nowrap !important;
    position: relative !important;
    z-index: 4 !important;
}
.cy-actions .btn-primary {
    background: linear-gradient(135deg, var(--accent), #ffca35) !important;
    color: #0a0a12 !important;
    border: 1px solid var(--accent) !important;
    box-shadow: 0 12px 34px rgba(251,223,0,.22) !important;
}
.cy-actions .btn-outline {
    color: var(--text-primary) !important;
    background: rgba(255,255,255,.045) !important;
    border: 1px solid var(--border-card) !important;
    backdrop-filter: blur(10px) !important;
}
.cy-actions .btn-primary:hover,
.cy-actions .btn-outline:hover {
    transform: translateY(-3px) !important;
}
.cy-actions .btn-outline:hover {
    color: var(--accent) !important;
    background: var(--accent-soft) !important;
    border-color: rgba(251,223,0,.28) !important;
}
html[data-theme="light"] .cy-actions .btn-outline {
    background: rgba(255,255,255,.68) !important;
    color: var(--text-primary) !important;
    border-color: rgba(66,45,12,.14) !important;
}
@media (max-width: 640px) {
    .cy-actions .btn-primary,
    .cy-actions .btn-outline {
        width: 100% !important;
    }
}
