/* ============================================================
   Aguilas Builder - Frontend
   Genero: dark security agency + azul electrico
   Composicion original (no basada en ninguna plantilla especifica)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body.ab-body{
    margin:0;
    font-family:var(--ab-font-body,'Inter',sans-serif);
    font-size:var(--ab-base-size,16px);
    line-height:1.6;
    color:var(--ab-text,#f8fbff);
    background:
        radial-gradient(circle at 82% 0%, rgba(47,109,255,.22), transparent 28%),
        radial-gradient(circle at 12% 8%, rgba(20,84,255,.18), transparent 28%),
        linear-gradient(180deg, #04060b 0%, var(--ab-bg-0,#07090f) 35%, #090b10 100%);
    overflow-x:hidden;
}
body.ab-body::before,body.ab-body::after{
    content:"";position:fixed;z-index:0;pointer-events:none;border-radius:50%;
    filter:blur(80px);opacity:.45;
}
body.ab-body::before{top:10%;left:-120px;width:320px;height:320px;background:radial-gradient(circle,rgba(20,84,255,.35),transparent 68%)}
body.ab-body::after{right:-140px;bottom:8%;width:360px;height:360px;background:radial-gradient(circle,rgba(47,109,255,.22),transparent 70%)}

.ab-container{width:min(1240px, calc(100% - 40px));margin:0 auto;position:relative;z-index:2}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Tipografia base ---------- */
h1,h2,h3,h4{margin:0;font-family:var(--ab-font-display,'Rajdhani',sans-serif);line-height:1;font-weight:700;color:var(--ab-text)}
h1{font-size:clamp(2.6rem, 6vw, 4.8rem);letter-spacing:-.01em}
h2{font-size:clamp(2rem, 4.4vw, 3.4rem);letter-spacing:-.005em}
h3{font-size:clamp(1.25rem, 1.8vw, 1.6rem);letter-spacing:0}
p{margin:0;color:var(--ab-text-dim,#9ba9c7)}

/* ---------- Kicker ---------- */
.ab-kicker{
    display:inline-flex;align-items:center;gap:10px;margin:0 0 14px;
    font-size:.85rem;color:var(--ab-silver);
    text-transform:uppercase;letter-spacing:.22em;font-weight:600
}
.ab-kicker::before{content:"";width:30px;height:1px;background:var(--ab-brand)}

/* ---------- Botones ---------- */
.ab-btn{
    position:relative;display:inline-flex;align-items:center;gap:10px;
    padding:14px 26px;border-radius:999px;border:0;cursor:pointer;
    font-family:inherit;font-size:.98rem;font-weight:700;letter-spacing:.02em;
    transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
    color:#fff
}
.ab-btn-primary{background:linear-gradient(90deg, var(--ab-brand), var(--ab-brand-2));box-shadow:0 14px 32px rgba(20,84,255,.32)}
.ab-btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(20,84,255,.44);filter:saturate(1.1)}
.ab-btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.18);color:var(--ab-text)}
.ab-btn-ghost:hover{border-color:var(--ab-brand-2);color:var(--ab-text)}
.ab-arrow{display:inline-block;transition:transform .25s cubic-bezier(.2,.7,.2,1);font-weight:900}
.ab-btn:hover .ab-arrow{transform:translate(3px,-3px)}

/* ---------- Topbar ---------- */
.ab-topbar{background:#05070c;border-bottom:1px solid rgba(255,255,255,.05);font-size:.84rem;color:var(--ab-text-dim)}
.ab-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:38px}
.ab-topbar-meta{display:flex;gap:20px;align-items:center}
.ab-topbar-meta a{display:inline-flex;align-items:center;gap:6px;color:inherit;transition:color .2s}
.ab-topbar-meta a:hover{color:var(--ab-brand-2)}
.ab-topbar-meta .dashicons{font-size:14px;width:14px;height:14px;line-height:1}

/* ---------- Header ---------- */
.ab-header-site{position:sticky;top:0;z-index:30;backdrop-filter:blur(14px);background:rgba(5,7,12,.78);border-bottom:1px solid rgba(255,255,255,.06)}
.ab-header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:80px}
.ab-brand-logo{display:flex;align-items:center;gap:12px}
.ab-brand-logo img{max-height:44px}
.ab-brand-shield{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--ab-brand-deep),var(--ab-brand));color:#fff}
.ab-brand-text strong{display:block;font-family:var(--ab-font-display);font-size:1.3rem;line-height:1;letter-spacing:.06em;color:#fff}
.ab-brand-text em{display:block;font-size:.7rem;font-style:normal;color:var(--ab-silver);letter-spacing:.22em;text-transform:uppercase;padding:3px 8px;margin-top:4px;background:var(--ab-brand);border-radius:4px;width:fit-content;color:#fff}
.ab-nav{display:flex;gap:24px;font-weight:600;font-size:.96rem}
.ab-nav a{color:var(--ab-text-dim);padding:6px 0;position:relative;transition:color .2s}
.ab-nav a:hover,.ab-nav a.is-active{color:var(--ab-text)}
.ab-nav a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--ab-brand-2);border-radius:2px}
.ab-header-actions{display:flex;align-items:center;gap:12px}
.ab-grid-launcher{display:grid;grid-template-columns:repeat(3,6px);gap:4px;padding:10px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:10px;cursor:pointer;width:fit-content}
.ab-grid-launcher span{display:block;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.7)}

