/*
Theme Name: Azterion 2026
Description: Azterion 2026 — Child theme for Hello Elementor. Full design system with interactive animations.
Author: Azterion
Template: hello-elementor
Version: 1.0.0
Text Domain: azterion-2026
*/

/* ==========================================================
   AZTERION 2026 — DESIGN SYSTEM
   Accent: #ffcc00 | Font: Inter | Base: Hello Elementor
   ========================================================== */

/* --- 1. TOKENS ------------------------------------------- */
:root {
    --az-black:        #0a0a0a;
    --az-white:        #ffffff;
    --az-yellow:       #ffcc00;
    --az-yellow-10:    rgba(255,204,0,0.10);
    --az-yellow-20:    rgba(255,204,0,0.20);

    --az-gray-50:      #f8f8f8;
    --az-gray-100:     #f2f2f2;
    --az-gray-200:     #e5e5e5;
    --az-gray-300:     #d4d4d4;
    --az-gray-400:     #a3a3a3;
    --az-gray-500:     #737373;
    --az-gray-600:     #525252;
    --az-gray-700:     #404040;
    --az-gray-900:     #171717;

    --az-font:         'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    --az-section-y:    112px;
    --az-container:    1200px;
    --az-gap:          32px;

    --az-radius-sm:    6px;
    --az-radius-md:    12px;
    --az-radius-lg:    20px;
    --az-radius-xl:    32px;
    --az-radius-pill:  999px;

    --az-shadow-sm:    0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
    --az-shadow-md:    0 4px 16px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
    --az-shadow-lg:    0 16px 48px rgba(0,0,0,0.10), 0 4px 16px rgba(0,0,0,0.06);

    --az-ease-out:     cubic-bezier(0.16, 1, 0.3, 1);
    --az-transition:   0.18s ease;
}

/* --- 2. GLOBAL BASE -------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html, body { overflow-x: hidden; } /* prevent horizontal scroll site-wide */

body {
    font-family: var(--az-font);
    font-size: 17px;
    line-height: 1.65;
    color: var(--az-gray-900);
    background: var(--az-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0;
    padding: 0;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4 { margin: 0; line-height: 1.15; letter-spacing: -0.02em; }
p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

/* Elementor resets */
.elementor-page, .elementor-section-wrap { background: transparent; }

/* --- 3. LAYOUT ------------------------------------------- */
.az-container {
    max-width: var(--az-container);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--az-gap);
    padding-right: var(--az-gap);
}

.az-section {
    padding-top: var(--az-section-y);
    padding-bottom: var(--az-section-y);
    background: var(--az-white);
}

.az-section--gray    { background: var(--az-white); }
.az-section--dark    { background: var(--az-black); }

/* ── CTA Card (Antigravity-style) ───────────────────────── */
.az-cta-wrap {
    background: var(--az-white);
    padding: var(--az-section-y) var(--az-gap);
}
.az-cta-wrap .az-container {
    max-width: 1000px;
}
.az-cta-card {
    background: var(--az-black);
    border-radius: 28px;
    padding: 80px 64px;
    position: relative;
    overflow: hidden;
}
.az-cta-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 50% at 20% 50%, rgba(255,204,0,0.07) 0%, transparent 70%),
        radial-gradient(ellipse 50% 60% at 80% 30%, rgba(255,255,255,0.03) 0%, transparent 60%);
    pointer-events: none;
}

/* Scroll-reveal animation for the card */
.az-card-reveal {
    opacity: 0;
    transform: translateY(48px) scale(0.98);
    transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}
.az-card-reveal.az-is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

@media (max-width: 768px) {
    .az-cta-card { padding: 48px 28px; border-radius: 20px; }
    .az-cta-wrap .az-container { padding-left: 12px; padding-right: 12px; }
}

.az-section__header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 72px;
}

/* --- 4. TYPOGRAPHY --------------------------------------- */
.az-h1 {
    font-size: clamp(40px, 6vw, 72px);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.05;
    color: var(--az-black);
}

.az-h2 {
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 700;
    letter-spacing: -0.025em;
    color: var(--az-black);
}

.az-h2--light { color: var(--az-white); }

.az-h3 {
    font-size: clamp(18px, 2.5vw, 22px);
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--az-black);
}

.az-eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--az-gray-500);
    margin-bottom: 14px;
}

.az-lead {
    font-size: 19px;
    line-height: 1.65;
    color: var(--az-gray-700);
}

/* Elementor typography integration */
.az-section .elementor-heading-title {
    font-family: var(--az-font) !important;
    letter-spacing: -0.025em !important;
}

/* --- 5. BUTTONS ------------------------------------------ */
.az-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    border-radius: var(--az-radius-pill);
    font-family: var(--az-font);
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    border: none;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    white-space: nowrap;
}

