/*
Theme Name: AfriCallShop
Theme URI: https://www.africallshop.com
Author: AfriCallShop
Description: AfriCallShop child theme on top of Blocksy. Brings back the legacy Startit/Qode templates + WPBakery shortcodes the site relies on, while benefiting from Blocksy's modern, lightweight base for SEO/Core Web Vitals.
Template: blocksy
Version: 0.2.0-design
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: africallshop
Tags: child-theme, blocksy, wpbakery, qode-compat
*/

/* =============================================================================
   AfriCallShop — Wise-like fintech design system
   =============================================================================
   Goals:
   - Strong brand presence (AfriCallShop blue) on a generous white canvas.
   - Tight, readable typography with Inter/system stack fallback.
   - Predictable spacing scale (4px-based).
   - Surgical overrides over Qode/Startit — DON'T touch admin / WPBakery editor.
   ============================================================================= */


/* ----------------------------------------------------------------------------
   1. Design tokens — Brand-led: AfriCallShop logo green is dominant. Generous whites,
   strong hero, dense-but-aerated layout.
---------------------------------------------------------------------------- */
:root {
    /* Brand — AfriCallShop official logo palette (extracted from logo.png) */
    --acs-brand:           #93CA4B; /* lime green from the map silhouette — dominant */
    --acs-brand-strong:    #7AB33A; /* hover / darker variant */
    --acs-brand-deep:      #5C8E29; /* for strong contrast text on light bg */
    --acs-brand-soft:      #E6F3D4; /* page-soft section bg */
    --acs-brand-contrast:  #ffffff;

    /* Neutrals (slate scale) */
    --acs-n-50:  #f9fafb;
    --acs-n-100: #f3f4f6;
    --acs-n-200: #e5e7eb;
    --acs-n-300: #d1d5db;
    --acs-n-400: #9ca3af;
    --acs-n-500: #6b7280;
    --acs-n-600: #4b5563;
    --acs-n-700: #374151;
    --acs-n-800: #1f2937;
    --acs-n-900: #111827;

    /* Surfaces */
    --acs-bg:            #ffffff;
    --acs-bg-soft:       var(--acs-n-50);
    --acs-bg-muted:      var(--acs-n-100);
    --acs-text:          var(--acs-n-900);
    --acs-text-muted:    var(--acs-n-500);
    --acs-border:        var(--acs-n-200);

    /* Type */
    --acs-font-sans: "Inter", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

    /* Sizing — modular scale */
    --acs-fs-xs:   12px;
    --acs-fs-sm:   14px;
    --acs-fs-base: 16px;
    --acs-fs-lg:   18px;
    --acs-fs-xl:   20px;
    --acs-fs-2xl:  24px;
    --acs-fs-3xl:  30px;
    --acs-fs-4xl:  38px;
    --acs-fs-5xl:  48px;
    --acs-fs-6xl:  60px;

    /* Spacing scale (4px base) */
    --acs-s-1:  4px;
    --acs-s-2:  8px;
    --acs-s-3: 12px;
    --acs-s-4: 16px;
    --acs-s-5: 24px;
    --acs-s-6: 32px;
    --acs-s-7: 48px;
    --acs-s-8: 64px;
    --acs-s-9: 96px;

    /* Radii */
    --acs-r-sm:  6px;
    --acs-r:    10px;
    --acs-r-lg: 16px;
    --acs-r-xl: 24px;
    --acs-r-pill: 999px;

    /* Shadows */
    --acs-shadow-sm: 0 1px 2px rgba(17, 24, 39, 0.06);
    --acs-shadow:    0 4px 12px rgba(17, 24, 39, 0.08);
    --acs-shadow-lg: 0 12px 32px rgba(17, 24, 39, 0.12);

    /* Easings */
    --acs-ease: cubic-bezier(0.4, 0, 0.2, 1);

    /* Layout */
    --acs-container: 1200px;

    /* Legacy aliases (kept for D.1-D.6 backwards compat) */
    --acs-brand-light: var(--acs-brand-strong);
    --acs-radius:      var(--acs-r-lg);

    /* Push Blocksy palette toward the new brand */
    --theme-palette-color-1:    var(--acs-brand);
    --paletteColor1:            var(--acs-brand);
    --theme-link-initial-color: var(--acs-brand);
}


/* ----------------------------------------------------------------------------
   1.b — WhatsApp-style hero block, big and confident
---------------------------------------------------------------------------- */
.qodef-slider {
    background: var(--acs-bg);
}
.qodef-slider .qodef-image::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(92, 142, 41, 0.70) 0%, rgba(92, 142, 41, 0.40) 60%, rgba(92, 142, 41, 0.75) 100%);
}
.qodef-slider .qodef-slider-content { z-index: 2; }
.qodef-slider .qodef-slide-text {
    font-family: var(--acs-font-sans) !important;
    font-weight: 800 !important;
    letter-spacing: -0.025em !important;
    text-shadow: 0 2px 16px rgba(0,0,0,0.18);
}
.qodef-slider .qodef-slide-text > span {
    color: #fff;
    font-size: clamp(36px, 5.2vw, 64px) !important;
}
.qodef-slider .qodef-slide-text span[style*="font-size:18px"] {
    font-weight: 500 !important;
    text-shadow: 0 1px 6px rgba(0,0,0,0.25);
}


/* ----------------------------------------------------------------------------
   2. Reset & base
---------------------------------------------------------------------------- */
body.wp-child-theme-africallshop {
    font-family: var(--acs-font-sans);
    font-size: var(--acs-fs-base);
    line-height: 1.55;
    color: var(--acs-text);
    background: var(--acs-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body.wp-child-theme-africallshop h1,
body.wp-child-theme-africallshop h2,
body.wp-child-theme-africallshop h3,
body.wp-child-theme-africallshop h4 {
    font-family: var(--acs-font-sans);
    color: var(--acs-text);
    letter-spacing: -0.02em;
    font-weight: 700;
}

body.wp-child-theme-africallshop h1 { font-size: clamp(36px, 4.5vw, var(--acs-fs-6xl)); line-height: 1.1; }
body.wp-child-theme-africallshop h2 { font-size: clamp(28px, 3.4vw, var(--acs-fs-4xl)); line-height: 1.18; }
body.wp-child-theme-africallshop h3 { font-size: clamp(20px, 2.2vw, var(--acs-fs-2xl)); line-height: 1.3; }

body.wp-child-theme-africallshop p { margin: 0 0 var(--acs-s-4); }
body.wp-child-theme-africallshop p:last-child { margin-bottom: 0; }


/* ----------------------------------------------------------------------------
   3. Components — Buttons (utility classes for new sections)
---------------------------------------------------------------------------- */
.acs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--acs-s-2);
    padding: 12px 22px;
    border-radius: var(--acs-r);
    font-family: var(--acs-font-sans);
    font-size: var(--acs-fs-base);
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease), background-color 0.15s var(--acs-ease), color 0.15s var(--acs-ease);
    white-space: nowrap;
}
.acs-btn:hover { transform: translateY(-1px); }
.acs-btn:active { transform: translateY(0); }
.acs-btn:focus-visible { outline: 2px solid var(--acs-brand); outline-offset: 2px; }

.acs-btn-primary { background: var(--acs-brand); color: var(--acs-brand-contrast); }
.acs-btn-primary:hover { background: var(--acs-brand-strong); color: var(--acs-brand-contrast); box-shadow: var(--acs-shadow); }

.acs-btn-dark { background: #000; color: #fff; }
.acs-btn-dark:hover { background: #1d1d1f; color: #fff; box-shadow: var(--acs-shadow); }

.acs-btn-secondary { background: var(--acs-bg); color: var(--acs-text); border-color: var(--acs-border); }
.acs-btn-secondary:hover { background: var(--acs-bg-soft); border-color: var(--acs-n-400); }

.acs-btn-ghost { background: transparent; color: var(--acs-brand); }
.acs-btn-ghost:hover { background: var(--acs-brand-soft); }

.acs-btn-lg { padding: 14px 28px; font-size: var(--acs-fs-lg); }
.acs-btn-sm { padding: 8px 14px; font-size: var(--acs-fs-sm); }


/* ----------------------------------------------------------------------------
   4. Components — Cards / Sections
---------------------------------------------------------------------------- */
.acs-section {
    padding: var(--acs-s-8) var(--acs-s-4);
}
.acs-section-soft { background: var(--acs-bg-soft); }
.acs-section-brand { background: var(--acs-brand); color: var(--acs-brand-contrast); }
.acs-section-brand h1, .acs-section-brand h2, .acs-section-brand h3 { color: var(--acs-brand-contrast); }

.acs-container {
    max-width: var(--acs-container);
    margin: 0 auto;
}

.acs-card {
    background: var(--acs-bg);
    border-radius: var(--acs-r-lg);
    padding: var(--acs-s-6);
    border: 1px solid var(--acs-border);
    transition: transform 0.18s var(--acs-ease), box-shadow 0.18s var(--acs-ease);
}
.acs-card:hover { transform: translateY(-2px); box-shadow: var(--acs-shadow); }

.acs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--acs-s-5);
}

.acs-eyebrow {
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: var(--acs-fs-xs);
    font-weight: 700;
    color: var(--acs-brand);
    margin-bottom: var(--acs-s-3);
}

.acs-text-muted { color: var(--acs-text-muted); }
.acs-text-lg    { font-size: var(--acs-fs-lg); }


/* ----------------------------------------------------------------------------
   5. Legacy compat — Qode/Startit selectors get the new look
---------------------------------------------------------------------------- */

/* Country list under .qodef-content: clickable rows with hover */
.qodef-content .vc_col-sm-4 p[style*="text-align: center"] a {
    display: block;
    padding: 8px 12px;
    border-radius: var(--acs-r-sm);
    color: var(--acs-text);
    transition: background-color 0.15s var(--acs-ease), color 0.15s var(--acs-ease);
    text-decoration: none;
}
.qodef-content .vc_col-sm-4 p[style*="text-align: center"] a:hover {
    background: var(--acs-brand-soft);
    color: var(--acs-brand);
}

