/* =====================================================================
   ZwaAPI — Brand System Stylesheet
   ---------------------------------------------------------------------
   • Color tokens         (light + dark, semantic + raw)
   • Typography scale     (display / heading / body / micro)
   • Spacing / radius     (consistent rhythm)
   • Component overrides  (cards, badges, buttons, navbars)
   • Landing page styles  (hero, features, pricing, CTA, contact, FAQ)
   ===================================================================== */


/* ─────────────────────────────────────────────────────────────────────
   1. DESIGN TOKENS
   ───────────────────────────────────────────────────────────────────── */

:root {
    /* Brand palette (Emerald — WhatsApp-aligned, premium SaaS) */
    --zwa-brand-50:  #E6F9EF;
    --zwa-brand-100: #C3F0D8;
    --zwa-brand-200: #9BE5BD;
    --zwa-brand-300: #6FD79E;
    --zwa-brand-400: #47CA85;
    --zwa-brand-500: #25D366;
    --zwa-brand-600: #1FB155;
    --zwa-brand-700: #0F8A57;
    --zwa-brand-800: #075E54;
    --zwa-brand-900: #075E54;

    /* Neutrals */
    --zwa-slate-50:  #f8fafc;
    --zwa-slate-100: #f1f5f9;
    --zwa-slate-200: #e2e8f0;
    --zwa-slate-300: #cbd5e1;
    --zwa-slate-400: #94a3b8;
    --zwa-slate-500: #64748b;
    --zwa-slate-600: #475569;
    --zwa-slate-700: #334155;
    --zwa-slate-800: #1e293b;
    --zwa-slate-900: #0f172a;
    --zwa-slate-950: #020617;

    /* Accents */
    --zwa-accent: #0ea5e9;        /* sky-500  — info / accent */
    --zwa-warning: #f59e0b;       /* amber-500 */
    --zwa-danger: #ef4444;        /* red-500  */

    /* Semantic — LIGHT MODE defaults */
    --zwa-bg:          #ffffff;
    --zwa-bg-subtle:   #f8fafc;
    --zwa-bg-muted:    #f1f5f9;
    --zwa-surface:     #ffffff;
    --zwa-surface-2:   #f8fafc;
    --zwa-border:      #e2e8f0;
    --zwa-border-soft: #f1f5f9;

    --zwa-fg:          #0f172a;
    --zwa-fg-muted:    #475569;
    --zwa-fg-subtle:   #64748b;

    --zwa-primary:        var(--zwa-brand-600);
    --zwa-primary-hover:  var(--zwa-brand-700);
    --zwa-primary-soft:   var(--zwa-brand-50);
    --zwa-primary-fg:     #ffffff;

    /* Effects */
    --zwa-shadow-sm: 0 1px 2px 0 rgb(15 23 42 / 5%);
    --zwa-shadow:    0 4px 6px -1px rgb(15 23 42 / 6%), 0 2px 4px -2px rgb(15 23 42 / 4%);
    --zwa-shadow-md: 0 10px 25px -3px rgb(15 23 42 / 7%), 0 4px 6px -2px rgb(15 23 42 / 4%);
    --zwa-shadow-lg: 0 25px 50px -12px rgb(15 23 42 / 12%);
    --zwa-ring:      0 0 0 3px rgb(34 197 94 / 35%);

    /* Radii */
    --zwa-radius-sm: 6px;
    --zwa-radius:    10px;
    --zwa-radius-md: 14px;
    --zwa-radius-lg: 20px;
    --zwa-radius-xl: 28px;

    /* Typography */
    --zwa-font-sans:  'Public Sans', 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --zwa-font-mono:  ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", monospace;
}