.az-btn:hover { transform: translateY(-2px); }
.az-btn:active { transform: translateY(0); }

.az-btn--primary {
    background: var(--az-black);
    color: var(--az-white);
    box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.az-btn--primary:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.22); color: var(--az-white); }

.az-btn--outline {
    background: transparent;
    color: var(--az-black);
    border: 1.5px solid var(--az-gray-300);
}
.az-btn--outline:hover { border-color: var(--az-black); }

.az-btn--yellow {
    background: var(--az-yellow);
    color: var(--az-black);
    font-weight: 600;
    box-shadow: 0 2px 12px rgba(255,204,0,0.35);
}
.az-btn--yellow:hover { background: #f5c400; box-shadow: 0 6px 20px rgba(255,204,0,0.4); color: var(--az-black); }

.az-btn--ghost {
    background: transparent;
    color: rgba(255,255,255,0.75);
    border: 1.5px solid rgba(255,255,255,0.2);
}
.az-btn--ghost:hover { color: var(--az-white); border-color: rgba(255,255,255,0.5); }

/* --- 6. NAVIGATION --------------------------------------- */
.az-nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 9999;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid transparent;
    transition: border-color 0.35s ease, box-shadow 0.35s ease;
}

.az-nav.is-scrolled {
    border-bottom-color: var(--az-gray-200);
    box-shadow: 0 1px 16px rgba(0,0,0,0.07);
}

.az-nav__inner {
    max-width: var(--az-container);
    margin: 0 auto;
    padding: 0 var(--az-gap);
    height: 68px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.az-nav__logo {
    display: flex;
    align-items: center;
    margin-right: auto;
    flex-shrink: 0;
}
.az-nav__logo img { height: 32px; width: auto; }

.az-nav__links {
    display: flex;
    align-items: center;
    gap: 4px;
}

.az-nav__links ul {
    display: flex;
    align-items: center;
    gap: 2px;
    list-style: none; margin: 0; padding: 0;
}

.az-nav__links ul li a {
    padding: 8px 14px;
    font-size: 14px;
    font-weight: 450;
    color: var(--az-gray-600);
    border-radius: var(--az-radius-sm);
    transition: color 0.15s ease, background 0.15s ease;
    text-decoration: none;
    display: block;
}

.az-nav__links ul li a:hover {
    color: var(--az-black);
    background: var(--az-gray-100);
}

/* Dropdown */
.az-nav__links ul li.menu-item-has-children { position: relative; }
.az-nav__links ul li.menu-item-has-children > a::after {
    content: '';
    display: inline-block;
    width: 8px;
    height: 5px;
    margin-left: 5px;
    background: currentColor;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    opacity: 0.45;
    vertical-align: middle;
    transition: transform 0.15s ease;
}
.az-nav__links ul li.menu-item-has-children:hover > a::after { transform: rotate(180deg); }
.az-nav__links ul li.menu-item-has-children > ul.sub-menu {
    position: absolute;
    top: 100%;           /* flush to parent — no gap that breaks hover */
    left: 0;
    min-width: 210px;
    background: var(--az-white);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-md);
    padding: 12px 6px 6px; /* top padding creates visual gap without hover gap */
    box-shadow: var(--az-shadow-lg);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-4px);
    /* Small delay only when HIDING so mouse has time to travel to submenu */
    transition: opacity 0.12s ease 0.08s, transform 0.12s ease 0.08s;
}
.az-nav__links ul li.menu-item-has-children:hover > ul.sub-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    transition: opacity 0.1s ease, transform 0.1s ease; /* show instantly */
}

.az-nav__cta-btn {
    display: inline-flex;
    align-items: center;
    padding: 10px 22px;
    background: var(--az-black);
    color: var(--az-white) !important;
    border-radius: var(--az-radius-pill);
    font-size: 14px;
    font-weight: 500;
    margin-left: 8px;
    flex-shrink: 0;
    transition: background 0.18s ease, transform 0.18s ease;
}
.az-nav__cta-btn:hover { background: var(--az-gray-700); transform: translateY(-1px); color: var(--az-white) !important; }

.az-nav__burger {
    display: none;
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    cursor: pointer;
    padding: 8px;
    color: var(--az-black) !important;
    margin-left: auto;
    border-radius: 0 !important;
    outline: none;
}
.az-nav__burger:hover,
.az-nav__burger:focus,
.az-nav__burger:active {
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: var(--az-black) !important;
}

/* --- 7. HERO --------------------------------------------- */
.az-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--az-white);
    padding-top: 68px;
}

#az-particles-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
}

.az-hero__inner {
    position: relative;
    z-index: 1;
    max-width: var(--az-container);
    margin: 0 auto;
    padding: 80px var(--az-gap);
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.az-hero__content { max-width: 820px; width: 100%; text-align: center; }

.az-hero__ctas {
    justify-content: center;
}

.az-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 16px;
    background: var(--az-gray-100);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-pill);
    font-size: 13px;
    font-weight: 500;
    color: var(--az-gray-600);
    margin-bottom: 32px;
}