/* Hero CTA buttons get the same Wise-like polish */
.qodef-slider .qodef-btn-solid {
    background: #000 !important;
    border-color: #000 !important;
    color: #fff !important;
    padding: 12px 22px !important;
    border-radius: var(--acs-r) !important;
    font-weight: 600 !important;
}
.qodef-slider .qodef-btn-solid:hover { background: #1d1d1f !important; }

.qodef-slider .qodef-btn-default {
    background: #fff !important;
    color: var(--acs-brand-deep) !important;
    border-color: #fff !important;
    padding: 12px 22px !important;
    border-radius: var(--acs-r) !important;
    font-weight: 600 !important;
}
.qodef-slider .qodef-btn-default:hover { background: var(--acs-bg-soft) !important; }

.qodef-slider .qodef-slide-text { line-height: 1.18 !important; }
.qodef-slider .qodef-slide-text span[style*="font-size:18px"] {
    display: inline-block;
    margin-top: var(--acs-s-4);
    letter-spacing: 0.1px;
}

/* Inline-styled CTA banner + How-it-works cards we injected via D.2: subtle lift on hover */
.qodef-content a[href*="apps.apple.com"][style*="background:#000"],
.qodef-content a[href*="play.google.com"][style*="background:#fff"] {
    transition: transform 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
    box-shadow: var(--acs-shadow-sm);
}
.qodef-content a[href*="apps.apple.com"][style*="background:#000"]:hover,
.qodef-content a[href*="play.google.com"][style*="background:#fff"]:hover {
    transform: translateY(-1px);
    box-shadow: var(--acs-shadow);
}

.qodef-content div[style*="border-radius:16px"][style*="background:#f9fafb"] {
    border: 1px solid var(--acs-border);
    transition: transform 0.18s var(--acs-ease), box-shadow 0.18s var(--acs-ease), border-color 0.18s var(--acs-ease);
}
.qodef-content div[style*="border-radius:16px"][style*="background:#f9fafb"]:hover {
    transform: translateY(-2px);
    border-color: var(--acs-brand-soft);
    box-shadow: 0 8px 24px rgba(92, 142, 41, 0.14);
}

/* WPBakery primary buttons inherit brand color */
.wpb_button.wpb_btn-info,
.qodef-btn.qodef-btn-solid:not([href*="apps.apple"]):not([href*="play.google"]):not(.qodef-slider .qodef-btn-solid) {
    background-color: var(--acs-brand) !important;
    border-color: var(--acs-brand) !important;
}

/* Body links default to brand color (in content area only — not menus/buttons) */
.qodef-content a:not(.qodef-btn):not([class*="qodef-button"]):not([class*="wpb_btn"]):not(.acs-btn) {
    color: var(--acs-brand);
    text-decoration: none;
    transition: color 0.15s var(--acs-ease);
}
.qodef-content a:not(.qodef-btn):not([class*="qodef-button"]):not([class*="wpb_btn"]):not(.acs-btn):hover {
    color: var(--acs-brand-strong);
    text-decoration: underline;
}


/* ----------------------------------------------------------------------------
   6. Header / Footer polish (Qode markup gets a tighter, modern feel)
---------------------------------------------------------------------------- */

/* WhatsApp-style header: white background, brand text, single subtle border */
.qodef-page-header {
    box-shadow: none !important;
    border-bottom: 1px solid var(--acs-border);
    background: rgba(255,255,255,0.96);
    backdrop-filter: saturate(140%) blur(6px);
    -webkit-backdrop-filter: saturate(140%) blur(6px);
}
.qodef-sticky-header-appear .qodef-page-header.qodef-sticky-up-mobile-header,
.qodef-page-header.qodef-sticky {
    box-shadow: var(--acs-shadow);
}

/* Menu items: tighter, more brand-aware */
.qodef-page-header .qodef-main-menu > ul > li > a {
    font-family: var(--acs-font-sans) !important;
    font-weight: 500 !important;
    font-size: 15px !important;
    letter-spacing: 0;
    color: var(--acs-text) !important;
    transition: color 0.15s var(--acs-ease) !important;
}
.qodef-page-header .qodef-main-menu > ul > li > a:hover,
.qodef-page-header .qodef-main-menu > ul > li.current-menu-item > a {
    color: var(--acs-brand) !important;
}

/* ----------------------------------------------------------------------------
   Custom AfriCallShop footer (.acs-footer) — replaces Qode's footer markup
---------------------------------------------------------------------------- */
.acs-footer {
    background: var(--acs-n-900);
    color: var(--acs-n-300);
    font-family: var(--acs-font-sans);
    margin-top: var(--acs-s-8);
}
.acs-footer-container {
    max-width: var(--acs-container);
    margin: 0 auto;
    padding: 0 var(--acs-s-4);
}
.acs-footer-main {
    padding: var(--acs-s-8) 0 var(--acs-s-7);
}
.acs-footer-main .acs-footer-container {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: var(--acs-s-7);
    align-items: start;
}
@media (max-width: 900px) {
    .acs-footer-main .acs-footer-container { grid-template-columns: 1fr 1fr; gap: var(--acs-s-6); }
    .acs-footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
    .acs-footer-main .acs-footer-container { grid-template-columns: 1fr; }
}

.acs-footer-brand .acs-footer-logo {
    font-family: var(--acs-font-sans);
    color: #fff !important;
    text-decoration: none;
    font-size: var(--acs-fs-xl);
    letter-spacing: -0.01em;
}
.acs-footer-tagline {
    color: var(--acs-n-400);
    font-size: var(--acs-fs-sm);
    margin: var(--acs-s-3) 0 var(--acs-s-5);
    line-height: 1.5;
    max-width: 320px;
}
.acs-footer-stores { display: flex; gap: var(--acs-s-3); flex-wrap: wrap; }
.acs-store {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: #111827;
    border: 1px solid var(--acs-n-700);
    border-radius: var(--acs-r);
    color: #fff !important;
    text-decoration: none;
    font-size: var(--acs-fs-sm);
    font-weight: 600;
    transition: border-color 0.15s var(--acs-ease), background-color 0.15s var(--acs-ease);
}
.acs-store:hover { border-color: var(--acs-n-400); background: var(--acs-n-800); }
.acs-store-google { background: #fff; color: var(--acs-n-900) !important; border-color: #fff; }
.acs-store-google:hover { background: var(--acs-n-100); border-color: var(--acs-n-100); }

.acs-footer-col h4 {
    color: #fff;
    font-family: var(--acs-font-sans);
    font-size: var(--acs-fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    margin: 0 0 var(--acs-s-4);
}
.acs-footer-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.acs-footer-col li { margin-bottom: var(--acs-s-2); }
.acs-footer-col a {
    color: var(--acs-n-300) !important;
    text-decoration: none;
    font-size: var(--acs-fs-sm);
    transition: color 0.15s var(--acs-ease);
}
.acs-footer-col a:hover { color: #fff !important; }

.acs-footer-bottom {
    border-top: 1px solid var(--acs-n-700);
    padding: var(--acs-s-4) 0;
    color: var(--acs-n-400);
    font-size: var(--acs-fs-xs);
}
.acs-footer-bottom .acs-footer-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--acs-s-3);
    flex-wrap: wrap;
}
.acs-footer-lang a {
    color: var(--acs-n-400) !important;
    text-decoration: none;
    margin: 0 4px;
    transition: color 0.15s var(--acs-ease);
}
.acs-footer-lang a:hover, .acs-footer-lang a.is-active { color: #fff !important; }


/* ----------------------------------------------------------------------------
   7. Forms (Wise-like : large, clean)
---------------------------------------------------------------------------- */
.qodef-content input[type="text"],
.qodef-content input[type="email"],
.qodef-content input[type="tel"],
.qodef-content input[type="search"],
.qodef-content select,
.qodef-content textarea {
    font-family: var(--acs-font-sans);
    font-size: var(--acs-fs-base);
    padding: 12px 14px;
    border: 1px solid var(--acs-border);
    border-radius: var(--acs-r);
    background: var(--acs-bg);
    color: var(--acs-text);
    transition: border-color 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
    width: 100%;
    box-sizing: border-box;
}
.qodef-content input:focus,
.qodef-content select:focus,
.qodef-content textarea:focus {
    border-color: var(--acs-brand);
    box-shadow: 0 0 0 3px var(--acs-brand-soft);
    outline: none;
}


/* ----------------------------------------------------------------------------
   8. Responsive utilities
---------------------------------------------------------------------------- */
@media (max-width: 768px) {
    body.wp-child-theme-africallshop h1 { font-size: 32px; }
    body.wp-child-theme-africallshop h2 { font-size: 24px; }
    .acs-section { padding: var(--acs-s-7) var(--acs-s-4); }
}


/* ----------------------------------------------------------------------------
   9. Print
---------------------------------------------------------------------------- */
@media print {
    .qodef-page-header, .qodef-page-footer, #africallshop-qr-card { display: none !important; }
}


/* ============================================================================
   10. WhatsApp-like custom theme (.acs-wa-*) — header + front-page.php only
   ============================================================================ */

.acs-wa-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: #fff;
    border-bottom: 1px solid var(--acs-border);
    font-family: var(--acs-font-sans);
    /* Defensive: the language switcher popover anchors to the bottom of its
       trigger inside the header. Any legacy `overflow: hidden` on header /
       header-inner would clip it. Force visible. */
    overflow: visible;
}
.acs-wa-header-inner {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 24px;
    height: 72px;
    display: flex;
    align-items: center;
    gap: 24px;
    overflow: visible;
}
.acs-wa-brand {
    display: flex; align-items: center; gap: 10px;
    text-decoration: none;
    color: var(--acs-n-900);
    font-weight: 700;
    font-size: 18px;
    letter-spacing: -0.01em;
}
.acs-wa-brand-mark {
    display: block;
    width: 44px;
    height: 44px;
    object-fit: contain;
    flex-shrink: 0;
}
.acs-wa-brand-name {
    font-family: var(--acs-font-sans);
    font-weight: 700;
    font-size: 18px;
    color: var(--acs-n-900);
    letter-spacing: -0.01em;
}
@media (max-width: 540px) {
    .acs-wa-brand-mark { width: 36px; height: 36px; }
    .acs-wa-brand-name { display: none; }
}
.acs-wa-nav { flex: 1; }
.acs-wa-nav ul {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 28px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.acs-wa-nav a {
    color: var(--acs-n-700);
    text-decoration: none;
    font-size: 15px;
    font-weight: 500;
    transition: color 0.15s var(--acs-ease);
}
.acs-wa-nav a:hover { color: var(--acs-brand-strong); }
.acs-wa-cta {
    display: inline-flex;
    align-items: center;
    background: var(--acs-brand-deep);
    color: #fff !important;
    padding: 12px 22px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    letter-spacing: 0.01em;
    box-shadow: 0 4px 12px rgba(92, 142, 41, 0.30);
    transition: background-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-wa-cta:hover { background: #4A7320; transform: translateY(-1px); box-shadow: 0 6px 18px rgba(92, 142, 41, 0.45); }

/* Language switcher — native <details>/<summary> dropdown.
   Why <details>: a previous CSS-only dropdown was clobbered by Qode/legacy
   z-index rules on some templates. <details> is a browser primitive that
   legacy stylesheets can't intercept (and gives us free keyboard a11y).

   Visual:
     - Collapsed:  🇬🇧  English  ▾   (pill with flag + native name + caret)
     - Open:       6-item popover with flag + native name per row
*/
.acs-wa-lang-menu {
    position: relative;
    display: inline-block;
}
/* Hide the default disclosure triangle (Webkit + Firefox + Edge). */
.acs-wa-lang-menu > summary::-webkit-details-marker { display: none; }
.acs-wa-lang-menu > summary { list-style: none; }
.acs-wa-lang-menu > summary::marker { content: ""; }

/* Trigger pill — same shape as the legacy pills so the header rhythm stays. */
.acs-wa-lang-current {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 36px;
    padding: 0 12px 0 10px;
    border: 1px solid var(--acs-border);
    border-radius: 999px;
    background: #fff;
    color: var(--acs-n-700);
    font-weight: 600;
    font-size: 13px;
    line-height: 1;
    cursor: pointer;
    user-select: none;
    transition: border-color 0.15s var(--acs-ease), background 0.15s var(--acs-ease);
}
.acs-wa-lang-current:hover,
.acs-wa-lang-menu[open] > .acs-wa-lang-current {
    border-color: var(--acs-brand);
    background: var(--acs-brand-soft);
}
.acs-wa-lang-flag {
    /* Emoji flags render best at this size; line-height 1 keeps the pill compact. */
    font-size: 16px;
    line-height: 1;
}
.acs-wa-lang-name { letter-spacing: 0.02em; }
.acs-wa-lang-caret {
    margin-left: 2px;
    font-size: 11px;
    color: var(--acs-n-500, #94a3b8);
    transition: transform 0.18s var(--acs-ease);
}
.acs-wa-lang-menu[open] .acs-wa-lang-caret { transform: rotate(180deg); }

/* Dropdown panel — `position: fixed` so it escapes every ancestor's overflow
   /transform/contain clipping. Coordinates (top / right) are set inline by
   the helper script in header.php once the menu is opened, computed from the
   summary's getBoundingClientRect(). z-index sits above the sticky header. */
.acs-wa-lang-options {
    position: fixed;
    margin: 0;
    padding: 6px;
    list-style: none;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
    min-width: 200px;
    z-index: 10000;
}
.acs-wa-lang-options li { list-style: none; }
.acs-wa-lang-options a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 8px;
    color: var(--acs-n-800, #1e293b);
    font-size: 14px;
    text-decoration: none;
    transition: background 0.12s var(--acs-ease), color 0.12s var(--acs-ease);
}
.acs-wa-lang-options a:hover,
.acs-wa-lang-options a:focus-visible {
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep);
    outline: none;
}

@media (max-width: 540px) {
    .acs-wa-lang-current { height: 32px; padding: 0 8px; font-size: 12px; gap: 4px; }
    .acs-wa-lang-flag { font-size: 14px; }
    /* Reclaim space on small viewports — drop the native name from the
       trigger, keep just flag + caret. The dropdown options still show the
       full names so the user knows what each row is. */
    .acs-wa-lang-current .acs-wa-lang-name { display: none; }
    .acs-wa-lang-options { min-width: 180px; }
    .acs-wa-lang-options a { padding: 8px 10px; font-size: 13px; }
}

.acs-wa-nav-toggle, .acs-wa-burger { display: none; }
@media (max-width: 880px) {
    /* Tighten the header gaps on tablets/phones — the row has 5 items
       (logo, burger, nav-drawer, lang dropdown, CTA) and the 24px desktop
       gap pushes the CTA off-screen on phones. 10px keeps it readable. */
    .acs-wa-header-inner { gap: 10px; padding: 0 14px; }

    .acs-wa-nav {
        /* Default (closed) state — nav still inside the header. We start
           collapsed via max-height:0 so the transition animates on open. */
        position: fixed;
        top: 72px; left: 0; right: 0;
        background: #fff;
        border-bottom: 1px solid var(--acs-border);
        max-height: 0; overflow: hidden;
        transition: max-height 0.25s var(--acs-ease);
        z-index: 99;
    }
    .acs-wa-nav ul { flex-direction: column; padding: 16px 24px; gap: 16px; align-items: stretch; }

    /* Open state — the header.php JS teleports the nav into <body> and adds
       .is-open. We use !important + a high-specificity selector on body to
       defeat any legacy Qode/Blocksy CSS that may override max-height on
       certain page templates (/blog masonry sets overflow on wrappers and
       sometimes ships its own .acs-wa-nav-like resets). */
    body > .acs-wa-nav.is-open,
    .acs-wa-nav.is-open {
        max-height: 80vh !important;
        overflow-y: auto !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    /* CSS-only fallback when JS is disabled — checkbox sibling selector. */
    .acs-wa-nav-toggle:checked ~ .acs-wa-nav { max-height: 80vh; overflow-y: auto; }
    .acs-wa-burger {
        display: flex; flex-direction: column;
        justify-content: center; align-items: center;
        gap: 4px;
        width: 40px; height: 40px;
        cursor: pointer;
        order: 2;
    }
    .acs-wa-burger span {
        display: block; width: 22px; height: 2px;
        background: var(--acs-n-900);
        transition: transform 0.2s var(--acs-ease), opacity 0.2s var(--acs-ease);
    }
    .acs-wa-nav-toggle:checked ~ .acs-wa-burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
    .acs-wa-nav-toggle:checked ~ .acs-wa-burger span:nth-child(2) { opacity: 0; }
    .acs-wa-nav-toggle:checked ~ .acs-wa-burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
    .acs-wa-cta { order: 3; padding: 10px 16px; font-size: 14px; white-space: nowrap; }
}
@media (max-width: 380px) {
    /* Phones under 380px (older / small Android) — last-resort compression
       so "Get the app" / "Télécharger" stays on a single line. */
    .acs-wa-header-inner { gap: 8px; padding: 0 10px; }
    .acs-wa-cta { padding: 9px 12px; font-size: 13px; }
}

/* === Front page sections === */

.acs-wa-main { font-family: var(--acs-font-sans); color: var(--acs-n-900); line-height: 1.55; }
.acs-wa-main * { box-sizing: border-box; }

/* shared section primitives */
.acs-wa-section { padding: 96px 24px; background: #fff; }
.acs-wa-section-soft { background: var(--acs-brand-soft); }
.acs-wa-section-inner { max-width: 1240px; margin: 0 auto; }
.acs-wa-section-narrow { max-width: 780px; }
.acs-wa-section-head { text-align: center; margin-bottom: 56px; }

.acs-wa-eyebrow {
    display: inline-block;
    color: var(--acs-brand-strong);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
}
.acs-wa-h2 {
    font-size: clamp(32px, 4vw, 48px);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 16px;
}
.acs-wa-lead {
    font-size: 18px;
    color: var(--acs-n-700);
    line-height: 1.6;
    margin: 0 0 24px;
    max-width: 560px;
}
.acs-wa-link {
    color: var(--acs-brand-strong);
    font-weight: 600;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-wa-link:hover { border-bottom-color: var(--acs-brand-strong); }

/* HERO */
.acs-wa-hero {
    padding: 96px 24px 72px;
    background: linear-gradient(180deg, #fff 0%, var(--acs-brand-soft) 100%);
    text-align: center;
}
.acs-wa-hero-inner { max-width: 920px; margin: 0 auto; }
.acs-wa-hero-title {
    font-size: clamp(40px, 6vw, 72px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--acs-n-900);
    margin: 12px 0 24px;
}
.acs-wa-hero-sub {
    font-size: clamp(17px, 1.8vw, 21px);
    color: var(--acs-n-700);
    max-width: 640px;
    margin: 0 auto 36px;
    line-height: 1.5;
}
.acs-wa-hero-ctas {
    display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}
.acs-wa-hero-ratings {
    margin-top: 24px;
    color: var(--acs-n-600);
    font-size: 14px;
    letter-spacing: 0.02em;
}

/* Official store badges — fixed badge BOX dimensions, image centred via object-fit.
   This keeps Apple (281×83) and Google (564×168) visually identical regardless of
   their native ratio and internal transparent padding. */
.acs-wa-store-badges {
    --acs-badge-w: 162px;
    --acs-badge-h: 48px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}
.acs-wa-store-badges-lg { --acs-badge-w: 188px; --acs-badge-h: 56px; }

.acs-wa-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--acs-badge-w);
    height: var(--acs-badge-h);
    line-height: 0;
    transition: transform 0.15s var(--acs-ease), opacity 0.15s var(--acs-ease);
    text-decoration: none !important;
}
.acs-wa-badge:hover { transform: translateY(-1px); opacity: 0.94; }
.acs-wa-badge img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
}

/* Footer override — tighter, against dark bg */
.acs-footer-stores.acs-wa-store-badges {
    --acs-badge-h: 44px;
    justify-content: flex-start;
}

/* Buttons */
.acs-wa-btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 14px 26px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 16px;
    text-decoration: none;
    border: 2px solid transparent;
    transition: transform 0.15s var(--acs-ease), background-color 0.15s var(--acs-ease), color 0.15s var(--acs-ease), border-color 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-wa-btn:hover { transform: translateY(-1px); }
.acs-wa-btn-primary { background: var(--acs-brand); color: #fff !important; box-shadow: 0 6px 16px rgba(147, 202, 75, 0.40); }
.acs-wa-btn-primary:hover { background: var(--acs-brand-strong); }
.acs-wa-btn-secondary { background: #fff; color: var(--acs-n-900) !important; border-color: var(--acs-n-300); }
.acs-wa-btn-secondary:hover { border-color: var(--acs-n-900); }
.acs-wa-btn-light { background: #fff; color: var(--acs-brand-strong) !important; }
.acs-wa-btn-light:hover { background: var(--acs-n-100); }
.acs-wa-btn-outline { background: transparent; color: #fff !important; border-color: rgba(255,255,255,0.6); }
.acs-wa-btn-outline:hover { background: rgba(255,255,255,0.1); border-color: #fff; }

/* SECTION 2 - feature + phone mockup */
.acs-wa-feature { background: #fff; }
.acs-wa-feature-inner {
    max-width: 1240px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
@media (max-width: 880px) {
    .acs-wa-feature-inner { grid-template-columns: 1fr; gap: 40px; }
    .acs-wa-feature-visual { order: -1; }
}
.acs-wa-phone-frame {
    background: var(--acs-n-900);
    border-radius: 36px;
    padding: 16px;
    box-shadow: 0 20px 60px rgba(92, 142, 41, 0.25);
    width: 280px;
    margin: 0 auto;
}
.acs-wa-phone-screen {
    background: var(--acs-brand-soft);
    border-radius: 24px;
    padding: 20px;
    display: flex; flex-direction: column; gap: 12px;
}
.acs-wa-phone-row {
    background: #fff;
    border-radius: 14px;
    padding: 12px 14px;
    display: flex; justify-content: space-between; align-items: center;
    font-size: 14px;
    box-shadow: 0 1px 2px rgba(92, 142, 41, 0.10);
}
.acs-wa-phone-row strong { color: var(--acs-brand-strong); font-weight: 700; }

/* SECTION 3 - steps */
.acs-wa-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
@media (max-width: 720px) { .acs-wa-steps { grid-template-columns: 1fr; } }
.acs-wa-step {
    text-align: center;
    padding: 32px 16px;
}
.acs-wa-step-num {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--acs-brand);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 22px;
    margin: 0 auto 20px;
    box-shadow: 0 6px 16px rgba(147, 202, 75, 0.40);
}
.acs-wa-step-title { font-size: 20px; font-weight: 700; margin: 0 0 8px; }
.acs-wa-step-text { color: var(--acs-n-600); margin: 0; line-height: 1.55; }

/* SECTION 4 - stats + testimonials */
.acs-wa-stats {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    text-align: center;
    margin-bottom: 64px;
}
@media (max-width: 720px) { .acs-wa-stats { grid-template-columns: repeat(2, 1fr); } }
.acs-wa-stat-num { font-size: 36px; font-weight: 800; color: var(--acs-brand-strong); line-height: 1; }
.acs-wa-stat-label { color: var(--acs-n-600); font-size: 14px; margin-top: 6px; letter-spacing: 0.02em; }

.acs-wa-testimonials {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
@media (max-width: 880px) { .acs-wa-testimonials { grid-template-columns: 1fr; } }
.acs-wa-quote {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    padding: 28px 24px;
    margin: 0;
}
.acs-wa-stars { color: #f59e0b; font-size: 16px; letter-spacing: 2px; margin-bottom: 10px; }
.acs-wa-quote blockquote { margin: 0 0 12px; font-size: 16px; line-height: 1.55; color: var(--acs-n-800); }
.acs-wa-quote figcaption { color: var(--acs-n-600); font-size: 14px; }

/* SECTION 5 - FAQ */
.acs-wa-faqs { display: flex; flex-direction: column; gap: 12px; }
.acs-wa-faq {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    padding: 20px 24px;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-wa-faq:hover { border-color: var(--acs-brand); }
.acs-wa-faq summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 17px;
    list-style: none;
    position: relative;
    padding-right: 24px;
    color: var(--acs-n-900);
}
.acs-wa-faq summary::-webkit-details-marker { display: none; }
.acs-wa-faq summary::after {
    content: "+";
    position: absolute; right: 0; top: 50%;
    transform: translateY(-50%);
    font-size: 24px; color: var(--acs-brand-strong);
    line-height: 1;
}
.acs-wa-faq[open] summary::after { content: "−"; }
.acs-wa-faq-body { margin-top: 14px; color: var(--acs-n-700); line-height: 1.6; }
.acs-wa-faq-body a { color: var(--acs-brand-strong); }

/* SECTION 6 - CTA banner */
.acs-wa-cta-banner {
    padding: 96px 24px;
    background: var(--acs-brand-strong);
    color: #fff;
    text-align: center;
}
.acs-wa-cta-h2 {
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 800;
    color: #fff;
    margin: 0 0 16px;
    letter-spacing: -0.025em;
}
.acs-wa-cta-sub {
    font-size: 18px;
    color: rgba(255,255,255,0.92);
    margin: 0 auto 32px;
    max-width: 600px;
}

/* Hide legacy Qode header (which we replaced with .acs-wa-header) — defensive */
.acs-wa-main + .qodef-page-header,
.acs-wa-main ~ .qodef-page-header { display: none !important; }


/* === Prices table (page-prices.php) === */
.acs-wa-rates {
    max-width: 800px;
    margin: 0 auto;
    background: #fff;
    border-radius: 16px;
    border: 1px solid var(--acs-border);
    padding: 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.acs-wa-rates-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 15px;
    min-width: 460px; /* keep table readable, scrolls horizontally if narrower */
}
@media (max-width: 540px) {
    .acs-wa-rates { padding: 16px; }
    .acs-wa-rates-table th:nth-child(3),
    .acs-wa-rates-table td:nth-child(3) { display: none; } /* hide "Top-up" column on tiny screens */
}
.acs-wa-rates-table th {
    text-align: left;
    color: var(--acs-n-500);
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 12px 16px;
    border-bottom: 1px solid var(--acs-border);
}
.acs-wa-rates-table td {
    padding: 16px;
    border-bottom: 1px solid var(--acs-n-100);
}
.acs-wa-rates-table tr:last-child td { border-bottom: 0; }
.acs-wa-rates-table tr:hover td { background: var(--acs-n-50); }
.acs-wa-country {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--acs-n-900);
    text-decoration: none;
    font-weight: 500;
}
.acs-wa-country:hover { color: var(--acs-brand-strong); }
.acs-wa-flag { font-size: 22px; line-height: 1; }
.acs-wa-pill {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}
.acs-wa-pill-on { background: var(--acs-brand-soft); color: var(--acs-brand-deep); }
.acs-wa-pill-off { color: var(--acs-n-400); }


/* ----------------------------------------------------------------------------
   11. Destinations linking blocks (front-page popular grid + prices A-Z list)
---------------------------------------------------------------------------- */

/* Popular destinations grid — front-page, 4×3 cards on desktop */
.acs-wa-dest-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
@media (max-width: 880px) { .acs-wa-dest-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .acs-wa-dest-grid { grid-template-columns: repeat(2, 1fr); } }
.acs-wa-dest-grid li { margin: 0; }
.acs-wa-dest {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    text-decoration: none;
    color: var(--acs-n-900);
    font-weight: 500;
    font-size: 15px;
    transition: border-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease), background 0.15s var(--acs-ease);
}
.acs-wa-dest:hover {
    border-color: var(--acs-brand);
    color: var(--acs-brand-deep);
    background: var(--acs-brand-soft);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(147, 202, 75, 0.18);
}
.acs-wa-dest .acs-wa-flag { font-size: 22px; line-height: 1; }
.acs-wa-dest-name { line-height: 1.2; }

/* A-Z directory list on page-prices.php */
.acs-wa-dest-az {
    list-style: none;
    margin: 0;
    padding: 0;
    column-count: 4;
    column-gap: 32px;
}
@media (max-width: 880px) { .acs-wa-dest-az { column-count: 2; } }
@media (max-width: 540px) { .acs-wa-dest-az { column-count: 1; } }
.acs-wa-dest-az li {
    margin: 0 0 10px;
    break-inside: avoid;
}
.acs-wa-dest-az a {
    color: var(--acs-n-700);
    text-decoration: none;
    font-size: 15px;
    border-bottom: 1px solid transparent;
    transition: color 0.15s var(--acs-ease), border-color 0.15s var(--acs-ease);
}
.acs-wa-dest-az a:hover {
    color: var(--acs-brand-deep);
    border-bottom-color: var(--acs-brand);
}


/* ----------------------------------------------------------------------------
   12. Blog — restyle Qode's .qodef-post-* masonry to match brand identity
   Covers /blog/, /help/, /fr/blog/, /fr/aide-et-support/, archives.
---------------------------------------------------------------------------- */

/* Archive title bar — Qode sets .qodef-title to a FIXED height (200px) and the
   inner .qodef-title-holder to position:absolute. With our larger paddings the
   absolute child overflows the 200px box and visually overlaps the first
   content paragraph. Override both: let .qodef-title size itself to its content
   and the holder flow naturally inside. */
.qodef-title {
    height: auto !important;
    min-height: 0 !important;
    background-color: var(--acs-brand-soft) !important;
    background-image: none !important;
    display: block !important;
    overflow: visible !important;
}
.qodef-title-holder {
    position: relative !important;
    display: block !important;
    height: auto !important;
    top: auto !important;
    left: auto !important;
}
.qodef-title-holder .qodef-container,
.qodef-title-holder .qodef-container-inner {
    display: block !important;
    height: auto !important;
    padding: 0 !important;
}

.qodef-title-subtitle-holder {
    background: var(--acs-brand-soft);
    padding: 64px 24px 56px !important;
    text-align: center;
    display: block !important;
}
.qodef-title-subtitle-holder-inner { max-width: 1200px; margin: 0 auto; }
.qodef-title-breadcrumbs-holder h1 {
    font-family: var(--acs-font-sans) !important;
    font-size: clamp(36px, 4.5vw, 56px) !important;
    font-weight: 800 !important;
    letter-spacing: -0.025em !important;
    color: var(--acs-n-900) !important;
    margin: 0 0 16px !important;
    line-height: 1.1 !important;
}
.qodef-breadcrumbs-holder,
.qodef-breadcrumbs,
.qodef-breadcrumbs-inner {
    color: var(--acs-n-600) !important;
    font-size: 14px !important;
    letter-spacing: 0.02em;
}
.qodef-breadcrumbs-inner a {
    color: var(--acs-brand-deep) !important;
    text-decoration: none !important;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s var(--acs-ease);
}
.qodef-breadcrumbs-inner a:hover { border-bottom-color: var(--acs-brand); }
.qodef-breadcrumbs .qodef-delimiter { color: var(--acs-n-400) !important; margin: 0 6px; }
.qodef-breadcrumbs .qodef-current { color: var(--acs-n-700) !important; }

/* Container — restore comfortable max-width */
body.qodef-blog-installed .qodef-container { padding: 56px 24px; }
body.qodef-blog-installed .qodef-container-inner { max-width: 1240px; margin: 0 auto; }

/* Masonry → CSS grid (replace floats Qode applies) */
.qodef-blog-holder.qodef-blog-type-masonry {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 28px !important;
    width: 100% !important;
}
.qodef-blog-holder.qodef-blog-type-masonry > article {
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
    position: static !important;
    transform: none !important;
}
.qodef-blog-masonry-grid-sizer,
.qodef-blog-masonry-grid-gutter { display: none !important; }
@media (max-width: 980px) { .qodef-blog-holder.qodef-blog-type-masonry { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; } }
@media (max-width: 640px) { .qodef-blog-holder.qodef-blog-type-masonry { grid-template-columns: 1fr !important; } }

/* Post card */
.qodef-blog-holder article {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.18s var(--acs-ease), box-shadow 0.18s var(--acs-ease), border-color 0.18s var(--acs-ease);
    display: flex;
    flex-direction: column;
}
.qodef-blog-holder article:hover {
    transform: translateY(-2px);
    border-color: var(--acs-brand);
    box-shadow: 0 12px 24px rgba(147, 202, 75, 0.18);
}
.qodef-post-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Post image — fixed aspect, fills top of card */
.qodef-post-image {
    margin: 0 !important;
    overflow: hidden;
    background: var(--acs-bg-soft);
    aspect-ratio: 16 / 10;
}
.qodef-post-image a {
    display: block;
    width: 100%;
    height: 100%;
}
.qodef-post-image img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.4s var(--acs-ease);
}
.qodef-blog-holder article:hover .qodef-post-image img { transform: scale(1.04); }

/* Card text body */
.qodef-post-text { padding: 24px 24px 28px; flex: 1; }
.qodef-post-text-inner { display: flex; flex-direction: column; height: 100%; }

.qodef-post-title {
    margin: 0 0 12px !important;
    font-family: var(--acs-font-sans) !important;
}
.qodef-post-title a {
    color: var(--acs-n-900) !important;
    font-size: 19px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    letter-spacing: -0.015em !important;
    text-decoration: none !important;
    transition: color 0.15s var(--acs-ease);
    display: block;
}
.qodef-post-title a:hover { color: var(--acs-brand-deep) !important; }

.qodef-post-info {
    color: var(--acs-n-500);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.qodef-post-info-date { color: var(--acs-n-500); font-size: 13px; }
.qodef-post-info-date a { color: var(--acs-n-500) !important; text-decoration: none !important; }

.qodef-post-excerpt {
    color: var(--acs-n-700) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    margin: 0 0 20px !important;
}
/* Posts on this site are authored as WPBakery shortcodes — Qode's word-based
   excerpt strips the tags and emits just "..." with no real text. Hide that
   placeholder block in the masonry/list layouts (single post view is unaffected). */
.qodef-blog-holder .qodef-post-excerpt { display: none !important; }

/* "Read More" button — pill, brand */
.qodef-blog-holder .qodef-btn.qodef-btn-default,
.qodef-blog-holder .qodef-btn.qodef-btn-small {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    align-self: flex-start;
    padding: 10px 18px !important;
    background: var(--acs-brand) !important;
    border: 1px solid var(--acs-brand) !important;
    color: #fff !important;
    border-radius: 999px !important;
    font-family: var(--acs-font-sans) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    transition: background-color 0.15s var(--acs-ease), border-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease) !important;
}
.qodef-blog-holder .qodef-btn.qodef-btn-default:hover,
.qodef-blog-holder .qodef-btn.qodef-btn-small:hover {
    background: var(--acs-brand-strong) !important;
    border-color: var(--acs-brand-strong) !important;
    transform: translateY(-1px);
}
.qodef-blog-holder .qodef-btn-text { color: #fff !important; }
.qodef-blog-holder .qodef-btn-text-icon { color: #fff !important; }
.qodef-blog-holder .qodef-btn-text-icon::before { content: "→"; font-style: normal; margin-left: 2px; }

/* Kill Qode's FontAwesome chevron (.qodef-btn::after content: \f054) which would
   render alongside our own → arrow above. Keep one icon only. */
.qodef-blog-holder .qodef-btn::after { content: none !important; padding: 0 !important; }

/* Pagination */
.qodef-pagination {
    margin: 56px 0 0 !important;
    text-align: center !important;
}
.qodef-pagination ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 6px;
    padding: 0;
    margin: 0;
    list-style: none;
}
.qodef-pagination li { margin: 0; padding: 0; list-style: none; }
.qodef-pagination li a,
.qodef-pagination li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border-radius: 10px;
    border: 1px solid var(--acs-border);
    background: #fff;
    color: var(--acs-n-700) !important;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none !important;
    transition: border-color 0.15s var(--acs-ease), background 0.15s var(--acs-ease), color 0.15s var(--acs-ease);
}
.qodef-pagination li a:hover {
    border-color: var(--acs-brand);
    color: var(--acs-brand-deep) !important;
    background: var(--acs-brand-soft);
}
.qodef-pagination li.active span {
    background: var(--acs-brand) !important;
    border-color: var(--acs-brand) !important;
    color: #fff !important;
}
.qodef-pagination li.qodef-pagination-prev a,
.qodef-pagination li.qodef-pagination-next a { padding: 0 14px; }
.qodef-pagination li.qodef-pagination-first-page a,
.qodef-pagination li.qodef-pagination-last-page a { padding: 0 12px; font-size: 13px; letter-spacing: -1px; }
.qodef-pagination li a i { font-style: normal; }

/* Single post page — typography lift */
body.single-post .qodef-blog-single .qodef-post-image { aspect-ratio: 16 / 8; border-radius: 16px; }
body.single-post .qodef-blog-single .qodef-post-image img { border-radius: 16px; }
body.single-post .qodef-blog-single .qodef-post-title a,
body.single-post .qodef-blog-single h1.qodef-post-title {
    font-size: clamp(28px, 3.4vw, 40px) !important;
    line-height: 1.15 !important;
    letter-spacing: -0.02em !important;
}
body.single-post .qodef-blog-single .qodef-post-text,
body.single-post .qodef-blog-single .qodef-post-content {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 24px;
}
body.single-post .qodef-blog-single .qodef-post-text p,
body.single-post .qodef-blog-single .qodef-post-text li {
    font-family: var(--acs-font-sans);
    font-size: 17px;
    line-height: 1.7;
    color: var(--acs-n-800);
}
body.single-post .qodef-blog-single .qodef-post-text h2 {
    margin-top: 40px;
    font-size: clamp(22px, 2.4vw, 28px);
    color: var(--acs-n-900);
}
body.single-post .qodef-blog-single .qodef-post-text h3 {
    margin-top: 28px;
    font-size: clamp(18px, 2vw, 22px);
    color: var(--acs-n-900);
}
body.single-post .qodef-blog-single .qodef-tags a {
    display: inline-block;
    padding: 6px 12px;
    margin: 4px 6px 4px 0;
    border-radius: 999px;
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep) !important;
    font-size: 13px;
    text-decoration: none;
    border: 1px solid transparent;
    transition: border-color 0.15s var(--acs-ease);
}
body.single-post .qodef-blog-single .qodef-tags a:hover { border-color: var(--acs-brand); }


/* ----------------------------------------------------------------------------
   13. Sitemap (page-template Sitemap) — brand-aligned grouped listing
---------------------------------------------------------------------------- */

.acs-sitemap-main { font-family: var(--acs-font-sans); color: var(--acs-n-900); }
.acs-sitemap-main * { box-sizing: border-box; }
.acs-sitemap-inner { max-width: 1240px; margin: 0 auto; padding: 0 24px; }

.acs-sitemap-hero {
    padding: 64px 24px 48px;
    background: linear-gradient(180deg, #fff 0%, var(--acs-brand-soft) 100%);
    text-align: center;
}
.acs-sitemap-h1 {
    font-size: clamp(36px, 4.5vw, 56px);
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 16px;
    line-height: 1.1;
    color: var(--acs-n-900);
}
.acs-sitemap-lead {
    font-size: 18px;
    color: var(--acs-n-700);
    max-width: 640px;
    margin: 0 auto 24px;
}

.acs-sitemap-search {
    max-width: 560px;
    margin: 0 auto;
    position: relative;
    display: flex;
    gap: 8px;
}
.acs-sitemap-search input {
    flex: 1;
    height: 48px;
    padding: 0 18px 0 44px;
    border: 1.5px solid var(--acs-border);
    border-radius: 999px;
    background: #fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%236b7280" stroke-width="2" stroke-linecap="round"><circle cx="11" cy="11" r="7"/><line x1="21" y1="21" x2="16.65" y2="16.65"/></svg>') no-repeat 14px center;
    background-size: 18px 18px;
    font-family: var(--acs-font-sans);
    font-size: 15px;
    color: var(--acs-n-900);
    transition: border-color 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-sitemap-search input:focus {
    border-color: var(--acs-brand);
    box-shadow: 0 0 0 3px var(--acs-brand-soft);
    outline: none;
}
.acs-sitemap-search button {
    height: 48px;
    padding: 0 18px;
    border: 1.5px solid var(--acs-border);
    border-radius: 999px;
    background: #fff;
    color: var(--acs-n-700);
    font-family: var(--acs-font-sans);
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-sitemap-search button:hover { border-color: var(--acs-brand); color: var(--acs-brand-deep); }
.acs-sitemap-empty {
    text-align: center;
    color: var(--acs-n-600);
    margin: 16px 0 0;
    font-size: 15px;
}

.acs-sitemap-toc {
    position: sticky;
    top: 72px;
    z-index: 5;
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border-bottom: 1px solid var(--acs-border);
}
.acs-sitemap-toc .acs-sitemap-inner {
    display: flex; flex-wrap: wrap; gap: 16px 24px;
    padding-top: 16px; padding-bottom: 16px;
    align-items: center;
}
.acs-sitemap-toc a {
    color: var(--acs-n-700);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 10px;
    border-radius: 999px;
    transition: background 0.15s var(--acs-ease), color 0.15s var(--acs-ease);
}
.acs-sitemap-toc a:hover { background: var(--acs-brand-soft); color: var(--acs-brand-deep); }

.acs-sitemap-section { padding: 56px 24px; background: #fff; }
.acs-sitemap-section-alt { background: var(--acs-bg-soft); }
.acs-sitemap-section h2 {
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 8px;
    color: var(--acs-n-900);
    scroll-margin-top: 140px;
}
.acs-sitemap-sub { color: var(--acs-n-600); margin: 0 0 28px; font-size: 16px; }
.acs-sitemap-section h3 {
    font-size: 17px;
    font-weight: 700;
    color: var(--acs-n-900);
    margin: 24px 0 12px;
    letter-spacing: -0.01em;
}
.acs-sitemap-count {
    font-weight: 500;
    color: var(--acs-n-500);
    font-size: 13px;
}

.acs-sitemap-region { margin: 16px 0 24px; }
.acs-sitemap-region-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--acs-brand-deep);
    margin: 0 0 10px;
}

.acs-sitemap-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}
@media (max-width: 880px) { .acs-sitemap-two-col { grid-template-columns: 1fr; gap: 24px; } }

.acs-sitemap-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 6px 16px;
}
.acs-sitemap-grid li { margin: 0; padding: 0; list-style: none; }
.acs-sitemap-grid a {
    display: block;
    padding: 6px 0;
    color: var(--acs-n-700);
    text-decoration: none;
    font-size: 14.5px;
    border-bottom: 1px solid transparent;
    transition: color 0.15s var(--acs-ease), border-color 0.15s var(--acs-ease);
}
.acs-sitemap-grid a:hover {
    color: var(--acs-brand-deep);
    border-bottom-color: var(--acs-brand);
}

.acs-sitemap-blog {
    list-style: none;
    margin: 0;
    padding: 0;
}
.acs-sitemap-blog li {
    margin: 0 0 4px;
    list-style: none;
}
.acs-sitemap-blog a {
    display: flex;
    align-items: baseline;
    gap: 14px;
    padding: 12px 16px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    text-decoration: none;
    transition: border-color 0.15s var(--acs-ease), background 0.15s var(--acs-ease);
}
.acs-sitemap-blog a:hover {
    border-color: var(--acs-brand);
    background: var(--acs-brand-soft);
}
.acs-sitemap-blog-date {
    color: var(--acs-n-500);
    font-size: 13px;
    font-weight: 500;
    min-width: 130px;
    flex-shrink: 0;
}
.acs-sitemap-blog-title {
    color: var(--acs-n-900);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
}
@media (max-width: 540px) {
    .acs-sitemap-blog a { flex-direction: column; gap: 4px; }
    .acs-sitemap-blog-date { min-width: 0; }
}

/* Hide the legacy Qode title block (rendered by sitemap.php as part of header) */
.page-template-sitemap .qodef-title-subtitle-holder,
.page-template-sitemap .qodef-title { display: none !important; }


/* ----------------------------------------------------------------------------
   14. Universal product-page CTA — appended via the_content filter on
   country/recharge/forfait pages to funnel toward the App Store / Play Store.
---------------------------------------------------------------------------- */

.acs-product-cta {
    margin: 48px 0 24px;
    padding: 48px 24px;
    background: linear-gradient(135deg, var(--acs-brand) 0%, var(--acs-brand-strong) 100%);
    border-radius: 20px;
    color: #fff;
    text-align: center;
    font-family: var(--acs-font-sans);
}
.acs-product-cta-inner { max-width: 720px; margin: 0 auto; }
.acs-product-cta-eyebrow {
    display: inline-block;
    color: rgba(255,255,255,0.85);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
}
.acs-product-cta-h2 {
    color: #fff !important;
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0 0 12px !important;
}
.acs-product-cta-sub {
    color: rgba(255,255,255,0.92) !important;
    font-size: 17px;
    line-height: 1.5;
    margin: 0 auto 24px !important;
    max-width: 520px;
}
.acs-product-cta-badges {
    display: flex;
    gap: 12px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
/* Each badge is a fixed-size box (180×56) — the image is centred inside via
   object-fit, so visually-cropped App-Store (281×83) and Google-Play (564×168)
   logos land at identical width/height regardless of their internal padding. */
.acs-product-cta-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 180px;
    height: 56px;
    text-decoration: none !important;
    border-bottom: 0 !important;
    transition: transform 0.15s var(--acs-ease);
}
.acs-product-cta-badge:hover { transform: translateY(-1px); }
.acs-product-cta-badge img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
}
.acs-product-cta-ratings {
    color: rgba(255,255,255,0.85) !important;
    font-size: 13px;
    letter-spacing: 0.02em;
    margin: 0 !important;
}
@media (max-width: 540px) {
    .acs-product-cta { padding: 36px 20px; margin: 32px 0 12px; }
    .acs-product-cta-badge { width: 152px; height: 48px; }
}

/* Country-scoped FAQ accordion injected on product pages */
.acs-product-faq {
    margin: 40px 0 24px;
    font-family: var(--acs-font-sans);
}
.acs-product-faq-inner { max-width: 760px; margin: 0 auto; }
.acs-product-faq-h2 {
    font-size: clamp(22px, 2.6vw, 28px) !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
    color: var(--acs-n-900) !important;
    margin: 0 0 20px !important;
    text-align: center;
}
.acs-product-faq-list { display: flex; flex-direction: column; gap: 10px; }
.acs-product-faq-item {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    padding: 18px 22px;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-product-faq-item:hover { border-color: var(--acs-brand); }
.acs-product-faq-item summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 16px;
    list-style: none;
    position: relative;
    padding-right: 28px;
    color: var(--acs-n-900);
    line-height: 1.4;
}
.acs-product-faq-item summary::-webkit-details-marker { display: none; }
.acs-product-faq-item summary::after {
    content: "+";
    position: absolute; right: 0; top: 50%;
    transform: translateY(-50%);
    font-size: 22px;
    color: var(--acs-brand-deep);
    line-height: 1;
}
.acs-product-faq-item[open] summary::after { content: "−"; }
.acs-product-faq-body {
    margin-top: 12px;
    color: var(--acs-n-700);
    line-height: 1.6;
    font-size: 15px;
}

/* Same-country cross-product widget (Call / Recharge / Forfait) */
.acs-product-related {
    margin: 40px 0 24px;
    padding: 28px;
    background: var(--acs-bg-soft);
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    font-family: var(--acs-font-sans);
}
.acs-product-related-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--acs-brand-deep) !important;
    margin: 0 0 16px !important;
}
.acs-product-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}
.acs-product-related-card {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    color: var(--acs-n-900) !important;
    text-decoration: none !important;
    font-weight: 600;
    font-size: 15px;
    transition: border-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease), color 0.15s var(--acs-ease), background 0.15s var(--acs-ease);
}
.acs-product-related-card:hover {
    border-color: var(--acs-brand) !important;
    color: var(--acs-brand-deep) !important;
    background: var(--acs-brand-soft);
    transform: translateY(-1px);
}
.acs-product-related-arrow {
    color: var(--acs-brand-deep);
    font-weight: 400;
    transition: transform 0.15s var(--acs-ease);
}
.acs-product-related-card:hover .acs-product-related-arrow { transform: translateX(2px); }


/* ----------------------------------------------------------------------------
   16. Product pages (call-*, fr/appeler-*, mobile-recharge-*, fr/recharges-*)
   — tame the legacy WPBakery dump so it stops competing with the brand layout.
---------------------------------------------------------------------------- */

/* Breathing room between Qode title bar and the WPBakery content. The title bar
   already has its own bg (brand-soft) thanks to section 12; the content needs a
   margin so it doesn't collide visually with the H1 zone. */
body.qodef-blog-installed .qodef-container,
body.single .qodef-container { padding-top: 32px; }

/* WPBakery wrapper — readable max-width, line-height, justified body off. */
.wpb-content-wrapper {
    max-width: 800px;
    margin: 0 auto;
    font-family: var(--acs-font-sans);
    color: var(--acs-n-800);
    line-height: 1.65;
    font-size: 16.5px;
}
.wpb-content-wrapper p,
.wpb-content-wrapper li {
    color: var(--acs-n-800) !important;
    line-height: 1.65 !important;
    text-align: left !important; /* override inline justify which kills readability */
}
.wpb-content-wrapper p { margin: 0 0 16px; }
.wpb-content-wrapper ul, .wpb-content-wrapper ol { margin: 0 0 20px 22px; padding: 0; }
.wpb-content-wrapper li { margin: 4px 0; }

/* Headings inside the WPBakery body — make them feel like the rest of the brand. */
.wpb-content-wrapper h2,
.wpb-content-wrapper .wpb_wrapper h2 {
    font-family: var(--acs-font-sans) !important;
    font-size: clamp(22px, 2.4vw, 28px) !important;
    font-weight: 700 !important;
    letter-spacing: -0.015em !important;
    color: var(--acs-n-900) !important;
    line-height: 1.25 !important;
    margin: 36px 0 14px !important;
    text-align: left !important;
}
.wpb-content-wrapper h3,
.wpb-content-wrapper .wpb_wrapper h3 {
    font-family: var(--acs-font-sans) !important;
    font-size: 19px !important;
    font-weight: 700 !important;
    color: var(--acs-n-900) !important;
    margin: 28px 0 10px !important;
}

/* Body links — keep brand color, no underline by default, underline on hover. */
.wpb-content-wrapper p a,
.wpb-content-wrapper li a {
    color: var(--acs-brand-deep) !important;
    text-decoration: none !important;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s var(--acs-ease);
}
.wpb-content-wrapper p a:hover,
.wpb-content-wrapper li a:hover { border-bottom-color: var(--acs-brand); }

/* Hide WPBakery rows that ended up with no useful descendant after our cleanup. */
.wpb-content-wrapper .vc_row.vc_row-fluid > .qodef-full-section-inner:empty,
.wpb-content-wrapper .vc_row.vc_row-fluid:has(> .clearfix.qodef-full-section-inner:empty) { display: none; }

/* The product CTA + FAQ + related blocks we inject — preserve their own width */
.acs-product-faq,
.acs-product-related,
.acs-product-cta {
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

/* Mobile: tighten the title bar so it doesn't dominate the viewport on phones */
@media (max-width: 720px) {
    body.qodef-blog-installed .qodef-title-subtitle-holder,
    body.single .qodef-title-subtitle-holder { padding: 36px 20px 28px !important; }
    body.qodef-blog-installed .qodef-container,
    body.single .qodef-container { padding-top: 16px; }
    .wpb-content-wrapper { padding: 0 16px; font-size: 16px; }
}


/* ----------------------------------------------------------------------------
   17. FR country landing template (template-fr-country.php)
---------------------------------------------------------------------------- */

.acs-country-main { font-family: var(--acs-font-sans); color: var(--acs-n-900); }
.acs-country-main * { box-sizing: border-box; }
.acs-country-inner { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.acs-country-inner-narrow { max-width: 760px; }

/* HERO ----------------------------------------------------------------------- */
.acs-country-hero {
    padding: 72px 24px 56px;
    background: linear-gradient(180deg, #fff 0%, var(--acs-brand-soft) 100%);
    text-align: center;
}
.acs-country-hero-inner { max-width: 720px; margin: 0 auto; }
.acs-country-flag {
    font-size: clamp(56px, 8vw, 88px);
    line-height: 1;
    margin: 0 0 16px;
}
.acs-country-eyebrow {
    display: inline-block;
    color: var(--acs-brand-deep);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
}
.acs-country-h1 {
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 18px;
    color: var(--acs-n-900);
}
.acs-country-lead {
    font-size: 18px;
    color: var(--acs-n-700);
    line-height: 1.55;
    margin: 0 auto 28px;
    max-width: 560px;
}
.acs-country-cta {
    display: flex; gap: 12px; justify-content: center; align-items: center; flex-wrap: wrap;
    margin-bottom: 16px;
}
.acs-country-cta .acs-wa-badge {
    width: 188px; height: 56px;
}
.acs-country-ratings {
    color: var(--acs-n-600);
    font-size: 13px;
    margin: 0;
    letter-spacing: 0.02em;
}

/* SECTIONS ------------------------------------------------------------------- */
.acs-country-section { padding: 64px 24px; background: #fff; }
.acs-country-section-soft { background: var(--acs-bg-soft); }
.acs-country-h2 {
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--acs-n-900);
    margin: 0 0 32px;
    text-align: center;
}

/* BENEFITS ------------------------------------------------------------------- */
.acs-country-benefits {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
    max-width: 880px;
    margin: 0 auto;
}
@media (max-width: 720px) { .acs-country-benefits { grid-template-columns: 1fr; } }
.acs-country-benefit {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    padding: 28px;
}
.acs-country-benefit-icon {
    width: 48px; height: 48px;
    display: flex; align-items: center; justify-content: center;
    background: var(--acs-brand-soft);
    border-radius: 12px;
    font-size: 24px;
    margin-bottom: 16px;
}
.acs-country-benefit h3 {
    font-size: 18px; font-weight: 700;
    margin: 0 0 8px;
    color: var(--acs-n-900);
    letter-spacing: -0.01em;
}
.acs-country-benefit p {
    color: var(--acs-n-700);
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
}

/* HOW IT WORKS --------------------------------------------------------------- */
.acs-country-steps {
    list-style: none;
    counter-reset: acs-country-step;
    padding: 0;
    margin: 0 auto;
    max-width: 720px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.acs-country-steps li {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 14px;
    padding: 22px 24px;
}
.acs-country-step-num {
    flex-shrink: 0;
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    background: var(--acs-brand-deep);
    color: #fff;
    border-radius: 50%;
    font-weight: 700;
    font-size: 17px;
}
.acs-country-steps h3 {
    font-size: 17px; font-weight: 700;
    margin: 0 0 4px;
    color: var(--acs-n-900);
}
.acs-country-steps p {
    color: var(--acs-n-700);
    font-size: 15px;
    line-height: 1.5;
    margin: 0;
}

/* CROSS-PRODUCT (recharge link) --------------------------------------------- */
.acs-country-cross {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    max-width: 720px;
    margin: 0 auto;
    padding: 24px 28px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    text-decoration: none !important;
    color: inherit !important;
    transition: border-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease), background 0.15s var(--acs-ease);
}
.acs-country-cross:hover {
    border-color: var(--acs-brand) !important;
    background: var(--acs-brand-soft);
    transform: translateY(-1px);
}
.acs-country-cross-eyebrow {
    display: block;
    color: var(--acs-brand-deep);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 4px;
}
.acs-country-cross-title {
    display: block;
    color: var(--acs-n-900);
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 4px;
    letter-spacing: -0.01em;
}
.acs-country-cross-sub {
    display: block;
    color: var(--acs-n-600);
    font-size: 14px;
}
.acs-country-cross-arrow {
    color: var(--acs-brand-deep);
    font-size: 24px;
    flex-shrink: 0;
    transition: transform 0.15s var(--acs-ease);
}
.acs-country-cross:hover .acs-country-cross-arrow { transform: translateX(2px); }

/* FAQ accordion -------------------------------------------------------------- */
.acs-country-faqs { display: flex; flex-direction: column; gap: 10px; }
.acs-country-faq {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    padding: 18px 22px;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-country-faq:hover { border-color: var(--acs-brand); }
.acs-country-faq summary {
    cursor: pointer;
    list-style: none;
    font-weight: 600;
    font-size: 16px;
    line-height: 1.4;
    color: var(--acs-n-900);
    position: relative;
    padding-right: 28px;
}
.acs-country-faq summary::-webkit-details-marker { display: none; }
.acs-country-faq summary::after {
    content: "+";
    position: absolute;
    right: 0; top: 50%;
    transform: translateY(-50%);
    font-size: 22px;
    color: var(--acs-brand-deep);
    line-height: 1;
}
.acs-country-faq[open] summary::after { content: "−"; }
.acs-country-faq-body {
    margin-top: 12px;
    color: var(--acs-n-700);
    line-height: 1.6;
    font-size: 15px;
}

/* RELATED NEIGHBOURS -------------------------------------------------------- */
.acs-country-neighbours {
    list-style: none;
    padding: 0; margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    max-width: 880px;
    margin: 0 auto;
}
.acs-country-neighbours li { margin: 0; list-style: none; }
.acs-country-neighbours a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    text-decoration: none !important;
    color: var(--acs-n-900) !important;
    font-weight: 500;
    transition: border-color 0.15s var(--acs-ease), background 0.15s var(--acs-ease), transform 0.15s var(--acs-ease);
}
.acs-country-neighbours a:hover {
    border-color: var(--acs-brand);
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep) !important;
    transform: translateY(-1px);
}
.acs-country-neighbours .acs-wa-flag { font-size: 22px; line-height: 1; }

/* FINAL CTA BANNER ---------------------------------------------------------- */
.acs-country-cta-banner {
    padding: 80px 24px;
    background: linear-gradient(135deg, var(--acs-brand-deep) 0%, var(--acs-brand-strong) 100%);
    color: #fff;
    text-align: center;
}
.acs-country-cta-banner h2 {
    color: #fff !important;
    font-size: clamp(26px, 3.4vw, 36px);
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0 0 12px;
    line-height: 1.15;
}
.acs-country-cta-banner p {
    color: rgba(255,255,255,0.92);
    font-size: 17px;
    margin: 0 auto 28px;
    max-width: 560px;
    line-height: 1.5;
}
.acs-country-cta-banner .acs-country-cta .acs-wa-badge { background: rgba(255,255,255,0.04); }

/* Defensive: hide any legacy Qode title block that might still render */
body.fr-country-landing .qodef-title-subtitle-holder,
body.fr-country-landing .qodef-title { display: none !important; }


/* ----------------------------------------------------------------------------
   18. Live rate card on country pages + currency switcher (page-prices/country)
---------------------------------------------------------------------------- */

.acs-country-rates {
    padding: 24px 24px 8px;
    background: #fff;
}
.acs-country-rate-card {
    background: linear-gradient(135deg, #fff 0%, var(--acs-brand-soft) 100%);
    border: 1px solid var(--acs-border);
    border-radius: 20px;
    padding: 32px 28px;
    text-align: center;
    box-shadow: 0 4px 16px rgba(147, 202, 75, 0.08);
}
.acs-country-rate-eyebrow {
    display: inline-block;
    color: var(--acs-brand-deep);
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 8px;
}
.acs-country-rate-h2 {
    font-size: clamp(20px, 2.4vw, 26px) !important;
    font-weight: 700 !important;
    letter-spacing: -0.015em !important;
    color: var(--acs-n-900) !important;
    margin: 0 0 24px !important;
    line-height: 1.25 !important;
}
.acs-country-rate-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 16px;
    max-width: 540px;
    margin: 0 auto 20px;
}
.acs-country-rate-cell {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 14px;
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}
.acs-country-rate-cell-pass {
    background: var(--acs-brand);
    border-color: var(--acs-brand);
}
.acs-country-rate-cell-pass .acs-country-rate-label,
.acs-country-rate-cell-pass .acs-country-rate-value { color: #fff !important; }
.acs-country-rate-label {
    color: var(--acs-n-600);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.acs-country-rate-value {
    color: var(--acs-n-900);
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.02em;
}
.acs-country-rate-note {
    color: var(--acs-n-500);
    font-size: 12.5px;
    margin: 14px 0 0 !important;
}

/* Currency switcher — inline pill form */
.acs-currency-switcher {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 999px;
    padding: 6px 6px 6px 16px;
    font-family: var(--acs-font-sans);
    font-size: 14px;
    margin: 0 0 24px;
}
.acs-currency-switcher-inline { margin: 0; }
.acs-currency-label {
    color: var(--acs-n-700);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.02em;
}
.acs-currency-switcher select {
    appearance: none;
    -webkit-appearance: none;
    background: var(--acs-brand-soft);
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 6px 28px 6px 14px;
    font-family: var(--acs-font-sans);
    font-size: 14px;
    font-weight: 600;
    color: var(--acs-brand-deep);
    cursor: pointer;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%235C8E29" stroke-width="2"><polyline points="6 9 12 15 18 9"/></svg>');
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 14px 14px;
    transition: border-color 0.15s var(--acs-ease);
}
.acs-currency-switcher select:hover { border-color: var(--acs-brand); }
.acs-currency-switcher select:focus { outline: none; border-color: var(--acs-brand); box-shadow: 0 0 0 3px var(--acs-brand-soft); }

/* Page-prices specific: centre the switcher + disclaimer under the table */
.acs-wa-section .acs-currency-switcher {
    display: inline-flex;
    margin: 0 auto 24px;
}
.acs-wa-section > .acs-wa-section-inner > .acs-currency-switcher {
    display: flex;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
}
.acs-rates-disclaimer {
    margin: 14px 0 0 !important;
    text-align: center;
    color: var(--acs-n-500);
    font-size: 12.5px;
}


/* ----------------------------------------------------------------------------
   19. Priority destinations grid + full prices table (page-prices.php)
---------------------------------------------------------------------------- */

/* --- Priority cards grid --- */
.acs-targets-grid {
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
}
.acs-target-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    padding: 20px 22px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: border-color 0.18s var(--acs-ease), transform 0.18s var(--acs-ease), box-shadow 0.18s var(--acs-ease);
}
.acs-target-card:hover {
    border-color: var(--acs-brand);
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(147, 202, 75, 0.16);
}
.acs-target-link {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    text-decoration: none !important;
    z-index: 1;
}
.acs-target-head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.acs-target-flag { font-size: 28px; line-height: 1; }
.acs-target-name {
    font-weight: 700;
    font-size: 16px;
    color: var(--acs-n-900);
    letter-spacing: -0.01em;
}
.acs-target-rates {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px 12px;
}
.acs-target-rate {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.acs-target-rate-label {
    color: var(--acs-n-500);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.acs-target-rate strong {
    color: var(--acs-n-900);
    font-size: 16px;
    font-weight: 700;
}
.acs-target-pass {
    margin-top: 4px;
    padding: 6px 10px;
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep);
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 600;
    align-self: flex-start;
}
.acs-target-pass strong { font-weight: 700; }

/* --- Filter input --- */
.acs-prices-filter {
    max-width: 480px;
    margin: 0 auto 16px;
}
.acs-prices-filter input {
    width: 100%;
    height: 44px;
    padding: 0 18px 0 44px;
    border: 1.5px solid var(--acs-border);
    border-radius: 999px;
    background: #fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%236b7280" stroke-width="2" stroke-linecap="round"><circle cx="11" cy="11" r="7"/><line x1="21" y1="21" x2="16.65" y2="16.65"/></svg>') no-repeat 14px center;
    background-size: 18px 18px;
    font-family: var(--acs-font-sans);
    font-size: 15px;
    transition: border-color 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-prices-filter input:focus {
    border-color: var(--acs-brand);
    box-shadow: 0 0 0 3px var(--acs-brand-soft);
    outline: none;
}
.acs-prices-empty {
    text-align: center;
    color: var(--acs-n-600);
    margin: 0 0 16px;
    font-size: 15px;
}

/* --- Per-continent section + table --- */
.acs-prices-cont {
    max-width: 920px;
    margin: 32px auto;
}
.acs-prices-cont-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--acs-n-900) !important;
    margin: 0 0 12px !important;
    letter-spacing: -0.01em;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--acs-border);
}
.acs-prices-cont-count {
    color: var(--acs-n-500);
    font-weight: 500;
    font-size: 14px;
    margin-left: 4px;
}
.acs-prices-table-wrap {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 14px;
    overflow: hidden;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.acs-prices-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14.5px;
    min-width: 540px;
}
.acs-prices-table th {
    text-align: right;
    padding: 12px 16px;
    color: var(--acs-n-500);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--acs-border);
    background: var(--acs-bg-soft);
}
.acs-prices-th-dest { text-align: left !important; }
.acs-prices-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--acs-n-100);
    vertical-align: middle;
}
.acs-prices-table tr:last-child td { border-bottom: 0; }
.acs-prices-table tr:hover td { background: var(--acs-bg-soft); }
.acs-prices-num { text-align: right; color: var(--acs-n-700); font-variant-numeric: tabular-nums; }
.acs-prices-num strong { color: var(--acs-n-900); font-weight: 700; }
.acs-prices-dest {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--acs-n-900) !important;
    text-decoration: none !important;
    font-weight: 500;
}
a.acs-prices-dest:hover { color: var(--acs-brand-deep) !important; }
.acs-prices-flag { font-size: 20px; line-height: 1; }

/* --- Target row highlight --- */
.acs-prices-target td {
    background: linear-gradient(90deg, var(--acs-brand-soft) 0%, #fff 70%);
}
.acs-prices-target:hover td {
    background: linear-gradient(90deg, var(--acs-brand-soft) 0%, var(--acs-bg-soft) 100%);
}
.acs-prices-target-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px; height: 18px;
    margin-left: 6px;
    background: var(--acs-brand);
    color: #fff;
    font-size: 11px;
    border-radius: 50%;
    line-height: 1;
}

@media (max-width: 540px) {
    .acs-prices-table { font-size: 13.5px; }
    .acs-prices-table th, .acs-prices-table td { padding: 10px 12px; }
    .acs-prices-flag { font-size: 18px; }
}


/* ----------------------------------------------------------------------------
   15. Multi-platform "Get the app" landing (template-apps.php)
---------------------------------------------------------------------------- */

.acs-apps-main { font-family: var(--acs-font-sans); color: var(--acs-n-900); }
.acs-apps-main * { box-sizing: border-box; }
.acs-apps-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

.acs-apps-hero {
    padding: 80px 24px 56px;
    background: linear-gradient(180deg, #fff 0%, var(--acs-brand-soft) 100%);
    text-align: center;
}
.acs-apps-eyebrow {
    display: inline-block;
    color: var(--acs-brand-deep);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
}
.acs-apps-h1 {
    font-size: clamp(40px, 5vw, 64px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.03em;
    margin: 0 0 20px;
    color: var(--acs-n-900);
}
.acs-apps-lead {
    font-size: 18px;
    color: var(--acs-n-700);
    line-height: 1.55;
    max-width: 620px;
    margin: 0 auto;
}

.acs-apps-section { padding: 64px 24px; background: #fff; }
.acs-apps-section-alt { background: var(--acs-bg-soft); }
.acs-apps-h2 {
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 32px;
    color: var(--acs-n-900);
    text-align: center;
}

.acs-apps-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    max-width: 880px;
    margin: 0 auto;
}
.acs-apps-grid-soon { grid-template-columns: repeat(3, minmax(0, 1fr)); max-width: 1080px; }
@media (max-width: 880px) {
    .acs-apps-grid,
    .acs-apps-grid-soon { grid-template-columns: 1fr; }
}

.acs-apps-card {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 28px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 18px;
    text-decoration: none;
    color: inherit;
    transition: transform 0.18s var(--acs-ease), border-color 0.18s var(--acs-ease), box-shadow 0.18s var(--acs-ease);
}
.acs-apps-card-available:hover {
    transform: translateY(-2px);
    border-color: var(--acs-brand);
    box-shadow: 0 14px 28px rgba(147, 202, 75, 0.20);
}
.acs-apps-card-icon {
    flex-shrink: 0;
    width: 56px; height: 56px;
    display: flex; align-items: center; justify-content: center;
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep);
    border-radius: 14px;
}
.acs-apps-card-body { flex: 1; min-width: 0; }
.acs-apps-card h3 {
    font-size: 19px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--acs-n-900);
    margin: 0 0 4px;
}
.acs-apps-card-sub {
    font-size: 14px;
    color: var(--acs-n-600);
    margin: 0 0 16px;
}
.acs-apps-card-badge {
    display: block;
    width: 162px;
    height: 48px;
    object-fit: contain;
    object-position: left;
}
.acs-apps-card-pill {
    display: inline-block;
    padding: 6px 14px;
    background: var(--acs-n-100);
    color: var(--acs-n-500);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
}
.acs-apps-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 48px;
    padding: 0 28px;
    background: var(--acs-brand);
    color: #fff;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.01em;
    transition: background 0.18s var(--acs-ease);
}
.acs-apps-card-available:hover .acs-apps-card-cta {
    background: var(--acs-brand-strong);
}

.acs-apps-card-soon { cursor: default; }
.acs-apps-card-soon .acs-apps-card-icon {
    background: var(--acs-n-100);
    color: var(--acs-n-500);
}
.acs-apps-card-soon h3 { color: var(--acs-n-700); }
.acs-apps-card-soon:hover { border-color: var(--acs-border); transform: none; box-shadow: none; }

.acs-apps-why {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px;
    max-width: 1080px;
    margin: 0 auto;
}
@media (max-width: 880px) { .acs-apps-why { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 540px) { .acs-apps-why { grid-template-columns: 1fr; } }
.acs-apps-why-item {
    padding: 24px;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 14px;
}
.acs-apps-why-item h3 {
    font-size: 17px;
    font-weight: 700;
    color: var(--acs-n-900);
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}
.acs-apps-why-item p {
    color: var(--acs-n-600);
    font-size: 14.5px;
    line-height: 1.5;
    margin: 0;
}
.acs-apps-note {
    text-align: center;
    color: var(--acs-n-500);
    font-size: 14px;
    margin: 40px 0 0;
}

/* Hide the legacy Qode title block on this template */
.page-template-template-apps .qodef-title-subtitle-holder,
.page-template-template-apps .qodef-title { display: none !important; }

/* ============================================================
   20. BREADCRUMB
   ============================================================ */
.acs-breadcrumb {
    background: #fff;
    border-bottom: 1px solid var(--acs-border);
}
.acs-breadcrumb-inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 14px 24px;
}
.acs-breadcrumb ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 13.5px;
    color: var(--acs-n-600);
}
.acs-breadcrumb li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.acs-breadcrumb li + li::before {
    content: "›";
    color: var(--acs-n-400);
    font-weight: 600;
}
.acs-breadcrumb a {
    color: var(--acs-n-600);
    text-decoration: none;
    transition: color 120ms ease;
}
.acs-breadcrumb a:hover,
.acs-breadcrumb a:focus { color: var(--acs-brand-deep); text-decoration: underline; }
.acs-breadcrumb [aria-current="page"] {
    color: var(--acs-n-900);
    font-weight: 600;
}
@media (max-width: 600px) {
    .acs-breadcrumb-inner { padding: 12px 16px; }
    .acs-breadcrumb ol { font-size: 12.5px; gap: 4px; }
}

/* ============================================================
   21. SINGLE-POST CTA + RELATED ARTICLES
   ============================================================ */
.acs-blog-cta {
    margin: 48px 0 32px;
    padding: 32px 28px;
    background: var(--acs-brand-soft);
    border-radius: 14px;
    border: 1px solid #d8eab2;
    text-align: center;
}
.acs-blog-cta-eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--acs-brand-deep);
    margin-bottom: 8px;
}
.acs-blog-cta-h2 {
    font-size: 26px;
    font-weight: 700;
    color: var(--acs-n-900);
    margin: 0 0 10px;
    letter-spacing: -0.02em;
}
.acs-blog-cta-lead {
    color: var(--acs-n-700);
    font-size: 15.5px;
    line-height: 1.55;
    max-width: 540px;
    margin: 0 auto 22px;
}
.acs-blog-cta-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0;
}
.acs-blog-cta-btn {
    display: inline-flex;
    align-items: center;
    padding: 12px 22px;
    border-radius: 999px;
    font-size: 14.5px;
    font-weight: 600;
    text-decoration: none !important;
    transition: all 0.15s ease;
    border: 1.5px solid transparent;
}
.acs-blog-cta-btn-primary { background: var(--acs-brand-deep); color: #fff !important; border-color: var(--acs-brand-deep); }
.acs-blog-cta-btn-primary:hover { background: #3D5F1B; border-color: #3D5F1B; transform: translateY(-1px); }
.acs-blog-cta-btn-ghost { background: #fff; color: var(--acs-n-900) !important; border-color: var(--acs-border); }
.acs-blog-cta-btn-ghost:hover { border-color: var(--acs-brand-deep); color: var(--acs-brand-deep) !important; }

.acs-related {
    margin: 32px 0 16px;
}
.acs-related-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--acs-n-900);
    margin: 0 0 18px;
    letter-spacing: -0.01em;
}
.acs-related-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
@media (max-width: 900px) { .acs-related-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .acs-related-grid { grid-template-columns: 1fr; } }
.acs-related-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none !important;
    color: var(--acs-n-900);
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.acs-related-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
    border-color: var(--acs-brand);
}
.acs-related-thumb {
    display: block;
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    background-color: var(--acs-n-100);
}
.acs-related-thumb-fallback {
    background-image: linear-gradient(135deg, var(--acs-brand-soft) 0%, #f3f4f6 100%);
}
.acs-related-body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}
.acs-related-cat {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--acs-brand-deep);
}
.acs-related-h3 {
    font-size: 15.5px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--acs-n-900);
    letter-spacing: -0.01em;
}