/* DARK MODE overrides */
[data-bs-theme="dark"] {
    --zwa-bg:          #0a0f1c;
    --zwa-bg-subtle:   #0f172a;
    --zwa-bg-muted:    #111827;
    --zwa-surface:     #111827;
    --zwa-surface-2:   #1e293b;
    --zwa-border:      #1f2937;
    --zwa-border-soft: #111827;

    --zwa-fg:          #f8fafc;
    --zwa-fg-muted:    #cbd5e1;
    --zwa-fg-subtle:   #94a3b8;

    --zwa-primary-soft: rgb(34 197 94 / 12%);
    --zwa-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 25%);
    --zwa-shadow:    0 4px 6px -1px rgb(0 0 0 / 30%), 0 2px 4px -2px rgb(0 0 0 / 20%);
    --zwa-shadow-md: 0 10px 25px -3px rgb(0 0 0 / 40%), 0 4px 6px -2px rgb(0 0 0 / 25%);
    --zwa-shadow-lg: 0 25px 50px -12px rgb(0 0 0 / 60%);
}


/* ─────────────────────────────────────────────────────────────────────
   2. OVERRIDE BOOTSTRAP / VUEXY PRIMARY
   ───────────────────────────────────────────────────────────────────── */

:root,
[data-bs-theme="light"] {
    --bs-primary: var(--zwa-primary);
    --bs-primary-rgb: 22, 163, 74;
    --bs-link-color: var(--zwa-primary);
    --bs-link-hover-color: var(--zwa-primary-hover);
}
[data-bs-theme="dark"] {
    --bs-primary: var(--zwa-brand-500);
    --bs-primary-rgb: 34, 197, 94;
}


/* ─────────────────────────────────────────────────────────────────────
   3. GLOBAL TYPOGRAPHY & BODY
   ───────────────────────────────────────────────────────────────────── */

html, body {
    font-family: var(--zwa-font-sans);
    background: var(--zwa-bg);
    color: var(--zwa-fg);
    font-feature-settings: "cv11", "ss01";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--zwa-font-sans);
    color: var(--zwa-fg);
    letter-spacing: -0.02em;
    font-weight: 700;
}

.zwa-display-1 { font-size: clamp(2.5rem, 5vw + 1rem, 4.25rem); line-height: 1.05; font-weight: 800; letter-spacing: -0.035em; }
.zwa-display-2 { font-size: clamp(2rem, 3.2vw + 1rem, 3rem);    line-height: 1.1;  font-weight: 800; letter-spacing: -0.03em; }
.zwa-heading-1 { font-size: clamp(1.625rem, 1.6vw + 1rem, 2.25rem); line-height: 1.18; font-weight: 700; letter-spacing: -0.02em; }
.zwa-heading-2 { font-size: clamp(1.375rem, 1vw + 1rem, 1.75rem);   line-height: 1.25; font-weight: 700; letter-spacing: -0.01em; }
.zwa-eyebrow   { font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--zwa-primary); }
.zwa-lead      { font-size: 1.125rem; line-height: 1.6; color: var(--zwa-fg-muted); }

.zwa-text-muted { color: var(--zwa-fg-muted) !important; }
.zwa-text-subtle { color: var(--zwa-fg-subtle) !important; }

.zwa-gradient-text {
    background: linear-gradient(135deg, var(--zwa-brand-500), var(--zwa-accent));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}


/* ─────────────────────────────────────────────────────────────────────
   4. BUTTONS
   ───────────────────────────────────────────────────────────────────── */