/* ---------- HERO ---------- */
.ab-hero{padding:40px 0 20px;position:relative}
.ab-hero-grid{
    position:relative;border-radius:32px;overflow:hidden;
    background:radial-gradient(circle at 78% 16%, rgba(20,84,255,.28), transparent 30%),
               linear-gradient(135deg, rgba(7,9,15,.98), rgba(10,31,82,.96));
    border:1px solid rgba(255,255,255,.06);
    padding:60px 56px;min-height:620px;
    display:grid;grid-template-columns:1fr 1fr 0.4fr;gap:32px;align-items:center;
}
.ab-hero-copy{z-index:4;max-width:440px}
.ab-hero-badge{
    display:inline-flex;align-items:center;gap:10px;padding:9px 20px;border-radius:999px;
    background:rgba(8,13,22,.78);border:1px solid rgba(47,109,255,.38);
    color:#ecf2ff;font-size:.92rem;font-weight:700;letter-spacing:.04em;margin-bottom:22px
}
.ab-hero-badge em{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--ab-brand-2);box-shadow:0 0 0 0 rgba(47,109,255,.7);animation:abPulse 1.8s infinite;font-style:normal}
@keyframes abPulse{0%{box-shadow:0 0 0 0 rgba(47,109,255,.7)}70%{box-shadow:0 0 0 10px rgba(47,109,255,0)}100%{box-shadow:0 0 0 0 rgba(47,109,255,0)}}
.ab-hero-title{font-size:clamp(2.4rem, 5.2vw, 4.4rem);line-height:1.05;color:#fff;font-weight:700;letter-spacing:-.01em;margin-bottom:14px}
.ab-hero-accent{display:block;color:var(--ab-brand-2);margin-top:4px}
.ab-hero-copy-text{max-width:380px;font-size:1.02rem;color:var(--ab-text-dim);margin-bottom:28px}
.ab-hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.ab-hero-figure{z-index:3;position:relative}
.ab-hero-figure img{width:100%;max-height:600px;object-fit:cover;object-position:center top;border-radius:18px}
.ab-hero-placeholder{aspect-ratio:3/4;max-height:560px;border-radius:18px;background:linear-gradient(180deg, rgba(10,31,82,.6), rgba(7,9,15,.9));display:grid;place-items:center;color:var(--ab-silver)}
.ab-hero-placeholder .dashicons{font-size:96px;width:96px;height:96px;opacity:.4}
.ab-hero-stats-side{z-index:4;display:flex;flex-direction:column;gap:22px;align-items:flex-end;position:relative}
.ab-hero-stat strong{display:block;font-family:var(--ab-font-display);font-size:2.6rem;line-height:1;color:#fff;font-weight:700}
.ab-hero-stat strong span{color:var(--ab-brand-2);margin-left:4px}
.ab-hero-stat em{display:block;font-style:normal;color:var(--ab-text-dim);font-size:.84rem;line-height:1.3;margin-top:6px;border-top:1px solid rgba(255,255,255,.12);padding-top:8px;max-width:140px}
.ab-hero-seal{position:relative;width:120px;height:120px;margin-top:10px}
.ab-seal-svg{width:100%;height:100%;animation:abRotate 18s linear infinite}
@keyframes abRotate{to{transform:rotate(360deg)}}
.ab-seal-play{position:absolute;inset:0;margin:auto;width:52px;height:52px;border-radius:50%;border:0;background:var(--ab-brand);color:#fff;cursor:pointer;display:grid;place-items:center;box-shadow:0 10px 24px rgba(20,84,255,.44)}
.ab-seal-play .dashicons{font-size:28px;width:28px;height:28px;line-height:1;margin-left:3px}
.ab-hero-word{position:absolute;left:0;right:0;text-align:center;font-family:var(--ab-font-display);font-weight:800;line-height:.82;text-transform:uppercase;pointer-events:none;letter-spacing:-.02em;z-index:2}
.ab-hero-word-outline{bottom:220px;font-size:clamp(5rem,12vw,11rem);color:transparent;-webkit-text-stroke:1px rgba(196,209,238,.2);z-index:2}
.ab-hero-word-solid{bottom:40px;font-size:clamp(4rem,10vw,9rem);color:rgba(196,209,238,.14);z-index:3}

/* ---------- Band ---------- */
.ab-band{background:var(--ab-brand);color:#fff;padding:14px 0}
.ab-band-inner{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap;font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.86rem}

/* ---------- Section generics ---------- */
.ab-section{padding:90px 0;position:relative}
.ab-section-dark{background:var(--ab-bg-1)}
.ab-section-head{max-width:720px;margin:0 auto 50px;text-align:center}
.ab-section-head .ab-kicker{justify-content:center}
.ab-section-head h2{margin:0 0 16px}
.ab-section-head p{color:var(--ab-text-dim)}
.ab-split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}

/* ---------- About ---------- */
.ab-about-photo{position:relative;border-radius:22px;overflow:hidden}
.ab-about-photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.ab-media-placeholder{aspect-ratio:4/5;display:grid;place-items:center;background:linear-gradient(180deg,rgba(10,31,82,.5),rgba(7,9,15,.9));color:var(--ab-silver)}
.ab-media-placeholder .dashicons{font-size:72px;width:72px;height:72px;opacity:.45}
.ab-about-mini{position:absolute;left:22px;right:22px;bottom:22px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ab-mini-card{background:rgba(5,7,12,.84);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);padding:14px 16px;border-radius:12px}
.ab-mini-card strong{display:block;font-family:var(--ab-font-display);font-size:1.6rem;color:#fff}
.ab-mini-card em{display:block;font-style:normal;color:var(--ab-text-dim);font-size:.78rem;margin-top:4px}
.ab-about-copy h2{margin-bottom:18px}
.ab-about-copy p{margin-bottom:26px}
.ab-big-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ab-big-stat{padding:22px 22px;background:var(--ab-surface);border:1px solid rgba(255,255,255,.06);border-radius:16px}
.ab-big-stat strong{display:block;font-family:var(--ab-font-display);font-size:1.9rem;color:#fff}
.ab-big-stat em{display:block;font-style:normal;color:var(--ab-text-dim);font-size:.85rem;margin-top:6px}
.ab-big-stat.is-accent{background:linear-gradient(135deg,var(--ab-brand),var(--ab-brand-2))}
.ab-big-stat.is-accent strong,.ab-big-stat.is-accent em{color:#fff}

/* ---------- Services ---------- */
.ab-services-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:20px}
.ab-service-card{position:relative;padding:32px 28px;border-radius:18px;background:var(--ab-surface);border:1px solid rgba(255,255,255,.06);transition:transform .28s ease, border-color .28s ease}
.ab-service-card:hover{transform:translateY(-4px);border-color:rgba(47,109,255,.4)}
.ab-service-num{position:absolute;top:22px;right:24px;font-family:var(--ab-font-display);font-size:1.6rem;color:rgba(196,209,238,.28);font-weight:700}
.ab-service-media{margin-bottom:18px;border-radius:12px;overflow:hidden;aspect-ratio:16/10}
.ab-service-media img{width:100%;height:100%;object-fit:cover}
.ab-service-card h3{margin-bottom:10px;color:#fff}
.ab-service-card p{color:var(--ab-text-dim);font-size:.96rem}
.ab-service-arrow{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:rgba(47,109,255,.14);color:var(--ab-brand-2);font-size:1.3rem;margin-top:18px;transition:background .2s}
.ab-service-arrow:hover{background:var(--ab-brand)}

/* ---------- Why ---------- */
.ab-why-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:28px}
.ab-why-row{display:flex;gap:20px;padding:22px 4px;border-top:1px solid rgba(255,255,255,.08)}
.ab-why-num{font-family:var(--ab-font-display);font-size:2.4rem;color:var(--ab-brand-2);font-weight:700;line-height:1;min-width:60px}
.ab-why-row h3{margin-bottom:8px;color:#fff}
.ab-why-row p{color:var(--ab-text-dim);font-size:.95rem}

/* ---------- Process ---------- */
.ab-process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px}
.ab-process-card{padding:30px 26px;border-radius:18px;background:var(--ab-surface);border:1px solid rgba(255,255,255,.06);position:relative}
.ab-process-num{display:block;font-family:var(--ab-font-display);font-size:2.6rem;color:var(--ab-brand-2);font-weight:700;line-height:1;margin-bottom:14px}
.ab-process-card h3{margin-bottom:8px;color:#fff}
.ab-process-card p{color:var(--ab-text-dim);font-size:.92rem}

/* ---------- Team ---------- */
.ab-team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px}
.ab-team-card{background:var(--ab-surface);border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.06);transition:transform .28s ease}
.ab-team-card:hover{transform:translateY(-4px)}
.ab-team-photo{position:relative;aspect-ratio:1/1;overflow:hidden}
.ab-team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ab-team-card:hover .ab-team-photo img{transform:scale(1.06)}
.ab-team-social{position:absolute;inset:auto 0 0 0;padding:14px;display:flex;gap:10px;justify-content:center;background:linear-gradient(180deg,transparent,rgba(5,7,12,.85));opacity:0;transition:opacity .3s}
.ab-team-card:hover .ab-team-social{opacity:1}
.ab-team-social a{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--ab-brand);color:#fff}
.ab-team-social .dashicons{font-size:16px;width:16px;height:16px;line-height:1}
.ab-team-card h3{padding:18px 20px 4px;font-size:1.15rem;color:#fff}
.ab-team-card em{display:block;padding:0 20px 20px;font-style:normal;color:var(--ab-text-dim);font-size:.88rem}

/* ---------- Pricing ---------- */
.ab-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.ab-plan-card{padding:36px 30px;border-radius:22px;background:var(--ab-surface);border:1px solid rgba(255,255,255,.06);position:relative}
.ab-plan-card.is-featured{background:linear-gradient(160deg, rgba(20,84,255,.2), var(--ab-surface));border-color:rgba(47,109,255,.38);transform:scale(1.03)}
.ab-plan-badge{display:inline-block;padding:5px 14px;background:rgba(47,109,255,.18);color:var(--ab-brand-2);border-radius:999px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.ab-plan-card.is-featured .ab-plan-badge{background:var(--ab-brand);color:#fff}
.ab-plan-card h3{margin-bottom:12px;color:#fff}
.ab-plan-card p{margin-bottom:22px;color:var(--ab-text-dim);font-size:.95rem}
.ab-plan-card ul{list-style:none;padding:0;margin:0 0 26px}
.ab-plan-card li{display:flex;gap:10px;padding:8px 0;font-size:.92rem;color:var(--ab-text)}
.ab-plan-card .dashicons{color:var(--ab-brand-2)}
.ab-plan-card .ab-btn{width:100%;justify-content:center}

/* ---------- Testimonials ---------- */
.ab-test-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.ab-test-card{padding:30px 28px;border-radius:18px;background:var(--ab-surface);border:1px solid rgba(255,255,255,.06)}
.ab-test-rating{display:flex;gap:2px;color:#f4c04c;margin-bottom:14px}
.ab-test-rating .dashicons{font-size:18px;width:18px;height:18px;line-height:1}
.ab-test-card blockquote{margin:0 0 16px;font-size:1.04rem;color:var(--ab-text);line-height:1.6}
.ab-test-card cite{font-style:normal;font-weight:700;color:var(--ab-brand-2);font-size:.9rem;text-transform:uppercase;letter-spacing:.1em}

/* ---------- FAQ ---------- */
.ab-faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.ab-faq-item{background:var(--ab-surface);border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden}
.ab-faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:20px;font-weight:700;color:#fff}
.ab-faq-item summary::-webkit-details-marker{display:none}
.ab-faq-icon{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--ab-brand);color:#fff;font-size:1.3rem;transition:transform .24s}
.ab-faq-item[open] .ab-faq-icon{transform:rotate(45deg)}
.ab-faq-answer{padding:0 26px 22px;color:var(--ab-text-dim);font-size:.95rem;line-height:1.7}

/* ---------- Careers & Contact forms ---------- */
.ab-form-card{display:grid;gap:14px;padding:30px;background:var(--ab-surface);border-radius:18px;border:1px solid rgba(255,255,255,.06)}
.ab-form-card label{display:grid;gap:6px}
.ab-form-card span{font-size:.85rem;color:var(--ab-text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.ab-form-card input,.ab-form-card textarea{padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(7,9,15,.6);color:var(--ab-text);font-family:inherit;font-size:.98rem}
.ab-form-card input:focus,.ab-form-card textarea:focus{outline:none;border-color:var(--ab-brand-2)}
.ab-form-card button{margin-top:6px;justify-content:center}
.ab-contact-info{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:14px}
.ab-contact-info li{display:flex;align-items:center;gap:14px;color:var(--ab-text)}
.ab-contact-info .dashicons{color:var(--ab-brand-2);font-size:22px;width:22px;height:22px;line-height:1}

/* ---------- CTA banner ---------- */
.ab-cta-banner{padding:80px 0;background:linear-gradient(135deg, var(--ab-brand-deep), var(--ab-bg-1));position:relative;overflow:hidden}
.ab-cta-inner{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.ab-cta-display{font-family:var(--ab-font-display);line-height:.9;color:rgba(255,255,255,.16);font-size:clamp(3rem,7vw,6rem);font-weight:700;letter-spacing:-.01em;text-transform:uppercase;margin:0 0 12px}
.ab-cta-display span{display:block}
.ab-cta-display strong{display:block;color:#fff}
.ab-cta-banner p{max-width:480px;color:var(--ab-silver)}
.ab-cta-arrow{display:grid;place-items:center;width:110px;height:110px;border-radius:50%;background:var(--ab-brand);color:#fff;font-size:3rem;font-weight:900;transition:transform .25s}
.ab-cta-arrow:hover{transform:scale(1.06) rotate(-8deg)}

/* ---------- Footer ---------- */
.ab-footer{padding:70px 0 0;background:#04060b;border-top:1px solid rgba(255,255,255,.06)}
.ab-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:50px}
.ab-footer p{color:var(--ab-text-dim);margin:18px 0}
.ab-footer-col h3{font-size:.95rem;color:#fff;margin-bottom:16px;text-transform:uppercase;letter-spacing:.1em}
.ab-footer-col a{display:block;padding:5px 0;color:var(--ab-text-dim);transition:color .2s}
.ab-footer-col a:hover{color:var(--ab-brand-2)}
.ab-socials{display:flex;gap:10px;margin-top:18px}
.ab-socials a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(47,109,255,.14);color:var(--ab-brand-2);transition:background .2s,color .2s}
.ab-socials a:hover{background:var(--ab-brand);color:#fff}
.ab-footer-bottom{padding:22px 0;border-top:1px solid rgba(255,255,255,.06);font-size:.85rem;color:var(--ab-text-dim);text-align:center}

/* ---------- WhatsApp FAB ---------- */
.ab-whatsapp-fab{position:fixed;right:24px;bottom:24px;z-index:100;display:inline-flex;align-items:center;gap:10px;padding:14px 22px 14px 56px;border-radius:999px;background:var(--ab-whatsapp);color:#fff;font-weight:700;box-shadow:0 18px 40px rgba(37,211,102,.38);overflow:hidden}
.ab-whatsapp-fab svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:28px;height:28px}
.ab-whatsapp-fab:hover{background:#1dba5a}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
    .ab-hero-grid{grid-template-columns:1fr;padding:44px 26px;min-height:auto}
    .ab-hero-word-outline,.ab-hero-word-solid{display:none}
    .ab-hero-stats-side{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap}
    .ab-nav{display:none}
    .ab-split{grid-template-columns:1fr}
    .ab-footer-grid{grid-template-columns:1fr 1fr;gap:32px}
    .ab-section{padding:60px 0}
    .ab-topbar-inner{flex-direction:column;gap:6px;padding:10px 0}
}
@media (max-width: 600px){
    .ab-footer-grid{grid-template-columns:1fr}
    .ab-header-actions .ab-btn{display:none}
    .ab-cta-inner{gap:20px}
    .ab-cta-arrow{width:80px;height:80px;font-size:2.2rem}
    .ab-whatsapp-fab span{display:none}
    .ab-whatsapp-fab{padding:16px;border-radius:50%}
    .ab-whatsapp-fab svg{position:static;transform:none}
}

/* ============ Page hero (interior pages) ============ */
.ab-page-hero{padding:100px 0 60px;background:linear-gradient(135deg, var(--ab-brand-deep), var(--ab-bg-0));position:relative;overflow:hidden}
.ab-page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 30%, rgba(47,109,255,.28), transparent 40%);pointer-events:none}
.ab-crumbs{position:relative;font-size:.85rem;color:var(--ab-silver);text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px}
.ab-crumbs a{color:var(--ab-text-dim);margin-right:6px}
.ab-crumbs span{margin:0 8px;color:rgba(255,255,255,.3)}
.ab-crumbs strong{color:var(--ab-brand-2);font-weight:700}
.ab-page-title{position:relative;font-size:clamp(2.6rem,5vw,4.2rem);color:#fff;margin-bottom:14px;text-transform:uppercase;letter-spacing:-.01em}
.ab-page-subtitle{position:relative;max-width:640px;color:var(--ab-silver);font-size:1.05rem}

/* ============ Marquee ============ */
.ab-band{background:var(--ab-brand);color:#fff;padding:0;overflow:hidden}
.ab-band-track{display:flex;white-space:nowrap;gap:28px;padding:16px 0;animation:abScroll 30s linear infinite;font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.86rem}
.ab-band-track span{flex-shrink:0}
@keyframes abScroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}

.ab-certs{background:var(--ab-bg-0);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);padding:20px 0;overflow:hidden}
.ab-certs-track{display:flex;gap:36px;white-space:nowrap;animation:abScroll 40s linear infinite}
.ab-cert-chip{display:inline-flex;align-items:center;padding:10px 22px;background:rgba(47,109,255,.1);border:1px solid rgba(47,109,255,.28);border-radius:999px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ab-silver);font-size:.84rem;flex-shrink:0}

/* ============ Alerts ============ */
.ab-alert{padding:12px 16px;border-radius:10px;font-size:.92rem;margin-bottom:4px}
.ab-alert-ok{background:rgba(37,211,102,.12);color:#64e89a;border:1px solid rgba(37,211,102,.32)}
.ab-alert-err{background:rgba(255,68,68,.12);color:#ff8080;border:1px solid rgba(255,68,68,.32)}

/* ============ Counter + scroll reveal helpers ============ */
.ab-counting{opacity:.5;transition:opacity .6s}
.ab-logo-img{max-height:52px;width:auto}

/* ============ Refinamientos del g\u00e9nero v2 ============ */
/* Tipograf\u00eda display m\u00e1s cuadrada */
.ab-body h1, .ab-body h2, .ab-body h3, .ab-body .ab-hero-title {
    font-family: 'Archivo Black', 'Inter', var(--ab-font-display), sans-serif !important;
    font-weight: 900;
    letter-spacing: -.015em;
}

/* Hero: composici\u00f3n con imagen grande central */
.ab-hero-grid {
    grid-template-columns: 1.1fr 1.25fr 0.75fr !important;
    padding: 44px 40px 20px !important;
    min-height: 720px !important;
    overflow: visible !important;
}
.ab-hero-title {
    font-size: clamp(2.2rem, 4.2vw, 3.8rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -.01em !important;
}
.ab-hero-accent {
    display:block;
    color: var(--ab-brand-2) !important;
    margin-top: 2px !important;
}

/* Imagen central m\u00e1s grande con overlay */
.ab-hero-figure {
    align-self: stretch !important;
    position: relative !important;
}
.ab-hero-figure img {
    width: 100% !important;
    height: 100% !important;
    min-height: 580px !important;
    object-fit: cover !important;
    object-position: center top !important;
    border-radius: 18px !important;
    mask-image: linear-gradient(180deg, rgba(0,0,0,1) 70%, rgba(0,0,0,0) 100%);
    -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,1) 70%, rgba(0,0,0,0) 100%);
}

/* Stats m\u00e1s grandes con l\u00ednea separadora */
.ab-hero-stat strong {
    font-size: clamp(2.6rem, 4vw, 3.6rem) !important;
    font-weight: 900 !important;
    font-family: 'Archivo Black', 'Inter', sans-serif !important;
}
.ab-hero-stat em {
    max-width: 180px !important;
    font-size: .9rem !important;
}

/* Sello rotatorio m\u00e1s grande */
.ab-hero-seal {
    width: 140px !important;
    height: 140px !important;
    margin-top: 16px !important;
}
.ab-seal-play {
    width: 62px !important;
    height: 62px !important;
}

/* Palabras gigantes a todo lo ancho */
.ab-hero-word {
    font-family: 'Archivo Black', 'Inter', sans-serif !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
}
.ab-hero-word-outline {
    bottom: 38% !important;
    font-size: clamp(6rem, 16vw, 15rem) !important;
    -webkit-text-stroke: 1.5px rgba(196,209,238,.22) !important;
    color: transparent !important;
    z-index: 2 !important;
}
.ab-hero-word-solid {
    bottom: 8px !important;
    font-size: clamp(5rem, 14vw, 13rem) !important;
    color: rgba(196,209,238,.18) !important;
    z-index: 3 !important;
}

/* Hero badge refinado */
.ab-hero-badge {
    padding: 10px 22px !important;
    font-size: .95rem !important;
}

/* Mobile ajustes */
@media (max-width: 980px) {
    .ab-hero-grid {
        grid-template-columns: 1fr !important;
        min-height: auto !important;
    }
    .ab-hero-figure img {
        min-height: auto !important;
        max-height: 480px !important;
    }
    .ab-hero-stat strong { font-size: 2.2rem !important; }
    .ab-hero-stats-side { flex-direction: row; flex-wrap: wrap; }
}

/* ============ Fixes ============ */
.ab-form-card button.ab-btn,
.ab-form-card button.ab-btn-primary,
.ab-btn.ab-btn-primary,
button.ab-btn-primary,
input[type='submit'].ab-btn-primary { color: #fff !important; }
.ab-form-card button:focus,
.ab-form-card button:active { color: #fff !important; }

/* Contact info icons more visible */
.ab-contact-info .dashicons { color: var(--ab-brand-2); font-size: 22px; width: 22px; height: 22px; line-height: 1; flex-shrink: 0; }
.ab-topbar-meta .dashicons { color: var(--ab-brand-2); font-size: 14px; width: 14px; height: 14px; line-height: 1.3; vertical-align: middle; }
.ab-service-arrow, .ab-cta-arrow, .ab-faq-icon { line-height: 1; }

/* Grid launcher fix (display:block was being set by another rule) */
.ab-body button.ab-grid-launcher {
    display: grid !important;
    grid-template-columns: repeat(3, 6px) !important;
    grid-template-rows: repeat(3, 6px) !important;
    gap: 4px !important;
    padding: 10px !important;
    width: fit-content !important;
    height: fit-content !important;
    background: transparent !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-items: center !important;
}
.ab-body .ab-grid-launcher > span {
    display: block !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,.7) !important;
    margin: 0 !important;
}

/* ============ Hero full-bleed ============ */
.ab-hero { padding: 0 !important; background: transparent; }
.ab-hero > .ab-container { width: 100% !important; max-width: 100% !important; padding: 0 !important; margin: 0 !important; }
.ab-hero-grid {
    border-radius: 0 !important;
    border: none !important;
    padding: 50px 7% 40px !important;
    min-height: 720px !important;
    background:
        radial-gradient(ellipse at 70% 35%, rgba(47,109,255,.35), transparent 55%),
        radial-gradient(ellipse at 15% 10%, rgba(20,84,255,.22), transparent 50%),
        linear-gradient(180deg, #07090f 0%, #050912 60%, #030610 100%) !important;
}

/* Stats con l\u00ednea separadora arriba del label */
.ab-hero-stat { position: relative; padding-top: 2px; }
.ab-hero-stat strong {
    display: block;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(196,209,238,.22);
    margin-bottom: 10px;
}
.ab-hero-stat em {
    border-top: none !important;
    padding-top: 0 !important;
    font-size: .92rem !important;
    color: var(--ab-silver) !important;
}

/* Palabras gigantes m\u00e1s dominantes */
.ab-hero-word-outline { font-size: clamp(7rem, 18vw, 17rem) !important; bottom: 42% !important; }
.ab-hero-word-solid   { font-size: clamp(6rem, 16vw, 15rem) !important; bottom: 0 !important; color: rgba(196,209,238,.22) !important; }

/* Badge con m\u00e1s padding */
.ab-hero-badge { padding: 12px 26px !important; background: rgba(5,8,15,.75) !important; }

/* ============ Band diagonal ============ */
.ab-band {
    background: transparent !important;
    overflow: visible !important;
    padding: 30px 0 !important;
    margin: -20px 0 !important;
    position: relative;
}
.ab-band::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--ab-brand);
    transform: skewY(-2deg) rotate(-2deg) scaleX(1.04);
    transform-origin: center;
    z-index: 1;
}
.ab-band-track {
    position: relative;
    z-index: 2;
    font-size: 1.4rem !important;
    padding: 22px 0 !important;
    gap: 40px !important;
    transform: skewY(-2deg) rotate(-2deg);
    transform-origin: center;
    font-family: var(--ab-font-display), 'Archivo Black', sans-serif;
    font-weight: 700;
    letter-spacing: .08em !important;
}
.ab-band-sep {
    color: rgba(7,9,15,.7);
    font-size: 1.2rem;
    display: inline-block;
    transform: translateY(-2px);
}

@media (max-width: 600px) {
    .ab-band-track { font-size: 1rem !important; }
}

/* ============ Section titles m\u00e1s grandes ============ */
.ab-section-head h2,
.ab-about-copy h2 {
    font-size: clamp(2.4rem, 5.2vw, 5rem) !important;
    line-height: 1 !important;
    letter-spacing: -.015em !important;
    color: rgba(196,209,238,.22) !important;
    text-transform: uppercase !important;
    font-family: 'Archivo Black', 'Inter', var(--ab-font-display), sans-serif !important;
    margin-bottom: 24px !important;
}
.ab-section-head p { font-size: 1.05rem !important; color: var(--ab-text-dim) !important; }
.ab-about-copy h2 { color: #fff !important; text-transform: none !important; }

/* Vertical label sobre la foto about */
.ab-about-photo { position: relative; }
.ab-vert-label {
    position: absolute;
    top: 30px;
    left: 30px;
    z-index: 5;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    background: var(--ab-brand);
    color: #fff;
    padding: 14px 18px;
    font-family: 'Archivo Black', 'Inter', sans-serif;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    font-size: .9rem;
    border-radius: 10px;
    box-shadow: 0 12px 30px rgba(20,84,255,.42);
}

/* Big stats uniformity */
.ab-big-stat { padding: 26px 26px !important; }
.ab-big-stat strong { font-size: 2.2rem !important; font-family: 'Archivo Black', 'Inter', sans-serif !important; }

/* ============ About head (title display + sub) ============ */
.ab-about-head {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 40px;
    align-items: start;
    margin-bottom: 40px;
}
.ab-about-display {
    font-family: 'Archivo Black', 'Inter', sans-serif !important;
    font-weight: 900;
    line-height: .95;
    letter-spacing: -.015em;
    text-transform: uppercase;
    font-size: clamp(2.4rem, 5.4vw, 5rem);
    color: rgba(196,209,238,.28) !important;
    margin: 0;
}
.ab-about-sub {
    font-family: 'Archivo Black', 'Inter', sans-serif;
    font-weight: 900;
    color: var(--ab-brand-2);
    font-size: clamp(1.2rem, 1.8vw, 1.7rem);
    line-height: 1.15;
    letter-spacing: -.005em;
    margin: 10px 0 0;
    padding-top: 10px;
}
@media (max-width: 900px) {
    .ab-about-head { grid-template-columns: 1fr; gap: 14px; }
}

/* Learn more link */
.ab-about-learn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--ab-brand-2);
    font-weight: 700;
    font-family: 'Archivo Black', 'Inter', sans-serif;
    letter-spacing: .02em;
    margin: 8px 0 18px;
    text-decoration: none;
    transition: gap .25s ease;
}
.ab-about-learn:hover { gap: 14px; color: var(--ab-text); }
.ab-about-learn span { font-size: 1.2rem; }

/* Reviews card */
.ab-reviews-card {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    padding: 14px 22px 14px 14px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--ab-brand), var(--ab-brand-2));
    box-shadow: 0 14px 30px rgba(20,84,255,.38);
    margin: 8px 0 22px;
}
.ab-reviews-avatars {
    display: flex;
    align-items: center;
}
.ab-reviews-avatars .ab-avatar {
    display: block;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 2px solid #0a1f52;
    margin-right: -10px;
    background: linear-gradient(135deg, #1e2a4a 0%, #0a1f52 100%);
    background-size: cover;
}
.ab-reviews-avatars .ab-avatar:nth-child(1){ background-image: radial-gradient(circle at 50% 40%, rgba(255,255,255,.4), transparent 50%), linear-gradient(135deg, #3b4e78, #1a2440); }
.ab-reviews-avatars .ab-avatar:nth-child(2){ background-image: radial-gradient(circle at 50% 40%, rgba(255,255,255,.4), transparent 50%), linear-gradient(135deg, #4a3b78, #241a40); }
.ab-reviews-avatars .ab-avatar:nth-child(3){ background-image: radial-gradient(circle at 50% 40%, rgba(255,255,255,.4), transparent 50%), linear-gradient(135deg, #3b7864, #1a4034); }
.ab-reviews-avatars .ab-avatar-plus {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #0a1f52;
    color: #fff;
    display: grid;
    place-items: center;
    font-size: 1.2rem;
    font-weight: 900;
    border: 2px solid rgba(255,255,255,.2);
}
.ab-reviews-card strong {
    display: block;
    color: #fff;
    font-family: 'Archivo Black', 'Inter', sans-serif;
    font-size: 1.3rem;
    line-height: 1;
}
.ab-reviews-card em {
    display: block;
    font-style: normal;
    color: rgba(255,255,255,.86);
    font-size: .82rem;
    margin-top: 4px;
    letter-spacing: .02em;
}
.ab-about-sub-wrap { padding-top: 24px; }
.ab-about-sub-eyebrow {
    font-size: .75rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--ab-silver);
    margin: 0 0 8px;
    font-weight: 700;
}
.ab-about-sub {
    font-size: clamp(1.05rem, 1.4vw, 1.4rem) !important;
    line-height: 1.25 !important;
}
.ab-about-copy { position: relative; padding-top: 10px; }
.ab-about-copy p:first-of-type { font-size: 1.05rem; line-height: 1.65; color: var(--ab-text); margin-bottom: 18px; }

/* ============ Service link & single ============ */
.ab-service-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 18px;
    color: var(--ab-brand-2);
    font-weight: 700;
    transition: gap .25s ease, color .2s;
}
.ab-service-link:hover { gap: 14px; color: var(--ab-text); }
.ab-service-link .ab-service-arrow {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: rgba(47,109,255,.16);
    color: var(--ab-brand-2);
    display: grid; place-items: center;
    font-size: 1.2rem; line-height: 1;
    transition: background .2s, color .2s;
}
.ab-service-link:hover .ab-service-arrow {
    background: var(--ab-brand);
    color: #fff;
}
.ab-service-link-label {
    font-size: .9rem;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.ab-single-split { grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.ab-single-media {
    position: relative;
    border-radius: 22px;
    overflow: hidden;
    aspect-ratio: 4/5;
}
.ab-single-media img { width: 100%; height: 100%; object-fit: cover; }
.ab-single-copy h2 {
    font-family: 'Archivo Black', 'Inter', sans-serif !important;
    font-size: clamp(2.2rem, 4vw, 3.6rem) !important;
    line-height: 1.05 !important;
    text-transform: none !important;
    margin: 14px 0 20px !important;
}
.ab-single-copy p { font-size: 1.05rem; line-height: 1.7; margin-bottom: 28px; }
@media (max-width: 900px) {
    .ab-single-split { grid-template-columns: 1fr; }
}

/* ============ Service single: features + WA ============ */
.ab-single-features {
    list-style: none;
    padding: 0;
    margin: 22px 0 28px;
    display: grid;
    gap: 10px;
}
.ab-single-features li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 1rem;
    color: var(--ab-text);
    padding: 10px 14px;
    border: 1px solid rgba(47,109,255,.2);
    border-radius: 10px;
    background: rgba(20,84,255,.06);
}
.ab-single-features .dashicons {
    color: var(--ab-brand-2);
    flex-shrink: 0;
    margin-top: 1px;
}

.ab-single-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 8px;
}
.ab-btn-wa {
    background: var(--ab-whatsapp) !important;
    box-shadow: 0 14px 28px rgba(37,211,102,.34) !important;
}
.ab-btn-wa::after { display: none !important; }
.ab-btn-wa:hover {
    filter: brightness(1.08);
    transform: translateY(-2px);
}
.ab-btn-wa svg { flex-shrink: 0; }

/* ============ Quitar subrayado en TODOS los botones y links de CTA ============ */
.ab-body .ab-btn,
.ab-body .ab-btn:hover,
.ab-body .ab-btn:focus,
.ab-body .ab-btn:active,
.ab-body a.ab-btn,
.ab-body a.ab-btn-primary,
.ab-body a.ab-btn-ghost,
.ab-body a.ab-btn-wa,
.ab-body button.ab-btn,
.ab-body .ab-service-link,
.ab-body .ab-service-link:hover,
.ab-body .ab-service-link span,
.ab-body .ab-about-learn,
.ab-body .ab-about-learn:hover,
.ab-body .ab-whatsapp-fab,
.ab-body .ab-whatsapp-fab:hover,
.ab-body .ab-cta-arrow,
.ab-body .ab-service-arrow,
.ab-body .ab-socials a,
.ab-body .ab-footer-col a,
.ab-body .ab-nav a,
.ab-body .ab-topbar-meta a,
.ab-body .ab-reviews-card,
.ab-body .ab-crumbs a,
.ab-body .ab-hero-actions a,
.ab-body .ab-brand-logo,
.ab-body .ab-seal-play {
    text-decoration: none !important;
}
.ab-body .ab-service-link-label,
.ab-body .ab-btn *,
.ab-body .ab-about-learn *,
.ab-body .ab-service-link *,
.ab-body .ab-whatsapp-fab * {
    text-decoration: none !important;
}
/* Nav active: mantener subrayado SOLO con pseudo-elemento, no con text-decoration */
.ab-body .ab-nav a.is-active {
    text-decoration: none !important;
}

/* ============ WhatsApp FAB: s\u00f3lo \u00edcono circular con efecto ============ */
.ab-whatsapp-fab {
    position: fixed !important;
    right: 26px !important;
    bottom: 26px !important;
    z-index: 999 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    width: 64px !important;
    height: 64px !important;
    border-radius: 50% !important;
    background: var(--ab-whatsapp) !important;
    color: #fff !important;
    box-shadow:
        0 0 0 0 rgba(37,211,102,.55),
        0 16px 40px rgba(37,211,102,.42) !important;
    overflow: visible !important;
    animation: abWaPulse 2s infinite;
    transition: transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s;
}
.ab-whatsapp-fab:hover {
    transform: scale(1.08) rotate(-6deg);
    animation-play-state: paused;
}
.ab-whatsapp-fab svg {
    position: static !important;
    transform: none !important;
    width: 32px !important;
    height: 32px !important;
}
.ab-whatsapp-fab span {
    display: none !important;
}
/* Tooltip al hover */
.ab-whatsapp-fab::after {
    content: attr(aria-label);
    position: absolute;
    right: 78px;
    top: 50%;
    transform: translateY(-50%) translateX(10px);
    background: rgba(5,7,12,.95);
    color: #fff;
    padding: 10px 16px;
    border-radius: 10px;
    font-size: .85rem;
    font-weight: 700;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease, transform .2s ease;
    border: 1px solid rgba(255,255,255,.12);
}
.ab-whatsapp-fab:hover::after {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

@keyframes abWaPulse {
    0%   { box-shadow: 0 0 0 0 rgba(37,211,102,.55), 0 16px 40px rgba(37,211,102,.42); }
    70%  { box-shadow: 0 0 0 22px rgba(37,211,102,0), 0 16px 40px rgba(37,211,102,.42); }
    100% { box-shadow: 0 0 0 0 rgba(37,211,102,0),  0 16px 40px rgba(37,211,102,.42); }
}

@media (max-width: 600px) {
    .ab-whatsapp-fab { width: 56px !important; height: 56px !important; right: 16px !important; bottom: 16px !important; }
    .ab-whatsapp-fab svg { width: 28px !important; height: 28px !important; }
    .ab-whatsapp-fab::after { display: none; }
}

/* ============ WA pulsante reforzado (anillo expansivo) ============ */
.ab-whatsapp-fab {
    animation: none !important;
}
.ab-whatsapp-fab::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: var(--ab-whatsapp);
    z-index: -1;
    animation: abWaRing 1.6s cubic-bezier(.2,.7,.2,1) infinite;
    opacity: .6;
}
.ab-whatsapp-fab {
    position: fixed !important;
    isolation: isolate;
}
@keyframes abWaRing {
    0%   { transform: scale(1);   opacity: .55; }
    70%  { transform: scale(1.85); opacity: 0;   }
    100% { transform: scale(1.85); opacity: 0;   }
}
/* Anillo est\u00e1tico de fondo (halo) */
.ab-whatsapp-fab {
    box-shadow:
        0 0 0 12px rgba(37,211,102,.14),
        0 18px 44px rgba(37,211,102,.48) !important;
}
.ab-whatsapp-fab:hover {
    transform: scale(1.08);
    animation-play-state: paused;
}
.ab-whatsapp-fab:hover::before {
    animation-play-state: paused;
}

/* ============ Galeria operativa ============ */
.ab-gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 200px;
    gap: 12px;
}
.ab-gallery-item {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    display: block;
    background: var(--ab-surface);
    border: 1px solid rgba(255,255,255,.06);
    transition: transform .3s ease;
}
.ab-gallery-item.is-wide { grid-column: span 2; grid-row: span 2; }
.ab-gallery-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.ab-gallery-item:hover { transform: translateY(-3px); }
.ab-gallery-item:hover img { transform: scale(1.08); }
.ab-gallery-overlay {
    position: absolute; inset: 0;
    display: grid; place-items: center;
    background: linear-gradient(180deg, rgba(5,7,12,0) 40%, rgba(5,7,12,.7));
    opacity: 0; transition: opacity .3s;
    color: var(--ab-brand-2);
}
.ab-gallery-overlay .dashicons {
    font-size: 40px; width: 40px; height: 40px; line-height: 1;
    background: var(--ab-brand);
    color: #fff;
    border-radius: 50%;
    display: grid; place-items: center;
    padding: 14px;
    box-shadow: 0 10px 24px rgba(20,84,255,.46);
}
.ab-gallery-item:hover .ab-gallery-overlay { opacity: 1; }

@media (max-width: 900px) {
    .ab-gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
    .ab-gallery-item.is-wide { grid-column: span 2; grid-row: span 1; }
}

/* ============ Certificaciones (descarga PDFs) ============ */
.ab-certs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 18px;
    margin-bottom: 40px;
}
.ab-cert-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 22px;
    background: var(--ab-surface);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    transition: transform .3s ease, border-color .3s ease, background .3s ease;
}
.ab-cert-card:hover {
    transform: translateY(-3px);
    border-color: rgba(47,109,255,.5);
    background: linear-gradient(160deg, rgba(20,84,255,.1), var(--ab-surface));
}
.ab-cert-icon {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: rgba(47,109,255,.16);
    color: var(--ab-brand-2);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.ab-cert-icon .dashicons { font-size: 28px; width: 28px; height: 28px; line-height: 1; }
.ab-cert-body strong {
    display: block;
    color: #fff;
    font-family: 'Archivo Black', 'Inter', sans-serif;
    font-size: 1.05rem;
    line-height: 1.2;
    margin-bottom: 6px;
}
.ab-cert-body em {
    display: block;
    font-style: normal;
    color: var(--ab-text-dim);
    font-size: .88rem;
    margin-bottom: 14px;
}
.ab-cert-dl {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--ab-brand-2);
    font-weight: 700;
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .1em;
}
.ab-cert-dl .dashicons { font-size: 16px; width: 16px; height: 16px; line-height: 1; }

/* Brochure CTA banner */
.ab-brochure-cta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
    padding: 30px 36px;
    background: linear-gradient(135deg, var(--ab-brand-deep), var(--ab-surface));
    border: 1px solid rgba(47,109,255,.35);
    border-radius: 22px;
    flex-wrap: wrap;
}
.ab-brochure-cta h3 {
    color: #fff;
    font-family: 'Archivo Black', 'Inter', sans-serif !important;
    font-size: clamp(1.4rem, 2.4vw, 2rem) !important;
    line-height: 1.1 !important;
    margin: 6px 0 0;
}
.ab-brochure-cta .ab-btn .dashicons {
    font-size: 18px; width: 18px; height: 18px; line-height: 1;
}

/* ============ Video modal ============ */
.ab-video-modal {
    position: fixed; inset: 0; z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
}
.ab-video-modal.is-open { display: flex; }
.ab-video-backdrop {
    position: absolute; inset: 0;
    background: rgba(3,5,11,.92);
    backdrop-filter: blur(6px);
    animation: abFade .3s ease;
}
.ab-video-frame {
    position: relative;
    width: min(1000px, 92vw);
    aspect-ratio: 16/9;
    background: #000;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 40px 100px rgba(0,0,0,.7);
    animation: abScale .35s cubic-bezier(.2,.7,.2,1);
}
.ab-video-el { width: 100%; height: 100%; display: block; }
.ab-video-close {
    position: absolute; top: -50px; right: 0;
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.2);
    background: rgba(255,255,255,.06);
    color: #fff;
    cursor: pointer;
    font-size: 1.6rem;
    line-height: 1;
    display: grid; place-items: center;
}
.ab-video-close:hover { background: rgba(255,255,255,.14); }
@keyframes abFade { from { opacity: 0 } to { opacity: 1 } }
@keyframes abScale { from { opacity: 0; transform: scale(.9) } to { opacity: 1; transform: scale(1) } }

/* Fix subrayados restantes en cert cards */
.ab-cert-card, .ab-cert-card *, .ab-cert-card strong, .ab-cert-card em, .ab-cert-dl,
.ab-gallery-item, .ab-gallery-item *,
.ab-brochure-cta, .ab-brochure-cta * { text-decoration: none !important; }

/* ============ Tabs de material ============ */
.ab-tabs { margin-top: 10px; }
.ab-tabs-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px;
    background: var(--ab-surface);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 999px;
    margin: 0 auto 40px;
    width: fit-content;
    max-width: 100%;
}
.ab-tab-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 24px;
    background: transparent;
    border: 0;
    color: var(--ab-text-dim);
    font-family: inherit;
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: .04em;
    border-radius: 999px;
    cursor: pointer;
    transition: color .2s, background .2s;
    text-decoration: none !important;
}
.ab-tab-btn:hover { color: var(--ab-text); }
.ab-tab-btn.is-active {
    background: linear-gradient(90deg, var(--ab-brand), var(--ab-brand-2));
    color: #fff;
    box-shadow: 0 10px 22px rgba(20,84,255,.34);
}
.ab-tab-btn .dashicons { font-size: 18px; width: 18px; height: 18px; line-height: 1; }

.ab-tab-panel { animation: abFadeIn .35s ease both; }
.ab-tab-panel[hidden] { display: none; }
@keyframes abFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* Videos grid */
.ab-videos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}
.ab-video-card {
    background: var(--ab-surface);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    overflow: hidden;
    transition: transform .3s, border-color .3s;
}
.ab-video-card:hover { transform: translateY(-3px); border-color: rgba(47,109,255,.4); }
.ab-video-thumb {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    background: #000;
    border: 0;
    cursor: pointer;
    padding: 0;
    overflow: hidden;
    display: block;
}
.ab-video-thumb video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    pointer-events: none;
}
.ab-video-play {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    background: rgba(5,7,12,.35);
    transition: background .25s;
}
.ab-video-play .dashicons {
    width: 66px; height: 66px;
    font-size: 38px;
    line-height: 1;
    background: var(--ab-brand);
    color: #fff;
    border-radius: 50%;
    display: grid; place-items: center;
    padding-left: 3px;
    box-shadow: 0 16px 40px rgba(20,84,255,.48);
    transition: transform .3s;
}
.ab-video-thumb:hover .ab-video-play { background: rgba(5,7,12,.5); }
.ab-video-thumb:hover .ab-video-play .dashicons { transform: scale(1.08); }
.ab-video-card h4 {
    margin: 0;
    padding: 16px 20px 20px;
    font-family: 'Archivo Black','Inter',sans-serif;
    font-size: 1rem;
    line-height: 1.25;
    color: #fff;
}

@media (max-width: 600px) {
    .ab-tabs-nav { flex-direction: column; width: 100%; border-radius: 18px; }
    .ab-tab-btn { justify-content: center; }
}

/* Fix borders on inactive tabs */
.ab-body button.ab-tab-btn,
.ab-body button.ab-tab-btn:not(.is-active) {
    border: 0 !important;
    outline: none !important;
    color: var(--ab-text-dim) !important;
    text-decoration: none !important;
    box-shadow: none !important;
}
.ab-body button.ab-tab-btn:not(.is-active):hover {
    color: var(--ab-text) !important;
    background: rgba(47,109,255,.08) !important;
}
.ab-body button.ab-tab-btn.is-active {
    color: #fff !important;
}
.ab-body button.ab-tab-btn:focus {
    outline: 2px solid var(--ab-brand-2) !important;
    outline-offset: 2px !important;
}

/* Fix bordes rojos en video thumb buttons */
.ab-body button.ab-video-thumb,
.ab-body button.ab-video-thumb:focus,
.ab-body button.ab-video-thumb:active {
    border: 0 !important;
    outline: none !important;
    box-shadow: none !important;
}
.ab-body button.ab-video-thumb:focus-visible {
    outline: 2px solid var(--ab-brand-2) !important;
    outline-offset: 2px !important;
}
/* Fallback cuando video preload no renderiza thumbnail */
.ab-video-thumb::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #0a1f52, #07090f);
    z-index: 0;
}
.ab-video-thumb video,
.ab-video-thumb .ab-video-play {
    position: relative;
    z-index: 1;
}

/* ============ Reducir tama\u00f1os de t\u00edtulos display (m\u00e1s peque\u00f1os) ============ */
.ab-section-head h2,
.ab-about-copy h2,
.ab-about-display {
    font-size: clamp(1.6rem, 3vw, 2.6rem) !important;
    line-height: 1.1 !important;
}
.ab-page-title {
    font-size: clamp(2rem, 3.4vw, 3rem) !important;
}
.ab-cta-display {
    font-size: clamp(2rem, 4vw, 3.6rem) !important;
}
.ab-hero-title {
    font-size: clamp(1.8rem, 3.4vw, 2.8rem) !important;
    line-height: 1.1 !important;
}
.ab-single-copy h2 {
    font-size: clamp(1.6rem, 3vw, 2.4rem) !important;
    line-height: 1.15 !important;
}
.ab-brochure-cta h3 {
    font-size: clamp(1.1rem, 1.8vw, 1.5rem) !important;
}
.ab-about-sub {
    font-size: clamp(.95rem, 1.2vw, 1.15rem) !important;
}
/* Palabras gigantes hero (solo desktop, mobile ya ocultas) */
.ab-hero-word-outline {
    font-size: clamp(4rem, 10vw, 9rem) !important;
}
.ab-hero-word-solid {
    font-size: clamp(3.4rem, 8vw, 7.5rem) !important;
}
/* Band text tama\u00f1o normal */
.ab-band-track {
    font-size: 1.05rem !important;
    letter-spacing: .06em !important;
}

/* ============ Columnas About con misma altura ============ */
.ab-body .ab-section .ab-split {
    align-items: stretch !important;
}
.ab-body .ab-split > .ab-about-photo,
.ab-body .ab-split > .ab-about-copy {
    display: flex;
    flex-direction: column;
    height: auto;
}
.ab-body .ab-about-photo {
    min-height: 100%;
}
.ab-body .ab-about-photo img {
    flex: 1 1 auto;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    aspect-ratio: auto !important;
}
.ab-body .ab-about-copy {
    justify-content: center;
}

/* ============ Hero limpio: sin BODYGUARD, sin stats side ============ */
.ab-hero-word-solid { display: none !important; }
.ab-hero-stats-side { display: none !important; }
.ab-hero-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 50px !important;
    padding: 60px 6% 40px !important;
    min-height: 620px !important;
}
/* Reubicar el sello rotatorio adentro del lado derecho */
.ab-hero-figure { position: relative; }
.ab-hero-figure .ab-hero-seal-relocate { display: none; }
/* Palabra outline sola queda centrada */
.ab-hero-word-outline {
    bottom: 10% !important;
}
@media (max-width: 980px) {
    .ab-hero-grid { grid-template-columns: 1fr !important; }
    .ab-hero-word-outline { display: none !important; }
}

/* Restaurar stats-side para que el sello rotatorio vuelva a verse */
.ab-body .ab-hero-stats-side { display: flex !important; flex-direction: column; align-items: flex-end; gap: 16px; }
.ab-body .ab-hero-stat { display: none !important; }
.ab-body .ab-hero-seal { display: block !important; margin-top: 0 !important; }
/* Reajustar grid hero a 3 columnas (copy + figura + seal column) */
.ab-body .ab-hero-grid {
    grid-template-columns: 1fr 1.2fr 0.35fr !important;
}
@media (max-width: 980px) {
    .ab-body .ab-hero-grid { grid-template-columns: 1fr !important; }
    .ab-body .ab-hero-stats-side { align-items: center !important; }
}

/* Ocultar placeholder hero cuando no hay imagen */
.ab-hero-figure:has(.ab-hero-placeholder) { visibility: hidden; pointer-events: none; }
/* Fallback browsers sin :has() */
.ab-hero-placeholder { opacity: 0 !important; }

/* Band recta horizontal (sin rotaci\u00f3n diagonal) */
.ab-body .ab-band { padding: 14px 0 !important; margin: 0 !important; background: var(--ab-brand) !important; }
.ab-body .ab-band::before { display: none !important; }
.ab-body .ab-band-track { transform: none !important; padding: 4px 0 !important; }

/* Eliminar completamente ab-hero-figure vacio (sin imagen real) */
.ab-body .ab-hero-figure:has(.ab-hero-placeholder) {
    display: none !important;
}
/* Fallback: si navegador no soporta :has, usar selector mas amplio */
.ab-body .ab-hero-placeholder { display: none !important; }
/* Si no hay figure, reajustar grid a 1fr + sello */
.ab-body .ab-hero-grid:not(:has(.ab-hero-figure img)) {
    grid-template-columns: 1.4fr 0.35fr !important;
}

/* ============ Hero con fondo cubriendo todo ============ */
.ab-body .ab-hero.has-bg {
    position: relative;
    overflow: hidden;
    min-height: 620px;
}
.ab-hero-bg-image,
.ab-hero-bg-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background-size: cover;
    background-position: center center;
    z-index: 0;
}
.ab-hero-bg-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(ellipse at 15% 50%, rgba(3,5,11,.92) 0%, rgba(3,5,11,.72) 38%, transparent 70%),
        linear-gradient(180deg, rgba(3,5,11,.55) 0%, rgba(3,5,11,.35) 50%, rgba(3,5,11,.85) 100%),
        linear-gradient(135deg, rgba(10,31,82,.48), rgba(7,9,15,.1));
    pointer-events: none;
}
.ab-body .ab-hero.has-bg .ab-container { position: relative; z-index: 2; }
.ab-body .ab-hero.has-bg .ab-hero-grid {
    background: transparent !important;
    border: none !important;
    padding: 60px 6% 40px !important;
    min-height: 620px !important;
}
.ab-body .ab-hero.has-bg .ab-hero-copy p,
.ab-body .ab-hero.has-bg .ab-hero-copy-text {
    color: #dfe6f5 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.6);
}
.ab-body .ab-hero.has-bg .ab-hero-title {
    text-shadow: 0 3px 20px rgba(0,0,0,.55);
}
.ab-body .ab-hero.has-bg .ab-hero-badge {
    backdrop-filter: blur(10px);
    background: rgba(8,13,22,.55) !important;
}

/* ============ Hero background slider ============ */
.ab-hero-bg-slider {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}
.ab-hero-bg-slider .ab-hero-bg-image {
    position: absolute;
    inset: 0;
    opacity: 0;
    transform: scale(1.05);
    transition: opacity 1.2s cubic-bezier(.4,0,.2,1), transform 6s ease-out;
    background-size: cover;
    background-position: center 65%; /* mostrar m\u00e1s arriba \u2192 cara visible */
    background-repeat: no-repeat;
}
.ab-hero-bg-slider .ab-hero-bg-image.is-active {
    opacity: 1;
    transform: scale(1);
}

/* Ajuste de posici\u00f3n fondo cuando es imagen \u00fanica */
.ab-body .ab-hero.has-bg .ab-hero-bg-image {
    background-position: center 60% !important;
}

/* ============================================================
   Aguilas Blancas Segurity — secciones nuevas (MVV / Features /
   Centro de control / Certificaciones / Clientes).
   Ajustes para alinear acentos a la paleta del logo (navy+dorado).
   ============================================================ */

/* Multi-telefonos en contacto */
.ab-contact-phones a { color: var(--ab-brand-2); border-bottom: 1px dashed rgba(230,184,90,.4); transition: color .2s; }
.ab-contact-phones a:hover { color: #fff; border-bottom-color: #fff; }

/* Mision / Vision / Valores */
.ab-mvv-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; }
.ab-mvv-card { position:relative; padding:38px 32px; border-radius:20px; background:linear-gradient(180deg, rgba(15,28,58,.92), rgba(10,22,46,.92)); border:1px solid rgba(230,184,90,.18); overflow:hidden; transition:transform .28s ease, border-color .28s ease; }
.ab-mvv-card:hover { transform:translateY(-4px); border-color:var(--ab-brand-2); }
.ab-mvv-card::after { content:""; position:absolute; right:-40px; top:-40px; width:180px; height:180px; border-radius:50%; background:radial-gradient(circle,rgba(230,184,90,.12),transparent 70%); pointer-events:none; }
.ab-mvv-icon { display:inline-grid; place-items:center; width:58px; height:58px; border-radius:14px; background:linear-gradient(135deg,var(--ab-brand-deep),var(--ab-brand)); color:var(--ab-brand-2); margin-bottom:20px; position:relative; z-index:2; }
.ab-mvv-icon .dashicons { font-size:26px; width:26px; height:26px; line-height:1; }
.ab-mvv-card h3 { color:#fff; margin-bottom:12px; font-size:1.5rem; letter-spacing:.04em; text-transform:uppercase; }
.ab-mvv-card p { color:var(--ab-text-dim); font-size:.98rem; line-height:1.65; }
.ab-mvv-values-list { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.ab-mvv-values-list li { display:flex; align-items:center; gap:8px; color:var(--ab-text); font-size:.94rem; font-weight:500; }
.ab-mvv-values-list .dashicons { color:var(--ab-brand-2); font-size:18px; width:18px; height:18px; line-height:1; }

/* Caracteristicas */
.ab-features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:22px; }
.ab-feature-card { position:relative; padding:36px 28px 28px; border-radius:18px; background:var(--ab-surface); border:1px solid rgba(230,184,90,.14); transition:all .28s ease; }
.ab-feature-card:hover { transform:translateY(-4px); border-color:var(--ab-brand-2); box-shadow:0 18px 44px rgba(10,31,82,.45); }
.ab-feature-badge { position:absolute; top:-18px; left:28px; display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius:12px; background:linear-gradient(135deg,var(--ab-brand-2),#d9a944); color:#0a1f52; font-family:var(--ab-font-display); font-weight:800; font-size:1.2rem; box-shadow:0 10px 24px rgba(230,184,90,.35); }
.ab-feature-card h3 { margin:10px 0 10px; color:#fff; font-size:1.2rem; }
.ab-feature-card p { color:var(--ab-text-dim); font-size:.95rem; }

/* Centro de control */
.ab-control-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:22px; margin-bottom:34px; }
.ab-control-card { padding:30px 26px; border-radius:18px; background:rgba(10,22,46,.8); border:1px solid rgba(230,184,90,.18); text-align:center; transition:all .28s ease; }
.ab-control-card:hover { border-color:var(--ab-brand-2); transform:translateY(-3px); }
.ab-control-icon { display:inline-grid; place-items:center; width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,var(--ab-brand-deep),var(--ab-brand)); color:var(--ab-brand-2); margin-bottom:18px; box-shadow:0 0 0 6px rgba(230,184,90,.08); }
.ab-control-icon .dashicons { font-size:34px; width:34px; height:34px; line-height:1; }
.ab-control-card h3 { margin-bottom:10px; color:#fff; font-size:1.15rem; }
.ab-control-card p { color:var(--ab-text-dim); font-size:.94rem; }
.ab-control-hours { display:flex; align-items:center; justify-content:center; gap:18px; padding:28px; border-radius:16px; background:linear-gradient(90deg,rgba(10,31,82,.92),rgba(15,28,58,.92)); border:1px solid rgba(230,184,90,.22); }
.ab-control-hours strong { font-family:var(--ab-font-display); font-size:clamp(3rem,8vw,5rem); font-weight:800; color:var(--ab-brand-2); line-height:1; }
.ab-control-hours em { font-style:normal; color:#fff; font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:.98rem; }

/* Certificaciones detalle */
.ab-cert-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; margin-bottom:40px; }
.ab-cert-card { position:relative; padding:28px 26px; border-radius:16px; background:var(--ab-surface); border:1px solid rgba(230,184,90,.16); transition:all .28s ease; }
.ab-cert-card:hover { border-color:var(--ab-brand-2); transform:translateY(-3px); }
.ab-cert-seal { display:inline-grid; place-items:center; width:50px; height:50px; border-radius:50%; background:radial-gradient(circle,var(--ab-brand-2),#b5862a); color:#0a1f52; margin-bottom:14px; box-shadow:0 0 0 4px rgba(230,184,90,.12); }
.ab-cert-seal .dashicons { font-size:24px; width:24px; height:24px; line-height:1; }
.ab-cert-card h3 { color:#fff; margin-bottom:10px; font-size:1.08rem; letter-spacing:.01em; }
.ab-cert-card p { color:var(--ab-text-dim); font-size:.92rem; line-height:1.6; }
.ab-iso-block { padding:32px; border-radius:18px; background:linear-gradient(135deg, rgba(10,31,82,.6), rgba(15,28,58,.8)); border:1px solid rgba(230,184,90,.22); }
.ab-iso-block h3 { color:#fff; margin-bottom:18px; font-size:1.25rem; letter-spacing:.05em; text-transform:uppercase; }
.ab-iso-list { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:12px; }
.ab-iso-list li { list-style: none; }
.ab-iso-chip { display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:12px; background:rgba(10,31,82,.7); border:1px solid rgba(230,184,90,.22); color:#fff; font-weight:600; font-size:.92rem; width:100%; }
.ab-iso-chip .dashicons { color:var(--ab-brand-2); }

/* Clientes */
.ab-clients-grid { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; }
.ab-client-tile { aspect-ratio:3/2; display:grid; place-items:center; padding:20px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid rgba(230,184,90,.14); transition:all .28s ease; }
.ab-client-tile:hover { background:rgba(230,184,90,.08); border-color:var(--ab-brand-2); transform:translateY(-3px); }
.ab-client-tile span { font-family:var(--ab-font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:#fff; font-size:1rem; text-align:center; line-height:1.2; }

@media (max-width: 980px) {
    .ab-mvv-values-list { grid-template-columns:1fr; }
    .ab-control-hours strong { font-size:3rem; }
}

/* Fix overflow horizontal causado por banda diagonal skewed */
html { overflow-x: hidden; }
.ab-body { overflow-x: hidden !important; }

/* Asegura stack vertical en cards de certificaciones y control */
.ab-cert-card { display: block !important; }
.ab-cert-card .ab-cert-seal,
.ab-cert-card h3,
.ab-cert-card p { display: block; }
.ab-control-card { display: block; text-align: center; }
.ab-feature-card { display: block; }
.ab-mvv-card { display: block; }
.ab-cert-grid { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important; }

/* Clientes carousel */
.ab-clients-carousel { overflow: hidden; position: relative; padding: 0 10px; }
.ab-clients-carousel::before,
.ab-clients-carousel::after { content: ''; position: absolute; top: 0; bottom: 0; width: 60px; z-index: 3; pointer-events: none; }
.ab-clients-carousel::before { left: 0; background: linear-gradient(90deg, var(--ab-bg-1) 0%, transparent 100%); }
.ab-clients-carousel::after  { right: 0; background: linear-gradient(270deg, var(--ab-bg-1) 0%, transparent 100%); }
.ab-clients-track { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; transition: transform .8s cubic-bezier(.4,0,.2,1); will-change: transform; }
.ab-clients-track .ab-client-tile { flex: 0 0 calc((100% - 18px * 5) / 6); aspect-ratio: 3 / 2; display: grid; place-items: center; padding: 22px 28px; border-radius: 14px; background: #ffffff; border: 1px solid rgba(230,184,90,.18); transition: transform .28s ease, box-shadow .28s ease; }
.ab-clients-track .ab-client-tile:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(10,31,82,.4); border-color: var(--ab-brand-2); }
.ab-clients-track .ab-client-tile img { max-width: 100%; max-height: 100%; object-fit: contain; filter: none; }
.ab-clients-track .ab-client-tile span { font-family: var(--ab-font-display); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #0a1f52; font-size: .95rem; text-align: center; line-height: 1.2; }

@media (max-width: 980px) {
    .ab-clients-track .ab-client-tile { flex: 0 0 calc((100% - 18px * 2) / 3); }
}
@media (max-width: 560px) {
    .ab-clients-track .ab-client-tile { flex: 0 0 calc((100% - 18px) / 2); }
}

/* Fondo personalizado por pagina en page hero */
.ab-page-hero.has-bg { background-size: cover; background-position: center 40%; background-repeat: no-repeat; position: relative; }
.ab-page-hero.has-bg .ab-page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,11,26,.78) 0%, rgba(10,31,82,.82) 55%, rgba(5,11,26,.92) 100%); z-index: 1; pointer-events: none; }
.ab-page-hero.has-bg > .ab-container { position: relative; z-index: 2; }
.ab-page-hero.has-bg .ab-page-title { text-shadow: 0 4px 24px rgba(5,11,26,.6); }

/* Footer FAQ compacto */
.ab-footer-faq { background: linear-gradient(180deg, rgba(10,31,82,.35), rgba(5,11,26,.9)); border-top: 1px solid rgba(230,184,90,.2); padding: 54px 0 36px; }
.ab-footer-faq-head { text-align: center; max-width: 720px; margin: 0 auto 32px; }
.ab-footer-faq-head .ab-kicker { justify-content: center; }
.ab-footer-faq-head h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); margin: 0; color: #fff; }
.ab-footer-faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.ab-footer-faq-item { background: rgba(255,255,255,.03); border: 1px solid rgba(230,184,90,.14); border-radius: 12px; overflow: hidden; transition: border-color .25s ease; }
.ab-footer-faq-item[open] { border-color: rgba(230,184,90,.42); }
.ab-footer-faq-item summary { list-style: none; cursor: pointer; padding: 16px 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; color: #fff; font-weight: 600; font-size: .98rem; }
.ab-footer-faq-item summary::-webkit-details-marker { display: none; }
.ab-footer-faq-item .ab-faq-icon { flex-shrink: 0; background: var(--ab-brand-2); color: #0a1f52; width: 30px; height: 30px; font-size: 1.1rem; }
.ab-footer-faq-item[open] .ab-faq-icon { transform: rotate(45deg); }
.ab-footer-faq-answer { padding: 0 22px 18px; color: var(--ab-text-dim); font-size: .92rem; line-height: 1.65; }

/* Convocatoria laboral - jobs grid */
.ab-jobs-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 22px; margin-bottom: 60px; }
.ab-job-card { display: flex; flex-direction: column; padding: 30px 28px; border-radius: 20px; background: linear-gradient(180deg, rgba(15,28,58,.92), rgba(10,22,46,.92)); border: 1px solid rgba(230,184,90,.18); transition: all .3s ease; }
.ab-job-card:hover { transform: translateY(-4px); border-color: var(--ab-brand-2); box-shadow: 0 20px 44px rgba(10,31,82,.5); }
.ab-job-head { border-bottom: 1px solid rgba(230,184,90,.14); padding-bottom: 18px; margin-bottom: 18px; }
.ab-job-head h3 { color: #fff; margin: 0 0 12px; font-size: 1.35rem; letter-spacing: .02em; }
.ab-job-meta { display: flex; flex-wrap: wrap; gap: 8px 16px; font-size: .86rem; color: var(--ab-text-dim); }
.ab-job-meta span { display: inline-flex; align-items: center; gap: 6px; }
.ab-job-meta .dashicons { font-size: 16px; width: 16px; height: 16px; line-height: 1; color: var(--ab-brand-2); }
.ab-job-salary { color: var(--ab-brand-2) !important; font-weight: 700; }
.ab-job-desc { color: var(--ab-text-dim); font-size: .94rem; line-height: 1.6; margin-bottom: 16px; }
.ab-job-block { margin-bottom: 16px; }
.ab-job-block > strong { display: block; font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; color: var(--ab-brand-2); margin-bottom: 8px; }
.ab-job-block ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.ab-job-block li { display: flex; align-items: flex-start; gap: 8px; color: var(--ab-text); font-size: .9rem; line-height: 1.5; }
.ab-job-block .dashicons { color: var(--ab-brand-2); font-size: 16px; width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; }
.ab-job-apply { margin-top: auto; justify-content: center; }

/* Formulario de convocatoria ampliado */
.ab-careers-form-wrap { max-width: 780px; margin: 40px auto 0; padding: 40px; background: var(--ab-surface); border-radius: 22px; border: 1px solid rgba(230,184,90,.2); }
.ab-careers-form-head { text-align: center; margin-bottom: 28px; }
.ab-careers-form-head h3 { color: #fff; margin: 0 0 8px; font-size: 1.6rem; }
.ab-careers-form-head p { color: var(--ab-text-dim); font-size: .95rem; }
.ab-form-careers { padding: 0; background: transparent; border: 0; }
.ab-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ab-form-careers select { padding: 14px 16px; border-radius: 10px; border: 1px solid rgba(255,255,255,.12); background: rgba(7,9,15,.6); color: var(--ab-text); font-family: inherit; font-size: .98rem; }
.ab-form-careers select:focus { outline: none; border-color: var(--ab-brand-2); }
.ab-form-check { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; color: var(--ab-text-dim); font-size: .88rem; cursor: pointer; }
.ab-form-check input { width: 18px; height: 18px; margin-top: 2px; flex-shrink: 0; accent-color: var(--ab-brand-2); }
.ab-form-check span { line-height: 1.5; }

@media (max-width: 680px) {
    .ab-form-row { grid-template-columns: 1fr; }
    .ab-careers-form-wrap { padding: 24px 18px; }
}

/* Nav submenu dropdown */
.ab-nav { position: relative; align-items: center; }
.ab-nav-item { position: relative; display: inline-flex; align-items: center; }
.ab-nav-toggle { display: inline-flex; align-items: center; gap: 6px; color: var(--ab-text-dim); padding: 6px 0; position: relative; font-weight: 600; font-size: .96rem; transition: color .2s; cursor: pointer; }
.ab-nav-toggle:hover, .ab-nav-item.is-active .ab-nav-toggle, .ab-nav-item.is-open .ab-nav-toggle { color: #fff; }
.ab-nav-item.is-active .ab-nav-toggle::after { content: ; position: absolute; left: 0; right: 14px; bottom: -4px; height: 2px; background: var(--ab-brand-2); border-radius: 2px; }
.ab-nav-caret { font-size: .65rem; line-height: 1; margin-left: 2px; transition: transform .25s ease; opacity: .75; }
.ab-nav-item:hover .ab-nav-caret, .ab-nav-item.is-open .ab-nav-caret { transform: rotate(-180deg); }

.ab-nav-sub { position: absolute; top: 100%; left: -14px; min-width: 180px; padding: 10px 0; margin-top: 8px; background: rgba(5,11,26,.96); backdrop-filter: blur(14px); border: 1px solid rgba(230,184,90,.22); border-radius: 14px; box-shadow: 0 20px 50px rgba(5,11,26,.6); opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .22s ease, transform .22s ease, visibility .22s; z-index: 40; }
.ab-nav-sub::before { content: ; position: absolute; top: -8px; left: 26px; width: 14px; height: 14px; background: rgba(5,11,26,.96); border-left: 1px solid rgba(230,184,90,.22); border-top: 1px solid rgba(230,184,90,.22); transform: rotate(45deg); }
.ab-nav-item:hover > .ab-nav-sub, .ab-nav-item:focus-within > .ab-nav-sub, .ab-nav-item.is-open > .ab-nav-sub { opacity: 1; visibility: visible; transform: translateY(0); }
/* Bridge invisible para que no se corte el hover */
.ab-nav-item::after { content: ; position: absolute; left: 0; right: 0; top: 100%; height: 18px; }

.ab-nav-sub a { display: block; padding: 9px 18px; color: var(--ab-text-dim); font-size: .94rem; font-weight: 500; border-left: 2px solid transparent; transition: color .2s ease, border-color .2s ease, background .2s ease; }
.ab-nav-sub a:hover { color: var(--ab-brand-2); background: rgba(230,184,90,.06); border-left-color: var(--ab-brand-2); }
.ab-nav-sub a.is-active { color: #fff; border-left-color: var(--ab-brand-2); }

/* Click support para mobile */
@media (max-width: 980px) {
    .ab-nav-sub { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: transparent; border: 0; padding: 4px 0 4px 14px; margin: 0; min-width: 0; }
    .ab-nav-sub::before { display: none; }
    .ab-nav-item { display: block; width: 100%; }
    .ab-nav-toggle { width: 100%; justify-content: space-between; }
}

/* Job card preview (listado) */
.ab-job-card-preview .ab-job-head h3 a { color: #fff; transition: color .2s ease; }
.ab-job-card-preview .ab-job-head h3 a:hover { color: var(--ab-brand-2); }
.ab-job-card-preview .ab-job-actions { margin-top: auto; padding-top: 12px; }
.ab-job-card-preview .ab-job-actions .ab-btn { width: 100%; justify-content: center; }

/* Job detail page */
.ab-job-back { display: inline-flex; align-items: center; gap: 8px; color: var(--ab-brand-2); font-weight: 600; margin-bottom: 20px; transition: color .2s ease; text-decoration: none; }
.ab-job-back:hover { color: #fff; }
.ab-job-back .dashicons { font-size: 18px; width: 18px; height: 18px; }

.ab-job-hero { display: flex; justify-content: space-between; align-items: flex-end; gap: 28px; flex-wrap: wrap; padding: 36px 38px; border-radius: 22px; background: linear-gradient(135deg, rgba(10,31,82,.85), rgba(15,28,58,.9)); border: 1px solid rgba(230,184,90,.22); margin-bottom: 34px; }
.ab-job-title { color: #fff; font-size: clamp(2rem, 4vw, 3.2rem); margin: 10px 0 18px; text-transform: uppercase; letter-spacing: -.01em; line-height: 1.05; }
.ab-job-meta-big { display: flex; flex-wrap: wrap; gap: 14px 22px; font-size: .96rem; color: var(--ab-text-dim); }
.ab-job-meta-big span { display: inline-flex; align-items: center; gap: 8px; }
.ab-job-meta-big .dashicons { color: var(--ab-brand-2); font-size: 18px; width: 18px; height: 18px; }
.ab-job-meta-big .ab-job-salary { color: var(--ab-brand-2); font-weight: 700; padding: 4px 14px; border: 1px solid rgba(230,184,90,.4); border-radius: 999px; }
.ab-job-cta { flex-shrink: 0; }

.ab-job-body { display: grid; grid-template-columns: 2fr 1fr; gap: 40px; margin-bottom: 40px; }
.ab-job-section { margin-bottom: 32px; }
.ab-job-section h2 { color: #fff; font-size: 1.5rem; margin: 0 0 14px; letter-spacing: .01em; }
.ab-job-section p { color: var(--ab-text-dim); font-size: 1rem; line-height: 1.75; }
.ab-job-big-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.ab-job-big-list li { display: flex; align-items: flex-start; gap: 10px; color: var(--ab-text); font-size: .98rem; line-height: 1.5; padding: 10px 14px; background: rgba(255,255,255,.03); border-left: 3px solid var(--ab-brand-2); border-radius: 8px; }
.ab-job-big-list .dashicons { color: var(--ab-brand-2); font-size: 18px; width: 18px; height: 18px; margin-top: 2px; flex-shrink: 0; }

.ab-job-side { position: sticky; top: 100px; align-self: flex-start; }
.ab-job-card-info { padding: 26px 24px; border-radius: 18px; background: var(--ab-surface); border: 1px solid rgba(230,184,90,.2); }
.ab-job-card-info h3 { color: var(--ab-brand-2); font-size: .82rem; text-transform: uppercase; letter-spacing: .16em; margin: 0 0 14px; }
.ab-job-card-info dl { margin: 0 0 18px; display: grid; gap: 8px; }
.ab-job-card-info dt { color: var(--ab-text-dim); font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 600; }
.ab-job-card-info dd { margin: 0 0 6px; color: #fff; font-size: .95rem; }
.ab-job-card-info .ab-job-salary-val { color: var(--ab-brand-2); font-weight: 700; }
.ab-job-card-info .ab-btn { width: 100%; justify-content: center; }

@media (max-width: 860px) {
    .ab-job-body { grid-template-columns: 1fr; }
    .ab-job-side { position: static; }
    .ab-job-hero { flex-direction: column; align-items: flex-start; padding: 26px 22px; }
}

/* ==================================================
   Modal de postulacion (apply modal)
   ================================================== */
.ab-modal { position: fixed; inset: 0; z-index: 10000; display: none; }
.ab-modal.is-open { display: block; }
.ab-modal-overlay { position: absolute; inset: 0; background: rgba(3, 8, 22, .85); backdrop-filter: blur(8px); animation: abModalFade .25s ease; }
.ab-modal-dialog { position: relative; z-index: 2; max-width: 760px; margin: 60px auto; padding: 44px 46px; background: linear-gradient(180deg, var(--ab-bg-1), var(--ab-bg-0)); border: 1px solid rgba(230,184,90,.35); border-radius: 22px; box-shadow: 0 40px 120px rgba(5, 11, 26, .7); animation: abModalIn .35s cubic-bezier(.34,1.56,.64,1); max-height: calc(100vh - 120px); overflow-y: auto; }
@keyframes abModalFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes abModalIn { from { opacity: 0; transform: translateY(20px) scale(.97); } to { opacity: 1; transform: translateY(0) scale(1); } }
.ab-modal-close { position: absolute; top: 14px; right: 18px; background: transparent; border: 0; color: var(--ab-text-dim); font-size: 2rem; line-height: 1; cursor: pointer; padding: 6px 12px; border-radius: 50%; transition: background .2s, color .2s; }
.ab-modal-close:hover { background: rgba(230,184,90,.14); color: var(--ab-brand-2); }
.ab-modal-head { text-align: center; margin-bottom: 26px; }
.ab-modal-head .ab-kicker { justify-content: center; }
.ab-modal-head h2 { color: #fff; font-size: clamp(1.6rem, 2.6vw, 2.2rem); margin: 0 0 10px; }
.ab-modal-sub { color: var(--ab-text-dim); font-size: .98rem; }

/* States */
.ab-modal-state { display: none; }
.ab-modal[data-state=idle] .ab-modal-state-idle,
.ab-modal[data-state=error] .ab-modal-state-idle { display: block; }
.ab-modal[data-state=success] .ab-modal-state-success { display: block; }

/* Form adaptado al modal */
.ab-modal .ab-form-card { padding: 0; background: transparent; border: 0; }
.ab-modal .ab-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ab-modal .ab-form-careers select { padding: 14px 16px; border-radius: 10px; border: 1px solid rgba(255,255,255,.12); background: rgba(7,9,15,.6); color: var(--ab-text); font-family: inherit; font-size: .98rem; }
.ab-modal .ab-form-careers select:focus { outline: none; border-color: var(--ab-brand-2); }
.ab-modal .ab-form-check { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; color: var(--ab-text-dim); font-size: .88rem; }
.ab-modal .ab-form-check input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--ab-brand-2); }

/* Success state */
.ab-modal-state-success { text-align: center; padding: 20px 10px; }
.ab-modal-success-icon { display: inline-block; margin-bottom: 20px; animation: abSuccessPop .6s cubic-bezier(.34,1.56,.64,1); }
@keyframes abSuccessPop { from { opacity: 0; transform: scale(.5); } to { opacity: 1; transform: scale(1); } }
.ab-modal-state-success h2 { color: #fff; font-size: 1.8rem; margin: 0 0 12px; }
.ab-modal-state-success p { color: var(--ab-text); font-size: 1rem; line-height: 1.6; margin: 0 0 10px; max-width: 520px; margin-left: auto; margin-right: auto; }
.ab-modal-small { color: var(--ab-text-dim) !important; font-size: .88rem !important; }
.ab-modal-state-success .ab-btn { margin-top: 22px; }

/* Preview card: botones duo */
.ab-job-actions-duo { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: auto; padding-top: 12px; }
.ab-job-actions-duo .ab-btn { justify-content: center; padding: 12px 18px; font-size: .9rem; }
.ab-job-actions-duo .ab-btn-ghost { border-width: 1px; }

/* CTA block al final del listado */
.ab-careers-cta-block { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 40px 28px; margin-top: 30px; border-radius: 20px; background: linear-gradient(135deg, rgba(10,31,82,.6), rgba(230,184,90,.08)); border: 1px dashed rgba(230,184,90,.4); text-align: center; }
.ab-careers-cta-block p { color: var(--ab-text-dim); max-width: 520px; font-size: 1rem; margin: 0; }

@media (max-width: 720px) {
    .ab-modal-dialog { margin: 20px 16px; padding: 30px 22px; max-height: calc(100vh - 40px); }
    .ab-modal .ab-form-row { grid-template-columns: 1fr; }
    .ab-job-actions-duo { grid-template-columns: 1fr; }
}

/* ==================================================
   Header / Nav responsive (drawer mobile)
   ================================================== */

/* Burger button (hidden on desktop) */
.ab-burger { display: none; background: transparent; border: 0; padding: 10px 8px; cursor: pointer; z-index: 1001; position: relative; width: 44px; height: 44px; flex-shrink: 0; }
.ab-burger span { display: block; width: 26px; height: 2.5px; background: var(--ab-brand-2); margin: 5px auto; border-radius: 2px; transition: transform .28s ease, opacity .2s ease, background .2s ease; }
.ab-burger.is-active span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.ab-burger.is-active span:nth-child(2) { opacity: 0; }
.ab-burger.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.ab-burger:hover span { background: #fff; }

/* Backdrop para cerrar drawer haciendo tap fuera */
.ab-nav-backdrop { position: fixed; inset: 0; background: rgba(3, 8, 22, .82); backdrop-filter: blur(6px); opacity: 0; visibility: hidden; transition: opacity .3s ease, visibility .3s; z-index: 29; }
body.ab-nav-open .ab-nav-backdrop { opacity: 1; visibility: visible; }

@media (max-width: 980px) {
    .ab-header-inner { min-height: 70px; gap: 12px; flex-wrap: nowrap; }
    .ab-brand-logo img { max-height: 42px; }
    .ab-brand-text strong { font-size: 1rem; letter-spacing: .05em; }
    .ab-brand-text em { font-size: .58rem; padding: 2px 7px; letter-spacing: .2em; }
    .ab-burger { display: block; margin-left: auto; }

    /* Drawer: nav fijo lateral derecho */
    .ab-nav {
        position: fixed;
        top: 0; right: 0; bottom: 0;
        width: min(340px, 86vw);
        padding: 84px 24px 32px;
        background: linear-gradient(180deg, rgba(10,22,46,.99), rgba(5,11,26,.99));
        border-left: 1px solid rgba(230,184,90,.3);
        box-shadow: -20px 0 60px rgba(3, 8, 22, .8);
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
        transform: translateX(100%);
        visibility: hidden;
        transition: transform .38s cubic-bezier(.4,0,.2,1), visibility .38s;
        z-index: 30;
        overflow-y: auto;
    }
    body.ab-nav-open .ab-nav { transform: translateX(0); visibility: visible; }

    /* Items del drawer */
    .ab-nav > a, .ab-nav > .ab-nav-item {
        display: block;
        width: 100%;
        padding: 14px 16px;
        border-radius: 10px;
        font-size: 1.05rem;
        color: var(--ab-text);
        border: 1px solid transparent;
        transition: background .2s, border-color .2s, color .2s;
    }
    .ab-nav > a::after { display: none !important; }
    .ab-nav > a.is-active { background: rgba(230,184,90,.14); border-color: rgba(230,184,90,.35); color: var(--ab-brand-2); }
    .ab-nav > a:hover, .ab-nav-has-sub:hover > .ab-nav-toggle { background: rgba(230,184,90,.08); color: #fff; }

    /* Toggle padre */
    .ab-nav-has-sub { padding: 0; border: 0; }
    .ab-nav-has-sub .ab-nav-toggle {
        display: flex;
        width: 100%;
        padding: 14px 16px;
        border-radius: 10px;
        justify-content: space-between;
        align-items: center;
        color: var(--ab-text);
        font-size: 1.05rem;
        font-weight: 600;
        border: 1px solid transparent;
    }
    .ab-nav-has-sub.is-active > .ab-nav-toggle { color: var(--ab-brand-2); background: rgba(230,184,90,.14); border-color: rgba(230,184,90,.35); }
    .ab-nav-has-sub .ab-nav-toggle::after { display: none !important; }
    .ab-nav-caret { transition: transform .25s ease; }
    .ab-nav-has-sub.is-open .ab-nav-caret { transform: rotate(-180deg); }

    /* Submenu accordion */
    .ab-nav-has-sub .ab-nav-sub {
        position: static;
        opacity: 0;
        visibility: hidden;
        max-height: 0;
        overflow: hidden;
        transform: none;
        background: transparent;
        border: 0;
        box-shadow: none;
        padding: 0;
        margin: 0;
        transition: max-height .32s ease, opacity .24s ease, visibility .24s, padding .24s;
    }
    .ab-nav-has-sub .ab-nav-sub::before { display: none; }
    .ab-nav-has-sub.is-open .ab-nav-sub {
        opacity: 1;
        visibility: visible;
        max-height: 300px;
        padding: 4px 0 8px;
    }
    .ab-nav-has-sub .ab-nav-sub a {
        display: block;
        padding: 11px 14px 11px 38px;
        color: var(--ab-text-dim);
        font-size: .96rem;
        border-left: 2px solid rgba(230,184,90,.2);
        margin-left: 12px;
        border-radius: 0;
        transition: color .2s, border-color .2s, background .2s;
    }
    .ab-nav-has-sub .ab-nav-sub a:hover,
    .ab-nav-has-sub .ab-nav-sub a.is-active { color: var(--ab-brand-2); border-left-color: var(--ab-brand-2); background: rgba(230,184,90,.06); }

    /* Header actions: esconder grid launcher en mobile, CTA va dentro del drawer */
    .ab-header-actions { display: none; }
    .ab-nav::after {
        content: '';
        display: block;
        flex: 1;
    }
}

@media (max-width: 720px) {
    .ab-topbar-inner { flex-direction: column; gap: 4px; padding: 8px 0; align-items: flex-start; }
    .ab-topbar-meta { gap: 14px; flex-wrap: wrap; }
    .ab-topbar { font-size: .78rem; }
    .ab-brand-text { display: none; }
    .ab-brand-logo img { max-height: 38px; }
}

/* Fix: desactivar backdrop-filter cuando nav mobile esta abierto
   para que position:fixed del drawer trabaje contra el viewport */
body.ab-nav-open .ab-header-site { backdrop-filter: none !important; transform: none !important; }
/* Wrapper del nav en header: sin transformaciones propias */
.ab-nav-wrap { display: contents; }

@media (max-width: 980px) {
    /* El drawer salta fuera del flujo; overflow del wrap no importa */
    .ab-nav-wrap { display: block; }
}

/* Especificidad para anular reset de tema sobre <button type=button> */
button.ab-burger { display: none; background: transparent; border: 0; padding: 10px 8px; cursor: pointer; z-index: 1001; position: relative; width: 44px; height: 44px; flex-shrink: 0; }
@media (max-width: 980px) {
    button.ab-burger { display: block !important; margin-left: auto; }
}

/* ==================================================
   Grid launcher (panel de accesos rapidos)
   ================================================== */
.ab-launcher { position: relative; }
.ab-launcher .ab-grid-launcher { transition: background .2s, transform .2s; border-radius: 10px; }
.ab-launcher .ab-grid-launcher:hover { background: rgba(230,184,90,.1); transform: scale(1.05); }
.ab-launcher.is-open .ab-grid-launcher { background: rgba(230,184,90,.22); }
.ab-launcher.is-open .ab-grid-launcher span { background: var(--ab-brand-2); }

.ab-launcher-panel {
    position: absolute;
    top: calc(100% + 14px);
    right: 0;
    width: 340px;
    padding: 20px;
    background: rgba(5,11,26,.98);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(230,184,90,.3);
    border-radius: 20px;
    box-shadow: 0 30px 80px rgba(3, 8, 22, .7);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(.96);
    transform-origin: top right;
    transition: opacity .24s ease, transform .24s cubic-bezier(.34,1.4,.64,1), visibility .24s;
    z-index: 40;
}
.ab-launcher-panel::before {
    content: '';
    position: absolute;
    top: -8px;
    right: 24px;
    width: 14px;
    height: 14px;
    background: rgba(5,11,26,.98);
    border-left: 1px solid rgba(230,184,90,.3);
    border-top: 1px solid rgba(230,184,90,.3);
    transform: rotate(45deg);
}
.ab-launcher.is-open .ab-launcher-panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.ab-launcher-head { padding: 4px 4px 14px; border-bottom: 1px solid rgba(230,184,90,.14); margin-bottom: 14px; }
.ab-launcher-head strong { display: block; color: #fff; font-family: var(--ab-font-display); font-size: 1rem; letter-spacing: .06em; text-transform: uppercase; }
.ab-launcher-head span { display: block; color: var(--ab-text-dim); font-size: .8rem; margin-top: 3px; }

.ab-launcher-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.ab-launcher-item {
    --ab-li: var(--ab-brand-2);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 14px 8px;
    border-radius: 12px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(230,184,90,.14);
    color: var(--ab-text-dim);
    font-size: .74rem;
    font-weight: 600;
    letter-spacing: .02em;
    text-align: center;
    text-decoration: none;
    transition: all .22s ease;
}
.ab-launcher-item:hover {
    background: color-mix(in srgb, var(--ab-li) 18%, transparent);
    border-color: var(--ab-li);
    color: #fff;
    transform: translateY(-2px);
}
.ab-launcher-icon {
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--ab-li) 16%, rgba(255,255,255,.04));
    color: var(--ab-li);
    transition: all .22s ease;
}
.ab-launcher-icon .dashicons { font-size: 22px; width: 22px; height: 22px; line-height: 1; }
.ab-launcher-icon svg { display: block; }
.ab-launcher-item:hover .ab-launcher-icon {
    background: var(--ab-li);
    color: #fff;
    transform: scale(1.06);
}
.ab-launcher-label { color: inherit; }

@media (max-width: 720px) {
    .ab-launcher-panel { width: calc(100vw - 28px); right: -8px; }
}

/* Ocultar topbar en mobile (mejor uso del espacio) */
@media (max-width: 720px) {
    .ab-topbar { display: none; }
}

/* Mobile hero: mostrar solo titulo + 1 CTA, ocultar lo demas */
@media (max-width: 720px) {
    .ab-hero-grid { padding: 40px 22px 44px; min-height: auto; }
    .ab-hero-badge { display: none; }
    .ab-hero-copy-text { display: none; }
    .ab-hero-seal { display: none; }
    .ab-hero-stats-side { display: none; }
    .ab-hero-figure { display: none; }
    .ab-hero-word-outline, .ab-hero-word-solid { display: none; }
    .ab-hero-title { font-size: clamp(2rem, 9vw, 2.8rem); line-height: 1.08; margin-bottom: 18px; }
    .ab-hero-actions { flex-direction: column; gap: 10px; }
    .ab-hero-actions .ab-btn { width: 100%; justify-content: center; }
    /* Ocultar la segunda CTA (ver servicios), dejar solo el primario */
    .ab-hero-actions .ab-btn-ghost { display: none; }
}

/* Hero mobile: forzar ocultar con alta especificidad */
@media (max-width: 720px) {
    body.ab-body .ab-hero-stats-side,
    body.ab-body .ab-hero-seal,
    body.ab-body .ab-hero-badge,
    body.ab-body .ab-hero-copy-text,
    body.ab-body .ab-hero-figure,
    body.ab-body .ab-hero-word-outline,
    body.ab-body .ab-hero-word-solid,
    body.ab-body .ab-hero-actions .ab-btn-ghost { display: none !important; }
}

/* Logo horizontal: icono transparente a la izquierda + texto a la derecha */
.ab-brand-logo { display: inline-flex !important; align-items: center; gap: 12px; }
.ab-logo-img { max-height: 52px; width: auto; background: transparent; }
.ab-footer .ab-logo-img { max-height: 48px; }
.ab-brand-logo .ab-brand-text { display: flex !important; flex-direction: column; line-height: 1; gap: 4px; }
.ab-brand-logo .ab-brand-text strong { font-family: var(--ab-font-display); font-size: 1.15rem; letter-spacing: .06em; color: #fff; font-weight: 800; text-transform: uppercase; }
.ab-brand-logo .ab-brand-text em { font-style: normal; font-size: .64rem; color: #0a1f52; background: linear-gradient(90deg,#d9a944,var(--ab-brand-2)); padding: 2px 10px; border-radius: 3px; letter-spacing: .28em; font-weight: 800; width: fit-content; }
.ab-footer .ab-brand-logo .ab-brand-text strong { color: #fff; }
@media (max-width: 720px) {
    .ab-brand-logo .ab-logo-img { max-height: 42px; }
    .ab-brand-logo .ab-brand-text strong { font-size: .98rem; }
    .ab-brand-logo .ab-brand-text em { font-size: .58rem; letter-spacing: .22em; }
}
