/* ============================================================
   LANN SEGUROS — estilos.css  v3.2
   Verde oscuro #025a41 · Verde #55c874 · Montserrat
============================================================ */

:root {
    --green-dark:  #025a41;
    --green-mid:   #03754f;
    --green-deep:  #013d2b;
    --green-light: #55c874;
    --green-pale:  #6fd585;
    --accent:      #fffae4;
    --white:       #ffffff;
    --text-dark:   #0f1f18;
    --text-mid:    #3a4f44;
    --text-soft:   #6b8278;
    --border:      #d4e4dc;
    --bg-soft:     #f4f9f6;
    --grad-main:   linear-gradient(135deg, #55c874 0%, #025a41 100%);
    --grad-dark:   linear-gradient(135deg, #025a41 0%, #013d2b 100%);
    --grad-glow:   linear-gradient(135deg, rgba(85,200,116,.12) 0%, rgba(2,90,65,.08) 100%);
    --shadow-sm:   0 2px 8px  rgba(2,90,65,.08);
    --shadow-md:   0 8px 24px rgba(2,90,65,.12);
    --shadow-lg:   0 20px 48px rgba(2,90,65,.18);
    --shadow-xl:   0 32px 64px rgba(2,90,65,.22);
    --r-sm:   .5rem;
    --r-md:   .875rem;
    --r-lg:   1.25rem;
    --r-xl:   2rem;
    --r-full: 9999px;
    --topbar-h: 38px;
    --nav-h:    68px;
    --t:      .3s cubic-bezier(.4,0,.2,1);
    --t-slow: .6s cubic-bezier(.4,0,.2,1);
}

/* ─────────────────── RESET ─────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; scroll-padding-top:calc(var(--topbar-h) + var(--nav-h)) }
body { font-family:'Montserrat',sans-serif; font-size:16px; line-height:1.65;
       color:var(--text-dark); background:var(--white);
       overflow-x:hidden; -webkit-font-smoothing:antialiased }
img  { max-width:100%; height:auto; display:block }
a    { text-decoration:none; color:inherit; transition:all var(--t) }
ul   { list-style:none }
button { border:none; background:none; cursor:pointer; font-family:inherit }
.container { max-width:1280px; margin:0 auto; padding:0 2rem }

/* ─────────────────── UTILITIES ─────────────────── */
.section-tag {
    display:inline-flex; align-items:center; gap:.4rem;
    padding:.42rem .95rem;
    background:var(--grad-glow); color:var(--green-dark);
    font-size:.75rem; font-weight:700; text-transform:uppercase;
    letter-spacing:1.5px; border-radius:var(--r-full);
    margin-bottom:.9rem; border:1px solid rgba(2,90,65,.15);
}
.section-tag.light {
    background:rgba(255,250,228,.15); color:var(--accent);
    border-color:rgba(255,250,228,.2);
}
.section-title { font-size:2.5rem; font-weight:800; line-height:1.1; color:var(--green-dark); margin-bottom:1rem }
.section-title.light { color:var(--white) }
.g-text     { background:var(--grad-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.g-text-alt { background:linear-gradient(135deg,#fffae4,#55c874); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.tc         { text-align:center }
.sec-hdr-c  { text-align:center; max-width:720px; margin:0 auto 2.5rem }
.sec-desc   { font-size:1rem; color:var(--text-mid); line-height:1.8; margin-top:.5rem }

/* ─────────────────── TOPBAR ─────────────────── */
.topbar {
    background: var(--green-deep);
    color: rgba(255,255,255,.9);
    height: var(--topbar-h);
    display: flex;
    align-items: center;
    font-size: .75rem;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1001;
}
/* CAMBIO 2: topbar-content con justify-content space-between */
.topbar-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .75rem;
    width: 100%;
}
/* CAMBIO 2: texto a la izquierda */
.topbar-left {
    display: flex;
    align-items: center;
}
.topbar-ayuda {
    color: rgba(255,255,255,.85);
    font-size: .75rem;
    font-weight: 600;
    white-space: nowrap;
}
.topbar-right { display:flex; align-items:center; gap:.75rem; }
.topbar-link  { color:rgba(255,255,255,.85); display:flex; align-items:center; gap:.35rem; font-weight:600; white-space:nowrap; font-size:.75rem; }
.topbar-link:hover { color:var(--white) }
.topbar-wa {
    display:inline-flex; align-items:center; gap:.35rem;
    background:#25D366; color:var(--white)!important;
    padding:.22rem .7rem; border-radius:var(--r-full);
    font-weight:700; transition:all var(--t); white-space:nowrap; font-size:.75rem;
}
.topbar-wa:hover { background:#1ebe5c; transform:translateY(-1px) }
.topbar-icon-link {
    display:inline-flex; align-items:center; justify-content:center;
    width:26px; height:26px;
    color:rgba(255,255,255,.75);
    border-radius:var(--r-sm);
    transition:all var(--t);
}
.topbar-icon-link:hover { color:var(--white); background:rgba(255,255,255,.12); }

/* ─────────────────── HEADER — ESTÁTICO ─────────────────── */
.header {
    position: sticky;
    top: var(--topbar-h);
    left: 0;
    width: 100%;
    background: rgba(255,255,255,0.97);
    box-shadow: 0 2px 16px rgba(2,90,65,.08);
    z-index: 100;
}

body { padding-top: var(--topbar-h); }

.nav { display:flex; align-items:center; justify-content:space-between; height:var(--nav-h) }

/* ── Logo ── */
.nav-logo { display:flex; align-items:center; gap:.65rem }
.logo-icon img { width:52px; height:52px; object-fit:contain; image-rendering:crisp-edges }
.logo-text-container { display:flex; flex-direction:column; line-height:1 }
.logo-text    { font-size:1.75rem; font-weight:800; letter-spacing:.02em; text-transform:uppercase; color:var(--green-dark) }
.logo-subtext { font-size:.72rem; font-weight:600; letter-spacing:.05em; color:var(--text-soft) }

/* ── Links inline desktop ── */
.desktop-nav { display:flex; align-items:center; gap:2.25rem; list-style:none }
.nav-link  { font-weight:600; font-size:.9rem; color:var(--text-dark); position:relative; padding:.4rem 0; transition:color var(--t) }
.nav-link::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--green-light); border-radius:2px; transition:width var(--t) }
.nav-link:hover::after,.nav-link.active::after { width:100% }
.nav-link:hover,.nav-link.active { color:var(--green-dark) }

.nav-actions { display:flex; align-items:center; gap:1rem }
.nav-toggle  { display:none; color:var(--green-dark); cursor:pointer; background:none; border:none; padding:.25rem }

/* ── Overlay ── */
.nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.52);
    z-index: 9000;
    cursor: pointer;
}
.nav-overlay.show { display: block }

/* ── Drawer móvil ── */
.nav-drawer {
    position: fixed;
    top: 0;
    right: 0;
    width: 78%;
    max-width: 280px;
    height: 100vh;
    background: #fff;
    z-index: 9100;
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1.5rem 2rem;
    box-shadow: -6px 0 30px rgba(0,0,0,.2);
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
}
.nav-drawer.show { transform: translateX(0) }

.nav-close {
    align-self: flex-end;
    background: none; border: none;
    color: var(--green-dark);
    cursor: pointer; padding: .25rem;
    margin-bottom: 1.5rem;
}

.nav-drawer-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    width: 100%;
}
.nav-drawer-list li { border-bottom: 1px solid var(--border); }
.nav-drawer-list .nav-link {
    display: block;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text-dark);
    padding: 1rem 0;
    width: 100%;
}