.btn-zwa {
    --_bg: var(--zwa-primary);
    --_fg: var(--zwa-primary-fg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .75rem 1.25rem;
    background: var(--_bg);
    color: var(--_fg);
    border: 1px solid var(--_bg);
    border-radius: var(--zwa-radius);
    font-weight: 600;
    font-size: .95rem;
    line-height: 1.4;
    text-decoration: none;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease, background .2s ease, border-color .2s ease, color .2s ease;
    white-space: nowrap;
}
.btn-zwa:hover {
    background: var(--zwa-primary-hover);
    border-color: var(--zwa-primary-hover);
    color: var(--_fg);
    box-shadow: 0 8px 22px -8px rgb(22 163 74 / 55%);
    transform: translateY(-1px);
}
.btn-zwa:focus-visible {
    outline: none;
    box-shadow: var(--zwa-ring);
}

.btn-zwa--ghost {
    --_bg: transparent;
    --_fg: var(--zwa-fg);
    border-color: var(--zwa-border);
}
.btn-zwa--ghost:hover {
    --_bg: var(--zwa-bg-muted);
    --_fg: var(--zwa-fg);
    border-color: var(--zwa-border);
    box-shadow: none;
}

.btn-zwa--lg { padding: 1rem 1.6rem; font-size: 1rem; }
.btn-zwa--sm { padding: .55rem .9rem; font-size: .875rem; }

.btn-zwa--white {
    --_bg: #fff;
    --_fg: var(--zwa-slate-900);
    border-color: #fff;
}
.btn-zwa--white:hover { --_bg: #f8fafc; --_fg: var(--zwa-slate-900); }


/* ─────────────────────────────────────────────────────────────────────
   5. NAVBAR (LANDING)
   ───────────────────────────────────────────────────────────────────── */

.zwa-nav {
    position: sticky;
    top: 0;
    z-index: 1030;
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    background: color-mix(in srgb, var(--zwa-bg) 78%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--zwa-border) 70%, transparent);
}
.zwa-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .75rem 0;
}
.zwa-nav__links {
    display: flex;
    align-items: center;
    gap: .25rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.zwa-nav__links a {
    color: var(--zwa-fg-muted);
    font-weight: 500;
    font-size: .92rem;
    padding: .55rem .85rem;
    border-radius: 8px;
    text-decoration: none;
    transition: color .15s, background .15s;
}
.zwa-nav__links a:hover,
.zwa-nav__links a.is-active {
    color: var(--zwa-fg);
    background: var(--zwa-bg-muted);
}

.zwa-nav__tools { display: flex; align-items: center; gap: .5rem; }

.zwa-iconbtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    border-radius: 10px;
    border: 1px solid var(--zwa-border);
    background: var(--zwa-surface);
    color: var(--zwa-fg-muted);
    transition: all .15s;
    cursor: pointer;
}
.zwa-iconbtn:hover { color: var(--zwa-fg); background: var(--zwa-bg-muted); }


/* ─────────────────────────────────────────────────────────────────────
   6. HERO SECTION
   ───────────────────────────────────────────────────────────────────── */

.zwa-hero {
    position: relative;
    overflow: hidden;
    padding: 4.5rem 0 5rem;
    background: var(--zwa-bg);
}
.zwa-hero::before {
    content: "";
    position: absolute;
    inset: -20% -10% auto -10%;
    height: 70%;
    background:
        radial-gradient(60% 60% at 50% 0%, rgb(34 197 94 / 14%), transparent 70%),
        radial-gradient(40% 50% at 80% 40%, rgb(14 165 233 / 10%), transparent 70%);
    z-index: 0;
    pointer-events: none;
}
[data-bs-theme="dark"] .zwa-hero::before {
    background:
        radial-gradient(60% 60% at 50% 0%, rgb(34 197 94 / 18%), transparent 70%),
        radial-gradient(40% 50% at 80% 40%, rgb(14 165 233 / 14%), transparent 70%);
}

.zwa-hero__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: 3.5rem;
    align-items: center;
}
@media (max-width: 991.98px) {
    .zwa-hero__grid { grid-template-columns: 1fr; gap: 2.5rem; text-align: center; }
}

.zwa-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .35rem .75rem .35rem .4rem;
    background: var(--zwa-primary-soft);
    color: var(--zwa-primary);
    border: 1px solid color-mix(in srgb, var(--zwa-primary) 25%, transparent);
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 600;
}
.zwa-hero__badge .pulse {
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--zwa-primary);
    color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: .68rem;
    font-weight: 700;
}

.zwa-hero h1 {
    margin: 1.25rem 0 1.25rem;
}
.zwa-hero p.lead {
    color: var(--zwa-fg-muted);
    font-size: 1.125rem;
    line-height: 1.6;
    max-width: 32rem;
}
@media (max-width: 991.98px) {
    .zwa-hero p.lead { margin-left: auto; margin-right: auto; }
}