.az-hero__badge::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--az-yellow);
    flex-shrink: 0;
}

.az-hero__title {
    font-size: clamp(42px, 7vw, 80px);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.02;
    color: var(--az-black);
    margin-bottom: 28px;
}

/* Word-split animation — injected by JS */
.az-word-wrap { overflow: hidden; display: inline-block; }
.az-word-wrap + .az-word-wrap { margin-left: 0.22em; }
.az-word { display: inline-block; }

.az-hero__subtitle {
    font-size: clamp(17px, 2vw, 21px);
    line-height: 1.6;
    color: var(--az-gray-600);
    margin: 0 auto 20px;
    max-width: 600px;
    font-weight: 400;
}

.az-hero__trust {
    font-size: 13px;
    color: var(--az-gray-400);
    margin: 0 auto 36px;
    max-width: 520px;
    line-height: 1.5;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.az-hero__trust::before {
    content: '';
    display: inline-block;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--az-yellow);
    flex-shrink: 0;
}

.az-hero__ctas {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

.az-hero__scroll {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    color: var(--az-gray-400);
    z-index: 1;
    animation: az-bob 2.2s ease infinite;
}

@keyframes az-bob {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(7px); }
}

/* --- 8. SCROLL REVEAL SYSTEM ----------------------------- */
/* Applied by JS — class .az-reveal */
.az-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.65s var(--az-ease-out), transform 0.65s var(--az-ease-out);
}
.az-reveal.az-is-visible {
    opacity: 1;
    transform: translateY(0);
}
/* Stagger delays for reveal groups */
.az-reveal-group .az-reveal:nth-child(1) { transition-delay: 0ms; }
.az-reveal-group .az-reveal:nth-child(2) { transition-delay: 80ms; }
.az-reveal-group .az-reveal:nth-child(3) { transition-delay: 160ms; }
.az-reveal-group .az-reveal:nth-child(4) { transition-delay: 240ms; }
.az-reveal-group .az-reveal:nth-child(5) { transition-delay: 320ms; }
.az-reveal-group .az-reveal:nth-child(6) { transition-delay: 400ms; }

/* --- 9. SECTION / CARD COMPONENTS ----------------------- */
.az-section-header { text-align: center; margin-bottom: 72px; }
.az-section-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--az-gray-500);
    margin-bottom: 12px;
}

/* Cards (service, problem, approach) */
.az-card {
    background: var(--az-white);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-lg);
    padding: 28px 32px;
    transition: border-color 0.2s ease, box-shadow 0.25s ease, transform 0.25s var(--az-ease-out);
}
.az-card:hover {
    border-color: var(--az-gray-300);
    box-shadow: var(--az-shadow-md);
    transform: translateY(-3px);
}

.az-card__icon {
    width: 48px; height: 48px;
    background: var(--az-gray-100);
    border-radius: var(--az-radius-sm);
    display: flex; align-items: center; justify-content: center;
    color: var(--az-black);
    margin-bottom: 20px;
    transition: background 0.2s ease;
}
.az-card:hover .az-card__icon { background: var(--az-yellow-20); }

.az-card__title {
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--az-black);
    margin-bottom: 10px;
}

.az-card__desc {
    font-size: 14px;
    line-height: 1.7;
    color: var(--az-gray-500);
    margin: 0;
}

.az-card__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--az-black);
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--az-gray-100);
    transition: gap 0.18s ease, color 0.18s ease;
}
.az-card__link:hover { gap: 10px; color: var(--az-gray-600); }

/* Problem pills */
.az-pill {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: var(--az-white);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-md);
    font-size: 14px;
    font-weight: 500;
    color: var(--az-gray-700);
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.2s var(--az-ease-out);
}
.az-pill:hover {
    border-color: var(--az-gray-300);
    box-shadow: var(--az-shadow-sm);
    transform: translateY(-2px);
}
.az-pill svg { flex-shrink: 0; color: var(--az-gray-400); }