/* ─────────────────── HERO ─────────────────── */
.hero {
    position: relative;
    min-height: calc(100svh - var(--topbar-h) - var(--nav-h));
    display: flex;
    align-items: center;
    overflow: hidden;
}
.hero-bg      { position:absolute; inset:0; z-index:0 }
.hero-bg-img  { width:100%; height:100%; object-fit:cover; filter:saturate(1.1) }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(1,61,43,.9) 0%,rgba(2,90,65,.78) 50%,rgba(1,61,43,.65) 100%) }
.hero-pattern { position:absolute; inset:0; background-image:radial-gradient(rgba(85,200,116,.07) 1px,transparent 1px); background-size:32px 32px }

.hero-particles { position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden }
.particle { position:absolute; border-radius:50%; opacity:.15; animation:floatParticle 8s ease-in-out infinite }
.p1 { width:280px;height:280px;background:var(--green-light);top:-80px;right:-60px;animation-duration:9s }
.p2 { width:180px;height:180px;background:var(--accent);bottom:-40px;left:-40px;animation-duration:11s;animation-delay:-3s }
.p3 { width:120px;height:120px;background:var(--green-light);top:30%;left:10%;animation-duration:7s;animation-delay:-2s }
.p4 { width:80px;height:80px;background:var(--accent);top:20%;right:20%;animation-duration:13s;animation-delay:-5s }
.p5 { width:60px;height:60px;background:var(--green-pale);bottom:20%;right:5%;animation-duration:10s;animation-delay:-1s }
.p6 { width:200px;height:200px;background:rgba(2,90,65,.5);bottom:10%;left:30%;animation-duration:14s;animation-delay:-4s }
@keyframes floatParticle { 0%,100%{transform:translateY(0) rotate(0deg)} 33%{transform:translateY(-22px) rotate(8deg)} 66%{transform:translateY(14px) rotate(-5deg)} }