.zwa-hero__ctas {
    display: flex;
    gap: .75rem;
    margin-top: 1.75rem;
    flex-wrap: wrap;
}
@media (max-width: 991.98px) {
    .zwa-hero__ctas { justify-content: center; }
}

.zwa-hero__trust {
    margin-top: 2rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    color: var(--zwa-fg-subtle);
    font-size: .85rem;
}
.zwa-hero__trust .avatars { display: flex; }
.zwa-hero__trust .avatars span {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--zwa-brand-200);
    border: 2px solid var(--zwa-surface);
    margin-left: -8px;
}
.zwa-hero__trust .avatars span:first-child { margin-left: 0; }

.zwa-hero__visual {
    position: relative;
    border-radius: var(--zwa-radius-xl);
    background: linear-gradient(135deg, var(--zwa-brand-500), var(--zwa-brand-700));
    padding: 1rem;
    box-shadow: var(--zwa-shadow-lg);
}
.zwa-hero__visual img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--zwa-radius-lg);
    background: var(--zwa-surface);
}

.zwa-hero__chip {
    position: absolute;
    background: var(--zwa-surface);
    color: var(--zwa-fg);
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius);
    padding: .65rem .85rem;
    font-size: .85rem;
    font-weight: 600;
    box-shadow: var(--zwa-shadow-md);
    display: flex; align-items: center; gap: .5rem;
}
.zwa-hero__chip--top    { top: -16px; left: -16px; }
.zwa-hero__chip--bottom { bottom: -16px; right: -16px; }
.zwa-hero__chip .dot {
    width: 8px; height: 8px; border-radius: 50%; background: var(--zwa-primary);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--zwa-primary) 25%, transparent);
}


/* ─────────────────────────────────────────────────────────────────────
   7. STATS STRIP
   ───────────────────────────────────────────────────────────────────── */

.zwa-stats {
    border-top: 1px solid var(--zwa-border-soft);
    border-bottom: 1px solid var(--zwa-border-soft);
    background: var(--zwa-bg-subtle);
    padding: 2.25rem 0;
}
.zwa-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 2rem;
}
@media (max-width: 767.98px) { .zwa-stats__grid { grid-template-columns: repeat(2, 1fr); } }
.zwa-stats__item {
    display: flex; flex-direction: column; align-items: center;
    text-align: center;
}
.zwa-stats__num {
    font-size: clamp(1.5rem, 2vw + 1rem, 2.5rem);
    font-weight: 800;
    color: var(--zwa-fg);
    letter-spacing: -0.02em;
    line-height: 1;
}
.zwa-stats__lbl {
    margin-top: .5rem;
    font-size: .82rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: .08em;
    color: var(--zwa-fg-subtle);
}


/* ─────────────────────────────────────────────────────────────────────
   8. SECTION SHELL
   ───────────────────────────────────────────────────────────────────── */

.zwa-section { padding: 5.5rem 0; background: var(--zwa-bg); }
.zwa-section--alt { background: var(--zwa-bg-subtle); }
.zwa-section__head { text-align: center; max-width: 720px; margin: 0 auto 3rem; }
.zwa-section__head h2 { margin: .9rem 0 .75rem; }
.zwa-section__head p { color: var(--zwa-fg-muted); font-size: 1.05rem; line-height: 1.6; }


/* ─────────────────────────────────────────────────────────────────────
   9. FEATURE CARDS
   ───────────────────────────────────────────────────────────────────── */

.zwa-features {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 1.25rem;
}
@media (max-width: 991.98px) { .zwa-features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .zwa-features { grid-template-columns: 1fr; } }