/* Process steps */
.az-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    position: relative;
}
.az-steps::before {
    content: '';
    position: absolute;
    top: 26px;
    left: 12%;
    right: 12%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--az-gray-200) 15%, var(--az-gray-200) 85%, transparent);
    z-index: 0;
}
.az-step {
    position: relative;
    z-index: 1;
    text-align: center;
}
.az-step__num {
    width: 52px; height: 52px;
    background: var(--az-yellow);
    color: var(--az-black);
    font-size: 17px;
    font-weight: 800;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    box-shadow: 0 0 0 4px var(--az-white), 0 0 0 5px var(--az-gray-200);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.az-step:hover .az-step__num {
    box-shadow: 0 0 0 4px var(--az-white), 0 0 0 5px var(--az-yellow), 0 6px 20px rgba(255,204,0,0.3);
    transform: scale(1.05);
}
.az-step__title { font-size: 16px; font-weight: 600; color: var(--az-black); margin-bottom: 8px; }
.az-step__desc { font-size: 13px; color: var(--az-gray-500); line-height: 1.6; }

/* Logo trust strip */
.az-logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 0 0 8px;
}
.az-logo-pill {
    padding: 12px 28px;
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-sm);
    font-size: 13px;
    font-weight: 700;
    color: var(--az-gray-500);
    letter-spacing: 0.04em;
    transition: border-color 0.18s ease, color 0.18s ease, background 0.18s ease, transform 0.18s ease;
    cursor: default;
    background: var(--az-white);
}
.az-logo-pill:hover {
    border-color: var(--az-gray-300);
    color: var(--az-black);
    background: var(--az-gray-50);
    transform: translateY(-2px);
}

/* --- Trust bar ------------------------------------------- */
.az-trust-bar {
    border-top: 1px solid var(--az-gray-100);
    border-bottom: 1px solid var(--az-gray-100);
    padding: 16px 0;
    background: var(--az-white);
}
.az-trust-bar__inner {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 24px;
    justify-content: center;
}
.az-trust-bar__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--az-gray-300);
    flex-shrink: 0;
    padding-right: 8px;
}
.az-trust-bar__name {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--az-gray-400);
    padding: 4px 14px;
    border: 1px solid var(--az-gray-150, #ebebeb);
    border-radius: 4px;
    background: var(--az-white);
    transition: color 0.15s, border-color 0.15s;
}
.az-trust-bar__name:hover { color: var(--az-gray-600); border-color: var(--az-gray-300); }

/* --- What we actually build grid ------------------------- */
.az-build-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    max-width: 960px;
    margin: 0 auto;
}
.az-build-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 22px 24px;
    background: var(--az-white);
    border: 1px solid var(--az-gray-150, #ebebeb);
    border-radius: var(--az-radius);
    transition: border-color 0.18s, box-shadow 0.18s;
}
.az-build-card:hover {
    border-color: var(--az-gray-300);
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.az-build-card__icon {
    flex-shrink: 0;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: var(--az-gray-50);
    border-radius: 8px;
    color: var(--az-black);
}
.az-build-card__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--az-black);
    margin-bottom: 4px;
    line-height: 1.3;
}
.az-build-card__desc {
    font-size: 13px;
    color: var(--az-gray-500);
    line-height: 1.6;
    margin: 0;
}

/* --- 10. FOOTER ILLUSTRATION ----------------------------- */
.az-footer-illustration {
    position: relative;
    background: var(--az-white);
    overflow: visible;
    margin: 0;
    padding: 0;
    line-height: 0;
    font-size: 0;
    display: block;
    vertical-align: bottom;
}
.az-footer-illustration::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 6px;
    background: #000000;
    z-index: 2;
    display: block;
}

.az-footer-banner-img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    position: relative;  /* sit above the particle canvas */
    z-index: 1;
    vertical-align: bottom;
    margin: 0;
    padding: 0;
}

/* --- 11. FOOTER ------------------------------------------ */
.az-footer {
    background: #000000;
    color: rgba(255,255,255,0.6);
    font-size: 14px;
    padding-top: 0;
    margin-top: 0;
}

.az-footer__body {
    max-width: var(--az-container);
    margin: 0 auto;
    padding: 72px var(--az-gap) 56px;
    display: grid;
    grid-template-columns: 1.5fr 2fr;
    gap: 80px;
}

.az-footer__brand img { height: 36px; width: auto; margin-bottom: 20px; }
.az-footer__brand p {
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255,255,255,0.4);
    max-width: 280px;
    margin-bottom: 16px;
}
.az-footer__tagline {
    font-size: 10px;
    letter-spacing: 0.16em;
    font-weight: 600;
    color: rgba(255,255,255,0.2);
    text-transform: uppercase;
    margin-bottom: 20px;
}

.az-footer__social {
    display: flex;
    gap: 12px;
    align-items: center;
}
.az-footer__social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.4);
    transition: border-color 0.18s ease, color 0.18s ease, background 0.18s ease;
}
.az-footer__social a:hover {
    border-color: var(--az-yellow);
    color: var(--az-yellow);
    background: rgba(255,204,0,0.08);
}

/* Mobile arrow — only visible inside mobile menu */
.az-mobile-arrow { display: none; }

/* Language switcher */
.az-nav__lang {
    display: flex;
    align-items: center;
    background: var(--az-gray-100);
    border-radius: 8px;
    padding: 3px;
    gap: 2px;
    margin: 0 4px 0 8px;
}
.az-lang-btn {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--az-gray-400);
    padding: 4px 10px;
    border-radius: 6px;
    transition: color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
    line-height: 1;
}
.az-lang-btn:hover { color: var(--az-gray-700); }
.az-lang-btn.is-active {
    color: var(--az-black);
    background: var(--az-white);
    box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}