.hero-container {
    position: relative;
    z-index: 2;
    padding-top: 3rem;
    padding-bottom: 6rem;
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
}
.hero-badge   { display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .85rem;background:rgba(255,250,228,.15);border:1px solid rgba(255,250,228,.3);border-radius:var(--r-full);color:var(--accent);font-size:.72rem;font-weight:700;backdrop-filter:blur(8px);margin-bottom:1rem;width:fit-content;text-decoration:none;transition:all var(--t);cursor:pointer; }
.hero-badge:hover { background:rgba(255,250,228,.25); border-color:rgba(255,250,228,.55); transform:translateY(-1px); }
.hero-badge svg { color:var(--green-light);flex-shrink:0 }
.hero-title   { font-size:4rem;font-weight:900;line-height:1.02;color:var(--white);margin-bottom:1.1rem;letter-spacing:-.025em }
.hero-accent  { background:linear-gradient(135deg,#55c874,#fffae4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text }
.hero-desc    { font-size:1.05rem;color:rgba(255,255,255,.85);line-height:1.82;max-width:560px;margin-bottom:2rem }
.hero-btns    { display:flex;gap:.85rem;flex-wrap:wrap }
.btn-primary-hero { display:inline-flex;align-items:center;gap:.55rem;padding:.9rem 1.85rem;background:var(--green-light);color:var(--green-deep);font-weight:800;font-size:.94rem;border-radius:var(--r-full);box-shadow:0 4px 20px rgba(85,200,116,.4);transition:all var(--t);border:2px solid transparent }
.btn-primary-hero:hover { background:var(--white);color:var(--green-dark);transform:translateY(-3px);box-shadow:0 8px 32px rgba(85,200,116,.5) }
.btn-ghost-hero { display:inline-flex;align-items:center;gap:.55rem;padding:.9rem 1.85rem;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.4);color:var(--white);font-weight:700;font-size:.94rem;border-radius:var(--r-full);backdrop-filter:blur(8px);transition:all var(--t) }
.btn-ghost-hero:hover { background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.65);transform:translateY(-3px) }

.hero-stats-row { display:flex;align-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-xl);backdrop-filter:blur(16px);padding:1.2rem 1.5rem;width:fit-content;max-width:100% }
.stat-card    { text-align:center;padding:0 1.4rem }
.stat-icon    { color:var(--green-light);margin-bottom:.3rem;opacity:.9 }
.stat-num     { font-size:1.65rem;font-weight:900;color:var(--green-light);line-height:1;margin-bottom:.25rem }
.stat-lbl     { font-size:.7rem;color:rgba(255,255,255,.8);font-weight:600;line-height:1.4;white-space:nowrap }
.stat-divider { width:1px;height:42px;background:rgba(255,255,255,.2);flex-shrink:0 }
.hero-scroll  { position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:3;animation:bounce 2s ease-in-out infinite }
.scroll-mouse { width:24px;height:38px;border:2px solid rgba(255,255,255,.45);border-radius:12px;display:flex;justify-content:center;padding-top:5px }
.scroll-wheel { width:3px;height:7px;background:rgba(255,255,255,.6);border-radius:2px;animation:scrollWheel 2s ease-in-out infinite }
@keyframes scrollWheel { 0%,100%{opacity:1;transform:translateY(0)} 50%{opacity:.3;transform:translateY(8px)} }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(-8px)} }