.zwa-feature {
    background: var(--zwa-surface);
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius-md);
    padding: 1.75rem;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    position: relative;
    overflow: hidden;
}
.zwa-feature:hover {
    transform: translateY(-3px);
    box-shadow: var(--zwa-shadow-md);
    border-color: color-mix(in srgb, var(--zwa-primary) 30%, var(--zwa-border));
}
.zwa-feature__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px;
    border-radius: 12px;
    background: var(--zwa-primary-soft);
    color: var(--zwa-primary);
    margin-bottom: 1.25rem;
}
.zwa-feature__icon svg { width: 24px; height: 24px; }
.zwa-feature__num {
    position: absolute;
    top: 1rem; right: 1.25rem;
    font-size: .75rem; font-weight: 700;
    color: var(--zwa-fg-subtle);
    letter-spacing: .08em;
}
.zwa-feature h3 {
    font-size: 1.125rem;
    font-weight: 700;
    margin: 0 0 .5rem;
}
.zwa-feature p {
    font-size: .9rem;
    line-height: 1.55;
    color: var(--zwa-fg-muted);
    margin: 0;
}


/* ─────────────────────────────────────────────────────────────────────
   10. PRICING
   ───────────────────────────────────────────────────────────────────── */

.zwa-pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 1.5rem;
    align-items: stretch;
}
@media (max-width: 991.98px) { .zwa-pricing-grid { grid-template-columns: 1fr; max-width: 540px; margin: 0 auto; } }

.zwa-plan {
    background: var(--zwa-surface);
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius-lg);
    padding: 2rem 1.75rem;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: border-color .2s, box-shadow .2s, transform .2s;
}
.zwa-plan:hover { border-color: color-mix(in srgb, var(--zwa-primary) 35%, var(--zwa-border)); box-shadow: var(--zwa-shadow); }

.zwa-plan--popular {
    border-color: var(--zwa-primary);
    box-shadow: 0 25px 45px -15px rgb(22 163 74 / 25%);
    transform: translateY(-6px);
}
.zwa-plan--popular::before {
    content: "MOST POPULAR";
    position: absolute;
    top: 0; left: 50%;
    transform: translate(-50%, -50%);
    background: var(--zwa-primary);
    color: #fff;
    padding: .3rem .85rem;
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .12em;
}

.zwa-plan__name {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--zwa-fg);
    margin: 0 0 .25rem;
}
.zwa-plan__desc {
    font-size: .85rem;
    color: var(--zwa-fg-subtle);
    margin: 0 0 1.25rem;
}
.zwa-plan__price {
    display: flex;
    align-items: baseline;
    gap: .35rem;
    margin-bottom: .25rem;
}
.zwa-plan__price .currency {
    font-size: 1rem;
    color: var(--zwa-fg-subtle);
    font-weight: 600;
}
.zwa-plan__price .amount {
    font-size: 2.75rem;
    font-weight: 800;
    color: var(--zwa-fg);
    letter-spacing: -0.03em;
    line-height: 1;
}
.zwa-plan__price .period {
    font-size: .9rem;
    color: var(--zwa-fg-subtle);
}
.zwa-plan__divider {
    height: 1px;
    background: var(--zwa-border);
    margin: 1.25rem 0;
}
.zwa-plan__features {
    list-style: none;
    margin: 0 0 1.5rem;
    padding: 0;
    display: grid;
    gap: .65rem;
    flex: 1;
}
.zwa-plan__features li {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    font-size: .9rem;
    color: var(--zwa-fg);
}
.zwa-plan__features li .ico {
    width: 18px; height: 18px;
    flex-shrink: 0;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 1px;
}
.zwa-plan__features li.is-included .ico { background: var(--zwa-primary-soft); color: var(--zwa-primary); }
.zwa-plan__features li.is-excluded   { color: var(--zwa-fg-subtle); text-decoration: line-through; text-decoration-color: var(--zwa-border); }
.zwa-plan__features li.is-excluded .ico { background: var(--zwa-bg-muted); color: var(--zwa-fg-subtle); }


/* ─────────────────────────────────────────────────────────────────────
   11. CTA BANNER
   ───────────────────────────────────────────────────────────────────── */