.az-footer__nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}
.az-footer__col h4 {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
    margin-bottom: 16px;
}
.az-footer__col ul { display: flex; flex-direction: column; gap: 10px; }
.az-footer__col ul li { font-size: 14px; color: rgba(255,255,255,0.5); }
.az-footer__col ul li a { color: rgba(255,255,255,0.5); transition: color 0.18s ease; }
.az-footer__col ul li a:hover { color: var(--az-white); }

.az-footer__bottom {
    border-top: 1px solid rgba(255,255,255,0.07);
    padding: 20px var(--az-gap);
    max-width: var(--az-container);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: rgba(255,255,255,0.25);
    flex-wrap: wrap;
    gap: 10px;
}
.az-footer__legal { display: flex; gap: 20px; }
.az-footer__legal a { color: rgba(255,255,255,0.25); transition: color 0.18s ease; }
.az-footer__legal a:hover { color: rgba(255,255,255,0.55); }

/* Elementor sections inside footer push area */
.az-footer .elementor-section { background: transparent; }

/* --- 12. SPLIT LAYOUT ------------------------------------ */
.az-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.az-split--flip > *:first-child { order: 2; }
.az-split--flip > *:last-child  { order: 1; }

.az-split__visual {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* --- 13. RESPONSIVE -------------------------------------- */
@media (max-width: 1024px) {
    :root { --az-section-y: 80px; }
    .az-split { grid-template-columns: 1fr; gap: 48px; }
    .az-split--flip > * { order: unset !important; }
    .az-steps { grid-template-columns: repeat(2, 1fr); }
    .az-steps::before { display: none; }
    .az-footer__body { grid-template-columns: 1fr; gap: 48px; }

    /* Home page inline grids */
    .az-services-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .az-problem-grid  { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 768px) {
    :root { --az-section-y: 64px; --az-gap: 20px; }

    .az-nav__links { display: none; }
    .az-nav__burger { display: flex; }

    /* Nav expands full screen — inner NEVER changes layout, zero flicker */
    .az-nav.menu-open {
        height: 100dvh;
        height: 100vh;
        background: #ffffff !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border-bottom: none;
        overflow: hidden;
    }
    /* Inner bar stays exactly the same — 68px, no flex changes */
    .az-nav.menu-open .az-nav__inner {
        height: 68px;
        flex-wrap: nowrap;
        overflow: hidden;
    }
    /* Hide desktop dropdown arrow in mobile menu */
    .az-nav.menu-open .az-nav__links ul li.menu-item-has-children > a::after {
        display: none !important;
    }
    /* Links panel: absolutely positioned BELOW the 68px bar */
    .az-nav.menu-open .az-nav__links {
        display: flex !important;
        flex-direction: column;
        position: absolute;
        top: 68px;
        left: 0;
        right: 0;
        bottom: 0;
        background: #ffffff;
        padding: 8px var(--az-gap) 32px;
        gap: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        z-index: 1;
    }
    .az-nav.menu-open .az-nav__links > ul {
        flex-direction: column;
        width: 100%;
    }
    .az-nav.menu-open .az-nav__links > ul > li {
        width: 100%;
        border-bottom: 1px solid var(--az-gray-100);
    }
    .az-nav.menu-open .az-nav__links > ul > li > a {
        font-size: 20px;
        padding: 16px 0;
        color: var(--az-black) !important;
        font-weight: 600;
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: none !important;
        border-radius: 0;
    }
    /* Mobile submenu — hidden by default, shown when parent has .az-sub-open */
    .az-nav.menu-open .az-nav__links ul li .sub-menu {
        position: static !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
        box-shadow: none !important;
        background: var(--az-gray-50, #fafafa);
        border-radius: 8px;
        margin: 0 0 8px 0;
        padding: 4px 16px;
        display: none;
        min-width: unset;
    }
    .az-nav.menu-open .az-nav__links ul li.az-sub-open > .sub-menu {
        display: block;
    }
    .az-nav.menu-open .az-nav__links ul li .sub-menu li {
        border: none;
    }
    .az-nav.menu-open .az-nav__links ul li .sub-menu li a {
        font-size: 16px !important;
        padding: 10px 0 !important;
        font-weight: 400 !important;
        color: var(--az-gray-600) !important;
        border-bottom: 1px solid var(--az-gray-100);
    }
    .az-nav.menu-open .az-nav__links ul li .sub-menu li:last-child a {
        border-bottom: none;
    }
    /* Arrow toggle for parent items */
    .az-mobile-arrow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border-radius: 6px;
        transition: transform 0.2s;
        flex-shrink: 0;
    }
    .az-sub-open > a > .az-mobile-arrow {
        transform: rotate(180deg);
    }
    .az-nav.menu-open .az-nav__lang {
        margin-top: 4px;
        padding-top: 4px;
        padding-bottom: 4px;
        border-top: 1px solid var(--az-gray-100);
    }
    .az-nav.menu-open .az-nav__cta-btn {
        display: block !important;
        text-align: center;
        margin-top: 16px;
        width: 100%;
    }

    .az-hero { min-height: 100svh; }
    .az-hero__title { font-size: clamp(34px, 10vw, 52px); }

    .az-steps { grid-template-columns: 1fr; }
    .az-footer__nav { grid-template-columns: repeat(2, 1fr); }
    .az-footer__brand p { max-width: 100%; }
    .az-footer__bottom { flex-direction: column; text-align: center; }

    /* Home page inline grids */
    .az-services-grid { grid-template-columns: 1fr !important; }
    .az-problem-grid  { grid-template-columns: 1fr !important; }
    .az-build-grid    { grid-template-columns: 1fr !important; }
}

@media (max-width: 480px) {
    .az-footer__nav { grid-template-columns: 1fr; }
    .az-hero__ctas { flex-direction: column; align-items: center; }
    .az-hero__ctas .az-btn { width: 100%; justify-content: center; }
}

/* --- 14. ELEMENTOR HELPERS ------------------------------- */
/* Use these CSS classes in Elementor > Advanced > CSS Class */

/* Sections */
.az-bg-white   { background: var(--az-white) !important; }
.az-bg-gray    { background: var(--az-gray-50) !important; }
.az-bg-dark    { background: var(--az-black) !important; }
.az-bg-dark .elementor-heading-title,
.az-bg-dark .elementor-widget-text-editor { color: var(--az-white) !important; }

/* Section padding helpers */
.az-pad-section {
    padding-top: var(--az-section-y) !important;
    padding-bottom: var(--az-section-y) !important;
}

/* Containers */
.az-max-content {
    max-width: var(--az-container) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Heading styles */
.az-title-xl .elementor-heading-title {
    font-size: clamp(42px, 7vw, 80px) !important;
    font-weight: 800 !important;
    letter-spacing: -0.04em !important;
    line-height: 1.02 !important;
}
.az-title-lg .elementor-heading-title {
    font-size: clamp(28px, 4vw, 48px) !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
}

/* Badge / eyebrow */
.az-badge-pill .elementor-heading-title {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 16px !important;
    background: var(--az-gray-100) !important;
    border: 1px solid var(--az-gray-200) !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--az-gray-600) !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}
.az-eyebrow-label .elementor-heading-title {
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: var(--az-gray-500) !important;
}

/* Card hover effects for Elementor columns */
.az-hover-card .elementor-widget-wrap {
    background: var(--az-white);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-lg);
    padding: 28px 32px !important;
    transition: border-color 0.2s ease, box-shadow 0.25s ease, transform 0.25s var(--az-ease-out);
}
.az-hover-card:hover .elementor-widget-wrap {
    border-color: var(--az-gray-300);
    box-shadow: var(--az-shadow-md);
    transform: translateY(-3px);
}

/* Yellow icon bg */
.az-icon-yellow .eicon, .az-icon-yellow .elementor-icon i {
    background: var(--az-yellow-20);
    border-radius: var(--az-radius-sm);
    padding: 10px;
}

/* Buttons */
.az-btn-primary a {
    background: var(--az-black) !important;
    color: var(--az-white) !important;
    border-radius: 999px !important;
    padding: 14px 28px !important;
    font-weight: 500 !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease !important;
}
.az-btn-primary a:hover { transform: translateY(-2px) !important; box-shadow: 0 6px 24px rgba(0,0,0,0.22) !important; }

.az-btn-yellow a {
    background: var(--az-yellow) !important;
    color: var(--az-black) !important;
    border-radius: 999px !important;
    padding: 14px 28px !important;
    font-weight: 600 !important;
}
.az-btn-yellow a:hover { transform: translateY(-2px) !important; }

/* Scroll reveal — add .az-reveal to any Elementor element */
/* JS handles adding .az-is-visible when in viewport */

/* --- 15. WP ADMIN BAR FIX -------------------------------- */
.admin-bar .az-nav { top: 32px; }
@media (max-width: 782px) {
    .admin-bar .az-nav { top: 46px; }
}

/* --- 16. SERVICE LANDING TEMPLATE ------------------------ */

/* Hero */
.az-svc-hero {
    padding: 100px var(--az-gap) 72px;
    text-align: center;
    background: var(--az-white);
}
.az-svc-hero__title {
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.025em;
    color: var(--az-black);
    margin: 0 0 24px;
}
.az-svc-hero__sub {
    font-size: clamp(17px, 2vw, 21px);
    line-height: 1.65;
    color: var(--az-gray-600);
    margin: 0 auto;
    max-width: 640px;
    font-weight: 400;
}

/* Breadcrumb */
.az-breadcrumb {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--az-gray-400);
    margin-bottom: 24px;
}
.az-breadcrumb a {
    color: var(--az-gray-400);
    text-decoration: none;
    transition: color 0.15s;
}
.az-breadcrumb a:hover { color: var(--az-black); }