/* ─────────────────── NOSOTROS ─────────────────── */
.about { padding:5rem 0; background:var(--white) }

.about-wrap {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 3.5rem;
    align-items: center;
    margin-bottom: 3rem;
}

.about-visual        { position:relative; padding-bottom:50px }
.about-main-img      { position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-xl); z-index:1 }
.about-main-img img  { width:100%; height:440px; object-fit:cover; display:block; transition:transform .8s ease }
.about-main-img:hover img { transform:scale(1.03) }
.about-main-overlay  { position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(1,61,43,.35) 100%); pointer-events:none }
.about-float-img     { position:absolute; bottom:0; right:-26px; z-index:2; width:175px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-xl); border:4px solid var(--white) }
.about-float-img img { width:100%; height:140px; object-fit:cover; display:block }
.about-years-badge   { position:absolute; top:-16px; left:-16px; z-index:3; background:var(--grad-main); color:var(--white); border-radius:var(--r-lg); padding:1rem 1.3rem; text-align:center; box-shadow:var(--shadow-lg) }
.aby-num { display:block; font-size:2.4rem; font-weight:900; line-height:1 }
.aby-txt { display:block; font-size:.68rem; font-weight:600; opacity:.9; line-height:1.3; margin-top:.15rem }

.about-lead { font-size:1.06rem; font-weight:600; color:var(--green-dark); line-height:1.8; margin-bottom:.9rem; border-left:3px solid var(--green-light); padding-left:1rem }
.about-body { font-size:.93rem; color:var(--text-mid); line-height:1.85; margin-bottom:.75rem }
.about-body:last-of-type { margin-bottom:0 }

.certs-row { display:flex; gap:.65rem; flex-wrap:wrap; margin-top:1.25rem }
.cert-pill  { display:inline-flex; align-items:center; gap:.45rem; padding:.48rem 1rem; background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-full); color:var(--green-dark); font-size:.78rem; font-weight:700; transition:all var(--t); box-shadow:var(--shadow-sm) }
.cert-pill:hover { border-color:var(--green-light); box-shadow:var(--shadow-md); transform:translateY(-2px); color:var(--green-mid) }

/* CAMBIO 1: cert pill en 2 líneas */
.cert-pill-multiline {
    align-items: center;
    border-radius: var(--r-lg);
    padding: .55rem 1rem;
}
.cert-pill-text {
    display: flex;
    flex-direction: column;
    gap: .1rem;
    line-height: 1.3;
}
.cert-pill-nit {
    font-size: .72rem;
    font-weight: 800;
    color: var(--green-mid);
    opacity: .9;
}

.about-bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.75rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
}
.about-block {
    background: var(--bg-soft);
    border: 1.5px solid var(--border);
    border-radius: var(--r-xl);
    padding: 1.75rem;
}
.about-block-title {
    font-size: 1.02rem; font-weight: 800; color: var(--green-dark);
    margin-bottom: 1rem;
    display: flex; align-items: center; gap: .52rem;
}
.about-block-title::before {
    content: ''; display: inline-block;
    width: 4px; height: 1em;
    background: var(--green-light); border-radius: 3px; flex-shrink: 0;
}
.about-block .about-body { font-size:.9rem }