.zwa-cta-banner {
    position: relative;
    border-radius: var(--zwa-radius-xl);
    background: linear-gradient(135deg, #0f172a 0%, #075E54 60%, #075E54 100%);
    color: #fff;
    overflow: hidden;
    padding: 3.5rem 3rem;
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 2rem;
    align-items: center;
    box-shadow: 0 30px 60px -20px rgb(22 163 74 / 35%);
}
.zwa-cta-banner::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(40% 60% at 90% 50%, rgb(34 197 94 / 35%), transparent 70%),
        radial-gradient(50% 50% at 0% 0%, rgb(14 165 233 / 25%), transparent 70%);
    pointer-events: none;
}
.zwa-cta-banner > * { position: relative; z-index: 1; }
.zwa-cta-banner h2 { color: #fff; margin-bottom: .75rem; }
.zwa-cta-banner p  { color: rgb(255 255 255 / 80%); margin-bottom: 1.5rem; max-width: 32rem; }
.zwa-cta-banner__visual img { width: 100%; max-width: 480px; margin-left: auto; display: block; border-radius: var(--zwa-radius); box-shadow: 0 25px 50px -10px rgb(0 0 0 / 35%); }

@media (max-width: 767.98px) {
    .zwa-cta-banner { grid-template-columns: 1fr; padding: 2.5rem 1.75rem; text-align: center; }
    .zwa-cta-banner__visual { display: none; }
}


/* ─────────────────────────────────────────────────────────────────────
   12. CONTACT
   ───────────────────────────────────────────────────────────────────── */

.zwa-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 2rem;
    align-items: stretch;
}
@media (max-width: 991.98px) { .zwa-contact-grid { grid-template-columns: 1fr; } }

.zwa-contact-card,
.zwa-contact-form {
    background: var(--zwa-surface);
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius-lg);
    padding: 2rem;
}
.zwa-contact-card h3 { font-size: 1.05rem; font-weight: 700; margin: 0 0 .35rem; }
.zwa-contact-card p  { font-size: .9rem; color: var(--zwa-fg-muted); margin: 0 0 1.5rem; }
.zwa-contact-list { display: grid; gap: 1.1rem; list-style: none; padding: 0; margin: 0; }
.zwa-contact-list li { display: flex; gap: .9rem; align-items: flex-start; }
.zwa-contact-list .ico {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: var(--zwa-primary-soft);
    color: var(--zwa-primary);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.zwa-contact-list .ico svg { width: 18px; height: 18px; }
.zwa-contact-list strong { display: block; font-size: .78rem; font-weight: 600; color: var(--zwa-fg-subtle); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .15rem; }
.zwa-contact-list span,
.zwa-contact-list a { color: var(--zwa-fg); font-weight: 600; text-decoration: none; font-size: .95rem; }
.zwa-contact-list a:hover { color: var(--zwa-primary); }

.zwa-input {
    width: 100%;
    padding: .8rem 1rem;
    background: var(--zwa-bg);
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius);
    color: var(--zwa-fg);
    font-size: .95rem;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
}
.zwa-input::placeholder { color: var(--zwa-fg-subtle); }
.zwa-input:focus {
    outline: none;
    border-color: var(--zwa-primary);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--zwa-primary) 18%, transparent);
}
.zwa-label { font-size: .82rem; font-weight: 600; color: var(--zwa-fg); margin-bottom: .4rem; display: block; }


/* ─────────────────────────────────────────────────────────────────────
   13. FAQ
   ───────────────────────────────────────────────────────────────────── */

.zwa-faq {
    max-width: 760px; margin: 0 auto;
    display: grid; gap: .75rem;
}
.zwa-faq__item {
    border: 1px solid var(--zwa-border);
    border-radius: var(--zwa-radius-md);
    background: var(--zwa-surface);
    overflow: hidden;
}
.zwa-faq__q {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.15rem 1.25rem;
    cursor: pointer;
    font-weight: 600;
    font-size: 1rem;
    color: var(--zwa-fg);
    list-style: none;
}
.zwa-faq__q::-webkit-details-marker { display: none; }
.zwa-faq__q::after {
    content: "+";
    font-size: 1.4rem;
    color: var(--zwa-fg-subtle);
    transition: transform .2s;
    line-height: 1;
}
.zwa-faq__item[open] .zwa-faq__q::after { content: "−"; color: var(--zwa-primary); }
.zwa-faq__a {
    padding: 0 1.25rem 1.25rem;
    color: var(--zwa-fg-muted);
    line-height: 1.6;
    font-size: .94rem;
}