/* Benefit cards */
.az-benefit-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 24px;
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-lg);
    background: var(--az-white);
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s var(--az-ease-out);
}
.az-benefit-card:hover {
    border-color: var(--az-gray-300);
    box-shadow: var(--az-shadow-sm);
    transform: translateY(-2px);
}
.az-benefit-card__icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--az-yellow-20);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--az-black);
}
.az-benefit-card__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--az-black);
    margin-bottom: 4px;
}
.az-benefit-card__desc {
    font-size: 14px;
    line-height: 1.6;
    color: var(--az-gray-500);
    margin: 0;
}

/* What-we-build / scope cards */
.az-card {
    padding: 28px 24px;
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-xl);
    background: var(--az-white);
    transition: border-color 0.2s, box-shadow 0.25s, transform 0.25s var(--az-ease-out);
}
.az-card:hover {
    border-color: var(--az-gray-300);
    box-shadow: var(--az-shadow-md);
    transform: translateY(-3px);
}
.az-card__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--az-radius-sm);
    background: var(--az-yellow-20);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--az-black);
}
.az-card__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--az-black);
    margin: 0;
}
.az-card__desc {
    font-size: 14px;
    line-height: 1.65;
    color: var(--az-gray-500);
    margin: 0;
}

/* Process steps */
.az-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    position: relative;
}
.az-steps::before {
    content: '';
    position: absolute;
    top: 28px;
    left: calc(12.5% + 20px);
    right: calc(12.5% + 20px);
    height: 1px;
    background: var(--az-gray-200);
    z-index: 0;
}
.az-step {
    text-align: center;
    padding: 0 16px;
    position: relative;
    z-index: 1;
}
.az-step__num {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--az-white);
    border: 2px solid var(--az-gray-200);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 800;
    color: var(--az-black);
    margin: 0 auto 20px;
    transition: background 0.2s, border-color 0.2s;
}
.az-step:hover .az-step__num {
    background: var(--az-yellow);
    border-color: var(--az-yellow);
}
.az-step__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--az-black);
    margin-bottom: 8px;
}
.az-step__desc {
    font-size: 13px;
    line-height: 1.65;
    color: var(--az-gray-500);
    margin: 0;
}