.pillars { display:flex; flex-direction:column; gap:.6rem; margin-top:.75rem }
.pillar  { display:flex; align-items:flex-start; gap:.8rem; padding:.85rem 1rem; background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-md); transition:all var(--t) }
.pillar:hover { border-color:var(--green-light); box-shadow:var(--shadow-sm); transform:translateX(3px) }
.pillar-icon  { width:38px; height:38px; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:var(--grad-main); border-radius:var(--r-sm); color:var(--white) }
.pillar-text strong { display:block; font-size:.9rem; color:var(--green-dark); font-weight:800; margin-bottom:.18rem }
.pillar-text p      { font-size:.82rem; color:var(--text-soft); line-height:1.5; margin:0 }

.about-block-esencia { display:flex; flex-direction:column }
.about-quote  { display:block; font-size:.97rem; font-style:italic; font-weight:700; color:var(--green-dark); line-height:1.7; padding:1rem 1.3rem; background:rgba(85,200,116,.1); border-left:4px solid var(--green-light); border-radius:0 var(--r-md) var(--r-md) 0; margin:1rem 0 }
.quote-mark   { font-size:1.4rem; color:var(--green-light); font-style:normal; line-height:0; vertical-align:-.2em; margin:0 .1rem }
.about-cierre { display:flex; flex-direction:column; padding:.85rem 1.1rem; background:var(--grad-dark); border-radius:var(--r-md); margin-top:auto }
.cierre-nombre  { font-size:1rem; font-weight:900; color:var(--green-light); letter-spacing:.03em }
.cierre-tagline { font-size:.84rem; color:rgba(255,255,255,.75); font-style:italic; font-weight:500; margin-top:.12rem }

/* ─────────────────── ALIADAS ─────────────────── */
.allies { padding:4rem 0; background:var(--bg-soft); overflow:hidden }
.allies-track-wrap { position:relative; margin-top:2rem }
.allies-track { display:flex; gap:1.25rem; animation:scrollTrack 28s linear infinite; width:max-content }
.allies-track:hover { animation-play-state:paused }
@keyframes scrollTrack { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ally-card { flex-shrink:0; width:180px; height:100px; background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-lg); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem; padding:1rem; box-shadow:var(--shadow-sm); transition:all var(--t); cursor:default }
.ally-card:hover { border-color:var(--green-light); box-shadow:var(--shadow-md); transform:translateY(-4px) }
.ally-card img   { max-width:110px; max-height:44px; object-fit:contain; filter:grayscale(30%); transition:filter var(--t) }
.ally-card:hover img { filter:grayscale(0) }
.ally-card span  { font-size:.72rem; font-weight:700; color:var(--text-mid); text-align:center }
.ally-text  { background:var(--grad-glow) }
.ally-icon  { color:var(--green-dark); opacity:.6 }
.ally-text span { font-size:.8rem; font-weight:700; color:var(--green-dark) }