/* In-content auto-link to /call-X / /fr/appeler-X — subtle underline only. */
.acs-autolink {
    color: var(--acs-brand-deep);
    text-decoration: underline;
    text-decoration-color: rgba(92, 142, 41, 0.35);
    text-underline-offset: 2px;
    transition: text-decoration-color 0.15s ease, color 0.15s ease;
}
.acs-autolink:hover {
    color: #3D5F1B;
    text-decoration-color: var(--acs-brand-deep);
}


/* ============================================================================
   14. Account / data deletion landings (template-account-deletion*.php)
   Required by Apple App Store + Google Play Store. Kept visually quiet — this
   is a compliance page, not a marketing page — but it still inherits the
   brand palette + typography.
   ============================================================================ */

.acs-deletion-main {
    font-family: var(--acs-font-sans);
    color: var(--acs-n-900);
    line-height: 1.55;
    background: var(--acs-bg);
}
.acs-deletion-main * { box-sizing: border-box; }
.acs-deletion-inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 24px;
}
.acs-deletion-inner-narrow { max-width: 640px; }

.acs-deletion-hero {
    padding: 72px 24px 48px;
    background: linear-gradient(180deg, #fff 0%, var(--acs-brand-soft) 100%);
    text-align: center;
}
.acs-deletion-eyebrow {
    display: inline-block;
    color: var(--acs-brand-strong);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
}
.acs-deletion-h1 {
    font-size: clamp(32px, 4vw, 48px);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 16px;
    color: var(--acs-n-900);
}
.acs-deletion-lead {
    font-size: 17px;
    color: var(--acs-n-700);
    line-height: 1.6;
    margin: 0 auto;
    max-width: 720px;
}

.acs-deletion-section {
    padding: 64px 24px;
    background: #fff;
}
.acs-deletion-section-alt { background: var(--acs-bg-soft); }

.acs-deletion-h2 {
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 12px;
    color: var(--acs-n-900);
}
.acs-deletion-section-lead {
    color: var(--acs-n-600);
    font-size: 16px;
    margin: 0 0 32px;
    max-width: 720px;
}

.acs-deletion-platforms {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
@media (max-width: 720px) {
    .acs-deletion-platforms { grid-template-columns: 1fr; gap: 16px; }
}
.acs-deletion-platform {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    padding: 28px 28px 24px;
}
.acs-deletion-platform h3 {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 16px;
    color: var(--acs-n-900);
    letter-spacing: -0.01em;
}
.acs-deletion-steps {
    margin: 0;
    padding-left: 22px;
    counter-reset: acs-step;
}
.acs-deletion-steps li {
    padding: 4px 0 4px 4px;
    color: var(--acs-n-700);
    font-size: 15px;
    line-height: 1.55;
}
.acs-deletion-steps li strong { color: var(--acs-n-900); font-weight: 600; }

.acs-deletion-items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}
@media (max-width: 720px) { .acs-deletion-items { grid-template-columns: 1fr; } }
.acs-deletion-item {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 12px;
    padding: 20px 22px;
}
.acs-deletion-item h3 {
    font-size: 16px;
    font-weight: 700;
    margin: 0 0 6px;
    color: var(--acs-n-900);
}
.acs-deletion-item p {
    margin: 0;
    font-size: 14.5px;
    color: var(--acs-n-600);
    line-height: 1.55;
}

.acs-deletion-kept {
    margin-top: 32px;
    padding: 20px 24px;
    background: #fff;
    border: 1px solid var(--acs-brand);
    border-left-width: 4px;
    border-radius: 12px;
}
.acs-deletion-kept h3 {
    font-size: 15px;
    font-weight: 700;
    margin: 0 0 4px;
    color: var(--acs-brand-deep);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.acs-deletion-kept p {
    margin: 0;
    color: var(--acs-n-700);
    font-size: 15px;
    line-height: 1.55;
}

/* Form */
.acs-deletion-form {
    background: #fff;
    border: 1px solid var(--acs-border);
    border-radius: 16px;
    padding: 28px;
    margin-top: 8px;
}
@media (max-width: 540px) { .acs-deletion-form { padding: 20px; } }
.acs-deletion-field { margin-bottom: 18px; }
.acs-deletion-field label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--acs-n-800);
    margin-bottom: 6px;
}
.acs-deletion-form input[type="text"],
.acs-deletion-form input[type="email"],
.acs-deletion-form textarea {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 14px;
    border: 1px solid var(--acs-border);
    border-radius: 10px;
    background: #fff;
    color: var(--acs-n-900);
    font: inherit;
    font-size: 15px;
    transition: border-color 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-deletion-form input:focus,
.acs-deletion-form textarea:focus {
    border-color: var(--acs-brand);
    box-shadow: 0 0 0 3px var(--acs-brand-soft);
    outline: none;
}
.acs-deletion-form textarea { resize: vertical; min-height: 96px; }

.acs-deletion-field-check label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-weight: 500;
    color: var(--acs-n-700);
    font-size: 14px;
    line-height: 1.5;
    cursor: pointer;
}
.acs-deletion-field-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    accent-color: var(--acs-brand);
    flex-shrink: 0;
}

.acs-deletion-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 26px;
    border-radius: 999px;
    border: none;
    background: var(--acs-brand);
    color: #fff;
    font-family: inherit;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(147, 202, 75, 0.30);
    transition: background-color 0.15s var(--acs-ease), transform 0.15s var(--acs-ease), box-shadow 0.15s var(--acs-ease);
}
.acs-deletion-btn:hover {
    background: var(--acs-brand-strong);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(147, 202, 75, 0.45);
}
.acs-deletion-btn:focus-visible {
    outline: 2px solid var(--acs-brand-deep);
    outline-offset: 2px;
}

.acs-deletion-note {
    margin: 14px 0 0;
    font-size: 13px;
    color: var(--acs-n-500);
    line-height: 1.5;
}

/* Honeypot — invisible to humans, never display:none (bots skip those). */
.acs-deletion-honey {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.acs-deletion-alert {
    padding: 14px 18px;
    border-radius: 12px;
    margin: 0 0 20px;
    font-size: 15px;
    line-height: 1.5;
}
.acs-deletion-alert-ok {
    background: var(--acs-brand-soft);
    color: var(--acs-brand-deep);
    border: 1px solid var(--acs-brand);
}
.acs-deletion-alert-err {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}