/* FAQ accordion */
.az-faq {
    border-bottom: 1px solid var(--az-gray-200);
}
.az-faq:first-of-type { border-top: 1px solid var(--az-gray-200); }
.az-faq__q {
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--az-black);
    cursor: pointer;
    gap: 16px;
    transition: color 0.15s;
}
.az-faq__q::-webkit-details-marker { display: none; }
.az-faq__q::after {
    content: '+';
    font-size: 22px;
    font-weight: 300;
    color: var(--az-gray-400);
    flex-shrink: 0;
    transition: transform 0.2s ease;
}
.az-faq[open] .az-faq__q { color: var(--az-black); }
.az-faq[open] .az-faq__q::after { transform: rotate(45deg); }
.az-faq__a {
    padding: 0 0 20px;
    font-size: 15px;
    line-height: 1.7;
    color: var(--az-gray-600);
}

/* Yellow button variant */
.az-btn--yellow {
    background: var(--az-yellow) !important;
    color: var(--az-black) !important;
    font-weight: 700 !important;
}
.az-btn--yellow:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(255, 204, 0, 0.35);
}

/* Ghost button for dark backgrounds */
.az-btn--ghost {
    background: transparent;
    color: rgba(255,255,255,0.6);
    border: 1px solid rgba(255,255,255,0.2);
    padding: 14px 28px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: color 0.2s, border-color 0.2s;
}
.az-btn--ghost:hover {
    color: rgba(255,255,255,0.9);
    border-color: rgba(255,255,255,0.4);
}

/* H2 light variant for dark cards */
.az-h2--light { color: var(--az-white); }