/* ─────────────────── SEGUROS ─────────────────── */
.services    { padding:5rem 0; background:var(--bg-soft); position:relative; overflow:hidden }
.svc-bg-blob { position:absolute; top:-200px; right:-200px; width:600px; height:600px; background:radial-gradient(circle,rgba(85,200,116,.08) 0%,transparent 70%); border-radius:50%; pointer-events:none }
.svc-duo     { display:grid; grid-template-columns:1fr 1fr; gap:2rem }
.svc-duo-card { background:var(--white); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-md); border:1.5px solid var(--border); display:flex; flex-direction:column; transition:transform var(--t-slow),box-shadow var(--t-slow) }
.svc-duo-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-xl) }
.svc-duo-img  { position:relative; height:260px; overflow:hidden }
.svc-duo-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s ease }
.svc-duo-card:hover .svc-duo-img img { transform:scale(1.06) }
.svc-duo-overlay { position:absolute; inset:0; background:linear-gradient(170deg,rgba(1,61,43,.35) 0%,rgba(1,61,43,.72) 100%) }
.svc-duo-top  { position:absolute; top:1.25rem; left:1.25rem; display:flex; align-items:center; gap:.5rem; z-index:2 }
.svc-duo-icon { width:36px; height:36px; background:rgba(255,255,255,.18); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.3); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; color:var(--white) }
.svc-duo-cat  { color:var(--white); font-size:.8rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; background:rgba(255,255,255,.12); backdrop-filter:blur(6px); padding:.3rem .75rem; border-radius:var(--r-full); border:1px solid rgba(255,255,255,.25) }
.svc-duo-title-img { position:absolute; bottom:1.25rem; left:1.5rem; z-index:2; color:var(--white); font-size:1.5rem; font-weight:700; line-height:1.2; text-shadow:0 2px 12px rgba(0,0,0,.3) }
.svc-duo-title-img strong { font-weight:900; color:var(--green-light); display:block; font-size:1.75rem }
.svc-duo-body { padding:1.75rem; flex:1; display:flex; flex-direction:column }
.svc-duo-desc { font-size:.93rem; color:var(--text-mid); line-height:1.7; margin-bottom:1.25rem }
.svc-chip-grid { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1rem }
.svc-chip      { display:inline-flex; align-items:center; gap:.4rem; padding:.4rem .85rem; background:var(--bg-soft); border:1.5px solid var(--border); border-radius:var(--r-full); font-size:.82rem; font-weight:600; color:var(--text-dark); transition:all var(--t); cursor:default }
.svc-chip:hover { background:rgba(85,200,116,.12); border-color:var(--green-light); color:var(--green-dark) }
.svc-chip-ico  { display:flex; align-items:center; color:var(--green-mid) }
.svc-note      { font-size:.75rem; color:var(--text-soft); font-style:italic; margin-bottom:.9rem }
.svc-duo-cta   { display:inline-flex; align-items:center; gap:.5rem; margin-top:auto; padding:.7rem 1.4rem; background:var(--grad-main); color:var(--white); font-weight:700; font-size:.88rem; border-radius:var(--r-full); box-shadow:var(--shadow-sm); transition:all var(--t); width:fit-content }
.svc-duo-cta:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); gap:.75rem }

/* ─────────────────── COTIZAR ─────────────────── */
.quote { padding:5rem 0; background:var(--grad-dark); position:relative; overflow:hidden }
.quote::before { content:''; position:absolute; top:-100px; right:-100px; width:500px; height:500px; background:radial-gradient(circle,rgba(85,200,116,.08) 0%,transparent 60%); border-radius:50% }
.quote-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; position:relative; z-index:1 }
.quote-desc   { color:rgba(255,255,255,.85); font-size:1rem; line-height:1.85; margin-bottom:1.75rem }
.quote-feats  { display:flex; flex-direction:column; gap:.9rem; margin-bottom:1.75rem }
.qf           { display:flex; gap:.85rem; align-items:flex-start }
.qf-ico       { width:36px; height:36px; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:rgba(85,200,116,.2); border-radius:var(--r-sm); color:var(--green-light) }
.qf strong    { display:block; color:var(--white); font-size:.95rem; margin-bottom:.15rem }
.qf p         { color:rgba(255,255,255,.75); font-size:.86rem; margin:0 }
.quote-form-wrap { background:var(--white); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-xl) }
.qform-head   { background:var(--grad-main); padding:1.5rem 1.75rem }
.qform-head h3 { color:var(--white); font-size:1.2rem; font-weight:800; margin-bottom:.2rem }
.qform-head p  { color:rgba(255,255,255,.82); font-size:.88rem }
.quote-form   { padding:1.75rem; display:flex; flex-direction:column; gap:.9rem }
.form-row     { display:grid; grid-template-columns:1fr 1fr; gap:.9rem }
.form-group   { display:flex; flex-direction:column; gap:.35rem }
.form-group label { font-size:.84rem; font-weight:700; color:var(--text-dark) }
.form-group input,
.form-group select,
.form-group textarea { padding:.75rem 1rem; border:2px solid var(--border); border-radius:var(--r-md); font-family:inherit; font-size:.94rem; color:var(--text-dark); transition:all var(--t); background:var(--white) }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--green-mid); box-shadow:0 0 0 3px rgba(2,90,65,.1) }
.form-group textarea { resize:vertical; min-height:80px }
.btn-submit   { display:flex; align-items:center; justify-content:center; gap:.6rem; width:100%; padding:.95rem; background:var(--grad-main); color:var(--white); font-weight:800; font-size:.96rem; border-radius:var(--r-md); border:none; cursor:pointer; transition:all var(--t); box-shadow:var(--shadow-md) }
.btn-submit:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg) }
.form-privacy { font-size:.75rem; color:var(--text-soft); text-align:center; line-height:1.5 }