/* ─────────────────────────────────────────────────────────────────────
   14. SOCIAL PROOF / LOGO STRIP
   ───────────────────────────────────────────────────────────────────── */

.zwa-logo-strip {
    padding: 2rem 0;
    border-top: 1px solid var(--zwa-border-soft);
    border-bottom: 1px solid var(--zwa-border-soft);
    background: var(--zwa-bg);
}
.zwa-logo-strip__title {
    text-align: center;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--zwa-fg-subtle);
    margin-bottom: 1.5rem;
}
.zwa-logo-strip__items {
    display: flex; flex-wrap: wrap;
    align-items: center; justify-content: center;
    gap: 2.5rem;
    opacity: .65;
    filter: grayscale(100%);
}
.zwa-logo-strip__items span { font-weight: 800; font-size: 1.05rem; color: var(--zwa-fg-muted); }


/* ─────────────────────────────────────────────────────────────────────
   15. FOOTER
   ───────────────────────────────────────────────────────────────────── */

.zwa-footer {
    background: var(--zwa-bg-subtle);
    color: var(--zwa-fg-muted);
    border-top: 1px solid var(--zwa-border);
    padding: 3.5rem 0 1.5rem;
}
.zwa-footer__grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 2rem;
    margin-bottom: 2.5rem;
}
@media (max-width: 767.98px) {
    .zwa-footer__grid { grid-template-columns: 1fr 1fr; }
    .zwa-footer__brand { grid-column: 1 / -1; }
}

.zwa-footer__brand p { margin: 1rem 0 1.25rem; max-width: 22rem; font-size: .9rem; line-height: 1.6; }
.zwa-footer h6 {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 700;
    color: var(--zwa-fg);
    margin-bottom: 1rem;
}
.zwa-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.zwa-footer ul a { color: var(--zwa-fg-muted); font-size: .9rem; text-decoration: none; transition: color .15s; }
.zwa-footer ul a:hover { color: var(--zwa-primary); }

.zwa-footer__bottom {
    border-top: 1px solid var(--zwa-border);
    padding-top: 1.5rem;
    display: flex; flex-wrap: wrap;
    align-items: center; justify-content: space-between;
    gap: 1rem;
    font-size: .85rem;
}
.zwa-footer__social { display: flex; gap: .35rem; }
.zwa-footer__social a {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--zwa-fg-muted);
    border: 1px solid var(--zwa-border);
    background: var(--zwa-surface);
    transition: color .15s, background .15s, border-color .15s;
}
.zwa-footer__social a:hover {
    color: var(--zwa-primary);
    border-color: color-mix(in srgb, var(--zwa-primary) 50%, var(--zwa-border));
    background: var(--zwa-primary-soft);
}


/* ─────────────────────────────────────────────────────────────────────
   16. ANNOUNCEMENT BAR
   ───────────────────────────────────────────────────────────────────── */
.zwa-announce {
    background: linear-gradient(90deg, var(--zwa-brand-700), var(--zwa-brand-500));
    color: #fff;
    text-align: center;
    padding: .55rem 1rem;
    font-size: .85rem;
    font-weight: 500;
}
.zwa-announce a { color: #fff; text-decoration: underline; font-weight: 600; margin-left: .25rem; }


/* ─────────────────────────────────────────────────────────────────────
   17. UTILITIES
   ───────────────────────────────────────────────────────────────────── */

.zwa-container { max-width: 1200px; margin-inline: auto; padding-inline: clamp(1rem, 3vw, 1.75rem); }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