/* ── Contact page ────────────────────────────────────────── */
.az-contact-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 80px;
    align-items: flex-start;
}
.az-contact-form-wrap {
    background: transparent;
    padding: 0;
}
.az-contact-form-wrap h2 {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--az-gray-400) !important;
    margin: 0 0 32px !important;
}
.az-form { display: flex; flex-direction: column; gap: 0; }
.az-form__group {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-bottom: 1px solid var(--az-gray-200);
    padding: 20px 0;
}
.az-form__group:first-of-type { border-top: 1px solid var(--az-gray-200); }
.az-form__label {
    font-size: 11px;
    font-weight: 700;
    color: var(--az-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 6px;
}
.az-form__input {
    padding: 0;
    border: none;
    border-radius: 0;
    font-size: 17px;
    font-family: inherit;
    color: var(--az-black);
    background: transparent;
    transition: color 0.15s;
    outline: none;
    width: 100%;
    box-sizing: border-box;
    line-height: 1.4;
}
.az-form__input::placeholder { color: var(--az-gray-300); }
.az-form__input:focus { color: var(--az-black); }
.az-form__textarea {
    resize: none;
    min-height: 100px;
}
.az-form .az-btn {
    margin-top: 32px;
    align-self: flex-start;
}
.az-contact-info {
    position: sticky;
    top: 100px;
    padding-top: 8px;
}
.az-contact-divider {
    height: 1px;
    background: var(--az-gray-200);
    margin: 28px 0;
}

/* Responsive: service pages */
@media (max-width: 768px) {
    .az-contact-grid { grid-template-columns: 1fr; }
    .az-contact-info { position: static; }
    .az-svc-hero { padding: 80px var(--az-gap) 56px; }
    .az-steps { grid-template-columns: 1fr 1fr; }
    .az-steps::before { display: none; }
    .az-step { margin-bottom: 32px; }
    /* Preserve rounded corners on all mobile sizes */
    .az-card { border-radius: 20px !important; }
}

@media (max-width: 540px) {
    .az-steps { grid-template-columns: 1fr; }
    .az-benefit-card { flex-direction: column; }
    [style*="grid-template-columns:repeat(4,1fr)"],
    [style*="grid-template-columns: repeat(4, 1fr)"],
    .az-industries-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    [style*="grid-template-columns:repeat(3,1fr)"],
    [style*="grid-template-columns: repeat(3, 1fr)"] {
        grid-template-columns: 1fr !important;
    }
    [style*="grid-template-columns:repeat(2,1fr)"],
    [style*="grid-template-columns: repeat(2, 1fr)"] {
        grid-template-columns: 1fr !important;
    }
    /* Prevent horizontal scroll without blocking vertical */
    .az-section, .az-container, .az-reveal-group {
        max-width: 100%;
    }
    /* Always preserve rounded corners on cards in mobile */
    .az-card {
        border-radius: 20px !important;
    }
    /* Ensure containers keep lateral padding so card edges don't touch screen */
    .az-container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}

/* ── Legal pages ─────────────────────────────────────────── */
.az-legal-content {
    color: var(--az-gray-700);
    font-size: 16px;
    line-height: 1.8;
}
.az-legal-content h2 {
    font-size: 20px;
    font-weight: 700;
    color: var(--az-black);
    margin: 48px 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--az-gray-200);
}
.az-legal-content p { margin: 0 0 16px; }
.az-legal-content ul {
    list-style: disc;
    padding-left: 24px;
    margin: 0 0 16px;
}
.az-legal-content ul li { margin-bottom: 8px; }
.az-legal-content a { color: var(--az-black); font-weight: 500; text-decoration: underline; }

/* ── Blog ────────────────────────────────────────────────── */
.az-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.az-blog-card {
    display: flex;
    flex-direction: column;
    background: var(--az-white);
    border: 1px solid var(--az-gray-200);
    border-radius: var(--az-radius-lg);
    overflow: hidden;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
    text-decoration: none;
    color: inherit;
}
.az-blog-card:hover {
    box-shadow: var(--az-shadow-lg);
    transform: translateY(-3px);
}
.az-blog-card__thumb {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    background: var(--az-gray-100);
}
.az-blog-card__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--az-gray-100);
    aspect-ratio: 16/9;
    color: var(--az-gray-300);
}
.az-blog-card__body {
    padding: 20px 24px 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.az-blog-card__cat {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--az-yellow);
    margin-bottom: 10px;
}
.az-blog-card__title {
    font-size: 17px;
    font-weight: 700;
    color: var(--az-black);
    line-height: 1.4;
    margin: 0 0 10px;
    flex: 1;
}
.az-blog-card__excerpt {
    font-size: 13px;
    color: var(--az-gray-500);
    line-height: 1.6;
    margin: 0 0 16px;
}
.az-blog-card__meta {
    font-size: 12px;
    color: var(--az-gray-400);
    display: flex;
    gap: 8px;
}
.az-blog-categories {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 40px;
}
.az-blog-cat-btn {
    padding: 6px 16px;
    background: var(--az-gray-100);
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    color: var(--az-gray-600);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}
.az-blog-cat-btn:hover,
.az-blog-cat-btn.is-active {
    background: var(--az-black);
    color: var(--az-white);
}
@media (max-width: 768px) {
    .az-blog-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
    .az-blog-grid { grid-template-columns: 1fr; }
}