/* ─────────────────── CONTACTO ─────────────────── */
.contact { padding:5rem 0; background:var(--bg-soft) }
.contact-cards   { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem }
.contact-cards-3 { grid-template-columns:repeat(3,1fr); max-width:860px; margin:0 auto }
.contact-card  { background:var(--white); border-radius:var(--r-xl); padding:2rem 1.5rem; text-align:center; box-shadow:var(--shadow-sm); border:1.5px solid var(--border); transition:all var(--t-slow) }
.contact-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:var(--green-light) }
.cc-icon       { width:60px; height:60px; display:flex; align-items:center; justify-content:center; background:var(--grad-main); border-radius:50%; color:var(--white); margin:0 auto 1.1rem }
.contact-card h3 { font-size:1.05rem; font-weight:700; color:var(--green-dark); margin-bottom:.7rem }
.cc-val        { display:block; color:var(--text-mid); font-size:.9rem; font-weight:500; margin-bottom:.3rem; transition:color var(--t) }
a.cc-val:hover { color:var(--green-mid) }

/* ─────────────────── FOOTER ─────────────────── */
.footer { background:var(--green-deep); color:var(--white); padding:3rem 0 1.25rem }
.footer-top { display:grid; grid-template-columns:2fr 3fr; gap:3rem; margin-bottom:2rem; padding-bottom:2rem; border-bottom:1px solid rgba(255,255,255,.1) }
.footer-brand { max-width:380px }
.footer-logo  { display:flex; align-items:center; gap:.75rem; margin-bottom:1.1rem }
.footer-logo .logo-text    { color:var(--white) }
.footer-logo .logo-subtext { color:rgba(255,255,255,.65) }
.footer-desc  { color:rgba(255,255,255,.75); font-size:.9rem; line-height:1.75; margin-bottom:1.25rem }
.social-links { display:flex; gap:.7rem }
.social-link  { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.1); border-radius:var(--r-md); color:var(--white); transition:all var(--t) }
.social-link:hover { background:var(--green-light); color:var(--green-deep); transform:translateY(-3px) }
.footer-links { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem }
.footer-col h4 { font-size:.9rem; font-weight:800; margin-bottom:.9rem; text-transform:uppercase; letter-spacing:.08em; color:var(--green-light) }
.footer-col ul { display:flex; flex-direction:column; gap:.55rem }
.footer-col a  { color:rgba(255,255,255,.7); font-size:.87rem }
.footer-col a:hover { color:var(--green-light); padding-left:4px }
.footer-bottom { text-align:center; color:rgba(255,255,255,.5); font-size:.82rem; padding-top:1rem }
.footer-bottom p { margin-bottom:.3rem }

/* ─────────────────── BOTONES FLOTANTES ─────────────────── */
.wa-float {
    position: fixed;
    right: 1.5rem;
    bottom: 5.5rem;
    width: 54px; height: 54px;
    border-radius: 50%;
    background: #25D366;
    color: var(--white);
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 6px 22px rgba(37,211,102,.45);
    z-index: 1000;
    transition: all var(--t);
    overflow: visible;
}
.wa-float svg     { display:block; flex-shrink:0 }
.wa-float:hover   { transform:translateY(-4px) scale(1.07); box-shadow:0 10px 30px rgba(37,211,102,.55) }
.wa-tip {
    position: absolute;
    right: calc(100% + .7rem);
    top: 50%; transform: translateY(-50%);
    background: var(--green-deep); color: var(--white);
    font-family: 'Montserrat', sans-serif;
    font-size: .74rem; font-weight: 700;
    white-space: nowrap; padding: .36rem .78rem;
    border-radius: var(--r-full);
    opacity: 0; pointer-events: none;
    transition: opacity var(--t);
}
.wa-float:hover .wa-tip { opacity:1 }

.scroll-top {
    position: fixed;
    right: 1.5rem;
    bottom: 1.5rem;
    width: 46px; height: 46px;
    background: var(--grad-main);
    color: var(--white);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-lg);
    opacity: 0; visibility: hidden;
    transition: all var(--t);
    z-index: 999;
    border: none; cursor: pointer;
}
.scroll-top.show  { opacity:1; visibility:visible }
.scroll-top:hover { transform:translateY(-4px); box-shadow:var(--shadow-xl) }

/* ─────────────────── RESPONSIVE ─────────────────── */
@media (max-width:1024px) {
    .container { padding:0 1.5rem }
    .hero-title { font-size:3.2rem }
    .about-wrap { grid-template-columns:1fr; gap:2.5rem }
    .about-visual { max-width:520px; margin:0 auto; padding-bottom:40px }
    .about-bottom { grid-template-columns:1fr; gap:1.5rem }
    .hero-stats-row { flex-wrap:wrap }
    .contact-cards { grid-template-columns:repeat(2,1fr) }
    .contact-cards-3 { grid-template-columns:repeat(3,1fr) }
    .quote-grid { grid-template-columns:1fr; gap:2.5rem }
    .svc-duo { grid-template-columns:1fr; max-width:600px; margin:0 auto }
}

@media (max-width:768px) {
    :root {
        --topbar-h: 36px;
        --nav-h:    60px;
    }

    .hero-title    { font-size:2.2rem }
    .section-title { font-size:1.85rem }

    .topbar { font-size:.7rem }
    .topbar-content { padding: 0 1rem }
    .topbar-link { font-size:.7rem }
    .topbar-wa { padding:.2rem .55rem; font-size:.7rem }
    /* Ocultar texto ayuda en móvil para no saturar */
    .topbar-ayuda { display: none }

    .hero-badge { font-size:.65rem; padding:.35rem .7rem; gap:.35rem }
    .hero-badge svg { width:11px; height:11px }
    .hero-desc { font-size:.93rem }
    .hero-stats-row { padding:.9rem 1rem; gap:0; width:100%; justify-content:space-around }
    .stat-card { padding:0 .6rem }
    .stat-num  { font-size:1.35rem }
    .stat-lbl  { font-size:.62rem }
    .stat-icon { display:none }
    .stat-divider { height:36px }

    .contact-cards   { grid-template-columns:1fr 1fr }
    .contact-cards-3 { grid-template-columns:1fr; max-width:100% }
    .svc-duo { max-width:100% }

    .desktop-nav { display: none }
    .nav-toggle  { display: flex }

    .footer-top { grid-template-columns:1fr }
    .footer-links { grid-template-columns:1fr 1fr }
    .form-row { grid-template-columns:1fr }

    .wa-float   { width:50px; height:50px; bottom:5rem; right:1.1rem }
    .scroll-top { width:42px; height:42px; bottom:1.25rem; right:1.1rem }
}

@media (max-width:480px) {
    :root {
        --topbar-h: 34px;
        --nav-h:    56px;
    }

    .container { padding:0 1rem }

    .topbar-content { padding:0 .75rem }
    .topbar-link { display:none }
    .topbar-wa { display:inline-flex }

    .hero-title { font-size:1.9rem }
    .hero-container { padding-top:2rem; padding-bottom:4rem; gap:1.75rem }
    .hero-btns { flex-direction:column; gap:.6rem }
    .btn-primary-hero,
    .btn-ghost-hero { width:100%; justify-content:center; font-size:.88rem; padding:.82rem 1.4rem }

    .hero-stats-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .75rem;
        background: rgba(255,255,255,.08);
        padding: 1rem;
        width: 100%;
    }
    .stat-card  { padding:.75rem .5rem; background:rgba(255,255,255,.07); border-radius:var(--r-md) }
    .stat-divider { display:none }
    .stat-num   { font-size:1.4rem }
    .stat-lbl   { font-size:.62rem; white-space:normal; line-height:1.3 }

    .contact-cards { grid-template-columns:1fr }
    .footer-links   { grid-template-columns:1fr }
    .about-float-img { display:none }
    .about-years-badge { top:10px; left:10px }

    .logo-text  { font-size:1.45rem }
    .logo-subtext { font-size:.65rem }
    .logo-icon img { width:42px; height:42px }
}