/* ===== ESTILOS GLOBALES / VARIABLES DE MARCA ===== */
    :root{--bg:#ececec;--bg-2:#f3f3f3;--bg-dark:#040404;--teal:#78E6D0;--teal-2:#26d6cb;--teal-3:#0a7f8a;--ink:#111111;--ink-soft:#18353a;--muted:#5d5d5d;--white:#ffffff;--panel:#b9efea;--panel-2:#0a393d;--radius:22px;--shadow:0 18px 44px rgba(0,0,0,.12);--container:1180px;--header-h:2cm;}
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;font-family:'TT Norms Pro','TT Norms',Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
    a{text-decoration:none;color:inherit}
    img{max-width:100%;display:block}
    .container{max-width:var(--container);margin:0 auto;padding:0 28px}
    section[id]{scroll-margin-top:calc(var(--header-h) + 12px)}

        /* ===== NAVBAR / MENÚ PRINCIPAL ===== */
    .navbar{background:rgba(243,246,245,.98);position:sticky;top:0;z-index:1000;box-shadow:0 1px 0 rgba(0,0,0,.04);backdrop-filter:blur(12px);transition:background .28s ease, box-shadow .28s ease}
    .navbar.scrolled{background:rgba(243,246,245,.82);box-shadow:0 8px 24px rgba(0,0,0,.06)}
    .navbar .container{display:flex;align-items:center;justify-content:space-between;padding-top:0;padding-bottom:0;min-height:var(--header-h)}
    .brand img{width:132px;height:auto}
    .menu-toggle{display:none}
    .navlinks{display:flex;gap:28px;align-items:center;font-weight:700;flex-wrap:wrap;justify-content:flex-end}
    .navlinks a{font-size:16px;position:relative;transition:color .25s ease}
    .navlinks a:hover,.navlinks a.active{color:var(--teal-2)}
    .navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;border-radius:999px;background:var(--teal-2)}

    .page{display:none}
    .page.active{display:block}

    .section-tag{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;background:rgba(120,230,208,.2);color:#2f7d83;font-size:14px;line-height:1;text-transform:uppercase;letter-spacing:.02em;font-weight:700}
    .dark-section .section-tag{background:rgba(6,82,87,.95);color:#9cf3e4;font-weight:800}
    .section-tag::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--teal-2)}
    .section-title{font-size:44px;line-height:1.05;letter-spacing:-.04em;margin:16px 0 8px}
    .section-sub{max-width:800px;font-size:18px;color:#d5d5d5}

        /* ===== PÁGINA: INICIO / HERO ===== */
    .hero{padding:26px 0 56px;background:var(--bg)}
    .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:42px;min-height:500px}
    .hero h1{font-size:80px;line-height:.96;letter-spacing:-.055em;margin:18px 0 18px;color:#183a40}
    .hero h1 .accent{color:var(--teal-2)}
    .hero p{font-size:20px;line-height:1.18;color:#232323;max-width:590px;margin:0 0 30px}
    .hero-copy{max-width:620px;align-self:center}
    .hero-copy h1{font-size:80px;line-height:.96;letter-spacing:-.055em;margin:18px 0 18px}
    .hero-copy h1 .accent{color:var(--teal-2)}
    .hero-copy p{font-size:20px;line-height:1.18;max-width:590px;margin:0 0 30px}
    .hero .hero-copy h1{color:#183a40}
    .hero .hero-copy p{color:#232323}
    .dark-section .hero-copy h1,
    .hero-contact .hero-copy h1{color:#dffefe}
    .dark-section .hero-copy p,
    .hero-contact .hero-copy p{color:#e0e0e0}
    .cta-row{display:flex;gap:18px;flex-wrap:wrap}
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:17px 28px;border-radius:14px;font-weight:800;font-size:16px;background:var(--teal-2);color:#000;box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease, filter .25s ease}
    .btn:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(0,0,0,.16);filter:saturate(1.05)}
    .btn.secondary{background:#24d6cb;color:#000}

    .hero-visual{position:relative;height:430px;display:flex;align-items:center;justify-content:center}
    .hero-visual.nodos-hero{height:500px}
    .nodos-wrap{position:relative;width:min(430px,78%);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:visible}
    .nodos-wrap::before{content:"";position:absolute;inset:10%;background:radial-gradient(circle, rgba(120,230,208,.18), rgba(120,230,208,0) 68%);filter:blur(18px)}
    .nodos-asset{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;animation:spinSlow 34s linear infinite;transform-origin:50% 50%;filter:drop-shadow(0 0 18px rgba(120,230,208,.2))}
    
    .glow{position:absolute;inset:14% 14%;background:radial-gradient(circle, rgba(120,230,208,.38), rgba(120,230,208,0) 62%);filter:blur(14px)}
    .network-graphic,.people-graphic,.puzzle-graphic{position:relative;width:min(430px,100%);aspect-ratio:1/1}
    .node{position:absolute;border:10px solid;border-radius:50%;background:#cbedeb}
    .line{position:absolute;height:8px;background:linear-gradient(90deg,var(--teal-2),#0b6e88);transform-origin:left center;border-radius:999px;animation:lineGlow 4s ease-in-out infinite}
    .network-graphic .center{width:110px;height:110px;left:160px;top:160px;border-color:#0e8c97;animation:pulse 2.8s ease-in-out infinite}
    .network-graphic .n1{width:58px;height:58px;left:78px;top:104px;border-color:#23d9cd}
    .network-graphic .n2{width:58px;height:58px;right:76px;top:106px;border-color:#0f8a9a}
    .network-graphic .n3{width:58px;height:58px;left:70px;bottom:108px;border-color:#1ad8cb}
    .network-graphic .n4{width:58px;height:58px;right:74px;bottom:100px;border-color:#065f8f}
    .network-graphic .l1{width:110px;left:121px;top:132px;rotate:38deg}
    .network-graphic .l2{width:108px;left:231px;top:132px;rotate:-38deg;animation-delay:.3s}
    .network-graphic .l3{width:110px;left:118px;top:260px;rotate:-38deg;animation-delay:.6s}
    .network-graphic .l4{width:110px;left:229px;top:261px;rotate:38deg;animation-delay:.9s}

    .people-graphic .ring{position:absolute;inset:26px;border:10px solid #0f808a;border-left-color:transparent;border-right-color:#0f808a;border-radius:50%;transform:rotate(-12deg)}
    .people-graphic .person{position:absolute;width:112px;height:150px;background:linear-gradient(180deg,#0f8ea5,#26d6cb);border-radius:56px 56px 36px 36px;filter:drop-shadow(0 0 8px rgba(120,230,208,.35))}
    .people-graphic .person::before{content:"";position:absolute;width:78px;height:78px;left:17px;top:-44px;border-radius:50%;background:inherit}
    .people-graphic .p1{left:66px;top:130px;scale:.9}
    .people-graphic .p2{left:158px;top:118px;width:126px;height:170px;z-index:2}
    .people-graphic .p2::before{width:86px;height:86px;left:20px;top:-48px}
    .people-graphic .p3{right:62px;top:130px;scale:.9}
    .people-graphic .q{position:absolute;left:202px;top:156px;z-index:3;color:#fff;font-size:72px;font-weight:800;transform:translateX(-50%);text-shadow:0 0 14px rgba(120,230,208,.55)}

    .puzzle-graphic .piece{position:absolute;width:150px;height:150px;background:rgba(120,230,208,.76)}
    .puzzle-graphic .piece:before,.puzzle-graphic .piece:after{content:"";position:absolute;border-radius:50%;background:inherit}
    .puzzle-graphic .a{left:138px;top:78px}.puzzle-graphic .a:before{width:42px;height:42px;right:-20px;top:54px}.puzzle-graphic .a:after{width:42px;height:42px;left:54px;bottom:-20px}
    .puzzle-graphic .b{left:138px;top:228px}.puzzle-graphic .b:before{width:42px;height:42px;left:54px;top:-20px}.puzzle-graphic .b:after{width:42px;height:42px;right:-20px;top:54px}
    .puzzle-graphic .c{left:288px;top:228px}.puzzle-graphic .c:before{width:42px;height:42px;left:-20px;top:54px}.puzzle-graphic .c:after{width:42px;height:42px;left:54px;top:-20px}
    .puzzle-graphic .d{left:288px;top:78px;transform:rotate(-18deg)}.puzzle-graphic .d:before{width:42px;height:42px;left:-20px;top:54px}.puzzle-graphic .d:after{width:42px;height:42px;left:54px;bottom:-20px}
    .puzzle-graphic .arrow{position:absolute;width:84px;height:12px;background:var(--teal-2);border-radius:999px;transform-origin:left center;animation:float 2.8s ease-in-out infinite}
    .puzzle-graphic .arrow::after{content:"";position:absolute;right:-2px;top:-8px;border-left:24px solid var(--teal-2);border-top:14px solid transparent;border-bottom:14px solid transparent}
    .puzzle-graphic .ar1{left:118px;top:326px;transform:rotate(-14deg)}
    .puzzle-graphic .ar2{left:174px;top:350px;transform:rotate(-72deg);animation-delay:.2s}
    .puzzle-graphic .ar3{left:247px;top:350px;transform:rotate(-112deg);animation-delay:.45s}

        /* ===== SECCIONES OSCURAS ===== */
    .dark-section{background:var(--bg-dark);color:white;padding:38px 0 72px}
    .light-section{background:var(--bg);padding:40px 0 72px}
        /* ===== TARJETAS DE SERVICIOS ===== */
    .cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:28px}
    .card{background:#08393d;border-radius:18px;padding:24px;min-height:245px;border:1px solid rgba(120,230,208,.18);position:relative;overflow:hidden;transform:translateY(0);transition:transform .28s ease, box-shadow .28s ease}
    .card:hover,.quick-card:hover,.step:hover,.value-card:hover,.benefit:hover,.channel-link:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(0,0,0,.16)}
    .card.light{background:#b8ece7;color:#05292f}
    .card h4{font-size:32px;line-height:1.08;margin:8px 0 12px}
    .card p,.card li{font-size:17px;line-height:1.2;color:inherit;opacity:.92}
    .iconbox{width:56px;height:56px;border-radius:14px;background:rgba(120,230,208,.16);display:grid;place-items:center;margin-bottom:18px}
    .iconbox.light{background:rgba(15,97,106,.1)}
    .list{padding-left:20px;margin:12px 0 0}
    .chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
    .chip{padding:9px 14px;border-radius:999px;background:#178da6;color:white;font-weight:700;font-size:14px}
    .card::after{content:"";position:absolute;right:-24px;bottom:-24px;width:140px;height:140px;border:4px solid rgba(255,255,255,.08);border-radius:50%;opacity:.35}

        /* ===== METODOLOGÍA / PASOS ===== */
    .steps{display:grid;grid-template-columns:repeat(4,minmax(250px,1fr));gap:28px;margin-top:38px;overflow:hidden}
    .step{position:relative;padding:40px 32px 34px;border-radius:34px;min-height:308px;background:#000;border:5px solid #f3f3f3;box-shadow:none;transition:transform .28s ease, box-shadow .28s ease}
    .step:nth-child(2),.step:nth-child(4){background:#103f43}
    .step::before,.step::after{content:"";position:absolute;top:50%;width:42px;height:calc(100% - 48px);transform:translateY(-50%);border:5px solid #f3f3f3;border-radius:26px;background:transparent;pointer-events:none}
    .step::before{left:-26px;border-right:none}
    .step::after{right:-26px;border-left:none}
    .steps .step:first-child::before,.steps .step:last-child::after{opacity:1}
    .step .num{font-size:92px;font-weight:800;line-height:.9;color:var(--teal-2);letter-spacing:-.06em}
    .step h3{font-size:32px;margin:30px 0 18px;color:#fff;letter-spacing:-.03em}
    .step p{font-size:18px;line-height:1.18;margin:0;max-width:310px;color:#e6f7f5}

        /* ===== BENEFICIOS ===== */
    .benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:42px;text-align:center}
    .benefit{transition:transform .28s ease, box-shadow .28s ease;border-radius:20px;padding:4px 8px 0}
    .benefit-icon{width:140px;height:140px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;background:rgba(120,230,208,.18);border:6px solid #8a8a8a;position:relative}
    .benefit-icon::after,.benefit-icon::before{content:"";position:absolute;width:18px;height:18px;border-top:6px solid #8a8a8a;border-right:6px solid #8a8a8a;border-radius:3px}
    .benefit-icon::before{left:-4px;top:22px;transform:rotate(130deg)}
    .benefit-icon::after{right:-4px;top:22px;transform:rotate(-45deg)}

    .iconbox svg,.benefit-icon svg{display:block}
    .iconbox{width:56px;height:56px;border-radius:14px;background:rgba(120,230,208,.16);display:grid;place-items:center;margin-bottom:18px}
    .iconbox svg{width:28px;height:28px;stroke:var(--teal);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
    .benefit-icon svg{width:70px;height:70px;stroke:var(--teal-2);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
    .iconbox i{font-size:28px;color:#3d8ea5;line-height:1;text-align:center}
    .benefit-icon i{font-size:58px;color:var(--teal-2);line-height:1;position:relative;z-index:2;text-align:center}
    .icon.brand-icon i{font-size:42px;color:currentColor;line-height:1;text-align:center}
    .channel-icon i{font-size:24px;line-height:1;text-align:center}
    .pin i{font-size:48px;line-height:1;text-align:center}

    .benefit h3{font-size:22px;margin:0 0 10px}
    .benefit p{font-size:17px;color:#4f4f4f;margin:0}

    .contact-band{background:linear-gradient(174deg,var(--teal-2) 0 44%, var(--bg) 44%);padding:36px 0 0}
    .contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden;border-radius:40px 40px 0 0;max-width:980px;margin:0 auto;background:black;box-shadow:var(--shadow)}
    .form-pane{background:#f4f4f4;padding:36px 34px 28px;border-top-left-radius:40px}
    .side-pane{background:#000;padding:42px 34px;color:white;border-top-right-radius:40px}
    .form-pane h3,.side-pane h3{font-size:22px;margin:0 0 8px}

    .form-pane p,.side-pane1 p{
      font-size:15px;
      line-height:1.2;
      color:#79e6d0;
      margin:0 0 22px
    }

    .form-pane p,.side-pane p{
      font-size:15px;
      line-height:1.2;
      color:#bcb1b1;
      margin:0 0 22px
    }

    .side-pane1 p{color:#79e6d0}

    .side-pane p{color:#183a3c}
    body[data-page="inicio"] .side-pane p,
    body[data-page="servicios"] .side-pane p{color:#79e6d0 !important}
    body[data-page="quienes-somos"] .side-pane p{color:#183a3c !important}

    .form-group{margin-bottom:16px}
    label{display:block;font-size:14px;font-weight:800;margin-bottom:8px;text-transform:uppercase}
    input,textarea{width:100%;border:0;background:#e5e5e5;border-radius:14px;padding:16px 18px;font:inherit;outline:none}
    input:focus,textarea:focus{box-shadow:0 0 0 2px rgba(38,214,203,.45)}
    textarea{min-height:92px;resize:vertical}
    .submit{width:100%;border:0;padding:16px 20px;border-radius:16px;background:var(--teal-2);font-size:18px;font-weight:800;cursor:pointer;transition:transform .25s ease, box-shadow .25s ease}
    .submit:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(0,0,0,.16)}
    .channel{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid rgba(120,230,208,.25)}
    .channel-icon{width:48px;height:48px;border-radius:12px;background:#063a3d;color:var(--teal);display:grid;place-items:center;font-size:24px;flex:0 0 auto}
    .channel .mini-btn{display:inline-flex;background:#0f665f;color:#fff;padding:6px 18px;border-radius:999px;font-size:15px;font-weight:700;margin-bottom:8px}
    .channel-link{display:flex;transition:transform .25s ease}

    .footer{padding:20px 0;background:var(--bg)}
    .footer .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
    .footer p{margin:0;text-align:center;font-size:14px}
    .footer-logo img{width:120px}

    .hero-contact{background:linear-gradient(90deg,#2d2b2c,#343434 35%, #0b2228 100%);color:white;padding:60px 0}
    .hero-contact .hero-grid{min-height:410px}
    .hero-contact h1{color:#b4f2ef;font-size:72px}
    .hero-contact p{color:#e0e0e0}
    .contact-card-layout{display:grid;grid-template-columns:1fr .95fr;gap:38px;margin-top:34px;align-items:start}
    .quick-cards{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:26px;margin-bottom:28px}
    .quick-card{background:#b8ece7;padding:28px;border-radius:20px;min-height:220px;box-shadow:var(--shadow);transition:transform .28s ease, box-shadow .28s ease}
    .quick-card h3{font-size:22px;margin:22px 0 14px}
    .quick-card p{font-size:18px;margin:0 0 22px;color:#214146}
    .quick-card a{color:#0a5278;font-weight:800}
    .location{display:flex;gap:18px;align-items:flex-start;margin-top:18px}
    .location .pin{font-size:48px;color:var(--teal-2)}
    .form-card{background:#f4f0f0;padding:28px 26px;border-radius:36px;box-shadow:var(--shadow)}
    .form-card h3{font-size:28px;text-align:center;color:#64dfe1;margin:0 0 22px}

    .mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;margin-top:42px}
    .mission-box{padding-top:8px}
    .mission-box h3{font-size:48px;margin:0 0 12px}
    .mission-box p{font-size:22px;line-height:1.22;color:#3a3a3a;margin:0;max-width:520px}
    .mission-line{width:120px;height:4px;background:var(--teal-2);margin:0 0 28px}
    .value-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
    .value-card{display:grid;grid-template-columns:56px 1fr 80px;gap:16px;align-items:center;background:#b8ece7;padding:22px;border-radius:18px;min-height:140px;transition:transform .28s ease, box-shadow .28s ease}
    .value-card.dark{background:#2d2a2d;color:#fff}
    .value-card.productivity-light{background:#f3f6f5;color:#1b1b1b}
    .value-card .big-num{font-size:54px;color:#6de9e0;font-weight:800;justify-self:end;transition:color .28s ease}
    .value-card:hover .big-num{color:#27cfc8}
    .value-card.scalability-card .big-num{color:#cfd6d5}
    .value-card.scalability-card:hover .big-num{color:#ffffff}
    .value-card h4{font-size:20px;margin:0 0 8px}
    .value-card p{margin:0;font-size:15px;line-height:1.25;color:inherit;opacity:.9}
    .value-card .icon{font-size:42px}

    .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
    .reveal.visible{opacity:1;transform:none}
    .delay-1{transition-delay:.08s} .delay-2{transition-delay:.16s} .delay-3{transition-delay:.24s} .delay-4{transition-delay:.32s}

    @keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
    @keyframes float{0%,100%{translate:0 0}50%{translate:0 -8px}}
    @keyframes lineGlow{0%,100%{filter:drop-shadow(0 0 0 rgba(120,230,208,.0))}50%{filter:drop-shadow(0 0 8px rgba(120,230,208,.65))}}
        /* ===== ANIMACIONES ===== */
    @keyframes spinSlow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

    @media (max-width:1100px){
      .hero h1,.hero-contact h1{font-size:62px}
      .cards,.benefits,.value-grid{grid-template-columns:repeat(2,1fr)}
      .steps{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
      .step{min-height:280px;padding:34px 24px 28px}
      .step::before,.step::after{display:none}
    }
    @media (max-width:860px){
      .hero-grid,.contact-wrap,.contact-card-layout,.mission-grid{grid-template-columns:1fr}
      .navlinks{gap:16px}
      .hero-visual{order:-1;height:340px}
      .hero-visual.nodos-hero{height:360px}
      .cards,.benefits,.quick-cards,.value-grid{grid-template-columns:1fr}
      .steps{grid-template-columns:1fr}
      .footer .container{flex-direction:column}
      .contact-wrap{border-radius:28px 28px 0 0}
      .form-pane,.side-pane{border-radius:0}
    }
    @media (max-width:560px){
      .container{padding:0 18px}
      .brand img{width:110px}
      .navlinks{gap:10px;font-size:12px}
      .hero h1,.hero-contact h1{font-size:48px}
      .section-title{font-size:34px}
      .mission-box h3{font-size:36px}
      .mission-box p{font-size:18px}
      .step .num{font-size:74px}
      .step h3{font-size:28px}
      .quick-cards{grid-template-columns:1fr}
    }
  

    /* ===== QUIÉNES SOMOS / AJUSTES V4 ===== */
    .qs-visual{position:relative;width:min(430px,100%);aspect-ratio:1/1;display:grid;place-items:center;margin-inline:auto}
    .qs-image{position:relative;z-index:2;width:74%;max-width:320px;height:auto;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.10))}
    .qs-ring{position:absolute;inset:2%;width:96%;height:96%;z-index:1;overflow:visible;animation:qsSpin 18s linear infinite}
    .qs-ring path{stroke-dasharray:100;stroke-dashoffset:100;animation:qsDraw 3.6s ease-out forwards, qsPulse 4.8s ease-in-out infinite 3.6s;filter:drop-shadow(0 0 6px rgba(15,128,138,.25))}
    @keyframes qsSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
    @keyframes qsDraw{from{stroke-dashoffset:100}to{stroke-dashoffset:0}}
    @keyframes qsPulse{0%,100%{opacity:.96}50%{opacity:.76}}

    .value-card{display:grid;grid-template-columns:72px 1fr 80px;gap:16px;align-items:center;background:#b8ece7;padding:22px;border-radius:18px;min-height:140px;transition:transform .28s ease, box-shadow .28s ease}
    .value-card .icon.brand-icon{font-size:0;color:var(--teal-2);width:58px;height:58px;display:grid;place-items:center}
    .value-card .icon.brand-icon svg{width:58px;height:58px;display:block}
    .value-card .big-num{font-size:54px;color:#6de9e0;font-weight:800;justify-self:end;transition:color .2s ease, transform .2s ease}
    .value-card:hover .big-num{color:#168681;transform:scale(1.02)}
    .value-card.dark .icon.brand-icon{color:var(--teal)}
    .value-card.dark .big-num{color:var(--teal-2)}
    .value-card.dark:hover .big-num{color:#5ccdc3}

  
/* ===== V9: QUIENES SOMOS / LOGICA ILIPAU ===== */
.logic-ilipau {
  padding-top: 0 !important;
}
.logic-ilipau .section-title{
  text-align:center;
  font-size: clamp(34px, 4.6vw, 62px);
  letter-spacing: -0.04em;
  margin-bottom: 12px;
}
.logic-ilipau .logic-subtitle{
  font-size: clamp(18px, 2vw, 28px);
  color:#333 !important;
  max-width: 1180px !important;
  margin:0 auto 34px !important;
  text-align:center;
}
.logic-ilipau .value-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:22px;
  margin-top: 0;
}
.logic-ilipau .value-card{
  display:grid;
  grid-template-columns: 64px 1fr 88px;
  align-items:start;
  gap:18px;
  padding:28px 34px;
  min-height: 214px;
  border-radius:26px;
  background:#b8ece7;
  box-shadow:none;
}
.logic-ilipau .value-card h4{
  font-size: clamp(24px, 2.5vw, 42px);
  line-height:1.05;
  margin:8px 0 10px;
  letter-spacing:-0.03em;
}
.logic-ilipau .value-card p{
  font-size: clamp(16px, 1.35vw, 26px);
  line-height:1.16;
  opacity:1;
  max-width: 640px;
}
.logic-ilipau .value-card .big-num{
  font-size: clamp(60px, 4.8vw, 96px);
  line-height:1;
  align-self:start;
  justify-self:end;
  font-weight:800;
  color:#6fe4db;
}
.logic-ilipau .value-card .icon.brand-icon{
  width:68px;
  height:68px;
}
.logic-ilipau .value-card .icon.brand-icon svg{
  width:68px;
  height:68px;
}
.logic-ilipau .value-card.productivity-light{
  background:#d9d9d9;
  color:#111;
}
.logic-ilipau .value-card.productivity-light .big-num{
  color:#8f8f8f;
}
.logic-ilipau .value-card.dark{
  background:#2d2a2d;
  color:#fff;
}
.logic-ilipau .value-card.scalability-card .big-num{
  color:#8f8f8f;
}
.logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#fff;
}
.logic-ilipau .value-card:hover .big-num{
  color:#168681;
}
.logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#fff;
}
.logic-ilipau .value-card.compact{
  min-height: 250px;
}
.logic-ilipau .value-card.wide{
  grid-template-columns: 1fr 168px 88px;
  min-height: 250px;
  align-items:center;
}
.logic-ilipau .wide-copy{
  padding-right:10px;
}
.logic-ilipau .wide-copy h4{
  margin-top: 0;
}
.logic-ilipau .growth-visual{
  width:150px;
  height:120px;
  align-self:center;
  justify-self:center;
}
.logic-ilipau .growth-visual svg{
  width:100%;
  height:100%;
  display:block;
}
.logic-ilipau .rocket-inline{
  color: var(--teal);
  font-size: .82em;
  vertical-align: middle;
  margin-left: 6px;
}
@media (max-width: 900px){
  .logic-ilipau .value-grid{
    grid-template-columns:1fr;
  }
  .logic-ilipau .value-card,
  .logic-ilipau .value-card.compact,
  .logic-ilipau .value-card.wide{
    grid-template-columns:64px 1fr 78px;
    min-height:auto;
  }
  .logic-ilipau .growth-visual{
    width:110px;
    height:90px;
  }
}

/* ===== V10 AJUSTE PROPORCIONES ===== */
.logic-ilipau .value-grid{
  grid-template-columns: 1.2fr 1.2fr;
}

.logic-ilipau .value-card.productivity-light{
  max-width: 320px;
  margin: 0 auto;
  text-align: center;
}

.logic-ilipau .value-card.productivity-light h4,
.logic-ilipau .value-card.productivity-light p{
  text-align: center;
}

.logic-ilipau .value-card.wide{
  grid-column: span 2;
  display: grid;
  grid-template-columns: 1.2fr 0.6fr 0.2fr;
  align-items: center;
}

.logic-ilipau .value-card.wide h4{
  font-size: clamp(26px, 2.8vw, 44px);
}

.logic-ilipau .value-card.wide p{
  max-width: 600px;
}

.logic-ilipau .value-card.wide .big-num{
  align-self: start;
}

.logic-ilipau .wide-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* ===== V11 AJUSTES QUIÉNES SOMOS ===== */
.logic-ilipau{
  padding-bottom: 28px !important;
}
.logic-ilipau .section-title{
  margin-bottom: 18px !important;
}
.logic-ilipau .logic-subtitle{
  max-width: 980px !important;
  margin: 0 auto 42px !important;
  line-height: 1.22 !important;
}
.logic-ilipau .value-grid{
  gap: 24px !important;
  align-items: stretch !important;
}
.logic-ilipau .value-card{
  padding: 30px 34px 28px !important;
  border-radius: 28px !important;
  transition: transform .28s ease, box-shadow .28s ease, background-color .28s ease, color .28s ease !important;
}
.logic-ilipau .value-card:hover{
  transform: translateY(-4px) !important;
  box-shadow: 0 18px 34px rgba(0,0,0,.10) !important;
}
.logic-ilipau .value-card h4{
  margin: 10px 0 12px !important;
  font-weight: 800 !important;
}
.logic-ilipau .value-card p{
  line-height: 1.2 !important;
}
.logic-ilipau .value-card .big-num{
  transition: color .25s ease, opacity .25s ease !important;
}
.logic-ilipau .value-card:hover .big-num{
  color:#16cfc7 !important;
}
.logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#ffffff !important;
}
.logic-ilipau .value-card.productivity-light{
  max-width: 300px !important;
  min-height: 246px !important;
  padding: 26px 26px 24px !important;
  align-self: stretch !important;
}
.logic-ilipau .value-card.productivity-light .icon.brand-icon{
  margin: 0 auto 2px !important;
}
.logic-ilipau .value-card.productivity-light h4{
  text-align: center !important;
  margin-top: 4px !important;
}
.logic-ilipau .value-card.productivity-light p{
  text-align: center !important;
  max-width: 240px !important;
  margin: 0 auto !important;
}
.logic-ilipau .value-card.productivity-light .big-num{
  align-self: start !important;
  justify-self: end !important;
}
.logic-ilipau .value-card.wide{
  min-height: 246px !important;
  grid-template-columns: minmax(0,1.55fr) 170px 88px !important;
  gap: 20px !important;
  padding: 28px 36px !important;
}
.logic-ilipau .wide-copy{
  justify-content: center !important;
  align-self: center !important;
}
.logic-ilipau .wide-copy h4{
  margin-bottom: 14px !important;
}
.logic-ilipau .wide-copy p{
  max-width: 760px !important;
}
.logic-ilipau .growth-visual{
  width: 160px !important;
  height: 126px !important;
}
.logic-ilipau .value-card.wide .big-num{
  align-self: start !important;
  justify-self: end !important;
}
.logic-ilipau .value-card:nth-child(1):hover,
.logic-ilipau .value-card:nth-child(2):hover{
  background:#ace6df !important;
}
.logic-ilipau .value-card.productivity-light:hover{
  background:#d1d1d1 !important;
}
.logic-ilipau .value-card.scalability-card:hover{
  background:#262326 !important;
}
@media (max-width: 900px){
  .logic-ilipau .logic-subtitle{
    margin-bottom: 28px !important;
  }
  .logic-ilipau .value-card.productivity-light{
    max-width: 100% !important;
  }
  .logic-ilipau .value-card.wide{
    grid-template-columns: 1fr !important;
  }
  .logic-ilipau .growth-visual{
    margin-left:auto !important;
  }
}

/* ===== V12 MISMA LÍNEA PRODUCTIVIDAD Y ESCALABILIDAD ===== */
.logic-ilipau .value-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
}

.logic-ilipau .value-card.productivity-light{
  grid-column: 1 / span 1 !important;
  max-width: 100% !important;
}

.logic-ilipau .value-card.wide{
  grid-column: 2 / span 1 !important;
  grid-template-columns: 1fr 120px 60px !important;
}

/* ===== V13 ALINEACIÓN PRODUCTIVIDAD / ESCALABILIDAD SOLO QUIÉNES SOMOS ===== */
.logic-ilipau .value-grid{
  display:grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap:24px !important;
  align-items:stretch !important;
}

.logic-ilipau .value-card.productivity-light{
  grid-column: 1 !important;
  justify-self: stretch !important;
  width: 72% !important;
  max-width: none !important;
  margin: 0 !important;
  min-height: 246px !important;
}

.logic-ilipau .value-card.wide{
  grid-column: 2 !important;
  justify-self: stretch !important;
  width: 100% !important;
  max-width: none !important;
  grid-template-columns: minmax(0,1.45fr) 160px 88px !important;
  min-height: 246px !important;
}

@media (max-width: 900px){
  .logic-ilipau .value-card.productivity-light,
  .logic-ilipau .value-card.wide{
    width:100% !important;
  }
}

/* ===== V14: AJUSTES SOLO PÁGINA SERVICIOS ===== */
#servicios .hero-visual {
  position:relative;
  min-height:420px;
}
#servicios .services-puzzle-wrap {
  position:relative;
  width:min(430px, 92%);
  aspect-ratio:1/1;
  display:flex;
  align-items:center;
  justify-content:center;
}
#servicios .services-puzzle-wrap img {
  width:100%;
  height:100%;
  object-fit:contain;
  position:relative;
  z-index:2;
  filter: drop-shadow(0 0 26px rgba(120,230,208,.10));
}
#servicios .services-puzzle-wrap .arrow {
  position:absolute;
  width:92px;
  height:12px;
  background:var(--teal-2);
  border-radius:999px;
  left:20px;
  bottom:72px;
  transform-origin:left center;
  z-index:1;
  animation: servicesArrowPulse 2.2s ease-in-out infinite;
}
#servicios .services-puzzle-wrap .arrow::after {
  content:"";
  position:absolute;
  right:-2px;
  top:50%;
  width:24px;
  height:24px;
  border-top:8px solid var(--teal-2);
  border-right:8px solid var(--teal-2);
  transform: translateY(-50%) rotate(45deg);
  border-radius:2px;
}
#servicios .services-puzzle-wrap .arrow.a1 { transform: rotate(-22deg); left:12px; bottom:82px; animation-delay:0s; }
#servicios .services-puzzle-wrap .arrow.a2 { transform: rotate(-52deg); left:54px; bottom:26px; width:96px; animation-delay:.25s; }
#servicios .services-puzzle-wrap .arrow.a3 { transform: rotate(-82deg); left:154px; bottom:6px; width:82px; animation-delay:.5s; }
@keyframes servicesArrowPulse {
  0%,100% { opacity:.55; transform: translateX(0) scale(1) var(--rot, none); }
  50% { opacity:1; transform: translateX(6px) scale(1.04) var(--rot, none); }
}

#servicios .service-solution-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
  margin-top:28px;
}
#servicios .service-card {
  background:#b8ece7;
  color:#05292f;
  border-radius:18px;
  padding:24px;
  min-height:245px;
  border:1px solid rgba(120,230,208,.18);
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, box-shadow .28s ease;
}
#servicios .service-card:hover {
  transform:translateY(-4px);
  box-shadow:0 18px 36px rgba(0,0,0,.16);
}
#servicios .service-card h4 {
  font-size:32px;
  line-height:1.08;
  margin:8px 0 12px;
  position:relative;
  z-index:2;
}
#servicios .service-card p,
#servicios .service-card li,
#servicios .service-card .chips {
  position:relative;
  z-index:2;
}
#servicios .service-card .wm {
  position:absolute;
  right:8px;
  bottom:8px;
  width:155px;
  height:155px;
  opacity:.18;
  z-index:1;
  pointer-events:none;
}
#servicios .service-card .wm svg {
  width:100%;
  height:100%;
  display:block;
}
#servicios .service-card .iconbox.light {
  background:rgba(15,97,106,.1);
  position:relative;
  z-index:2;
}
#servicios .service-card.integraciones .wm {
  width:150px;
  height:150px;
  right:10px;
  bottom:0;
}
#servicios .service-card.ventas .wm,
#servicios .service-card.flujos .wm {
  width:150px;
  height:150px;
}
#servicios .service-card.auto-procesos .wm {
  width:142px;
  height:142px;
  right:18px;
  bottom:12px;
}

#servicios #metodologia .steps {
  display:grid;
  grid-template-columns:repeat(4,minmax(245px,1fr));
  gap:28px;
  margin-top:38px;
  overflow:hidden;
}
#servicios #metodologia .step {
  position:relative;
  padding:26px 26px 24px;
  border-radius:34px;
  min-height:330px;
  background:#000;
  border:5px solid rgba(243,243,243,.35);
  box-shadow:none;
  transition:transform .28s ease, box-shadow .28s ease;
}
#servicios #metodologia .step:nth-child(2),
#servicios #metodologia .step:nth-child(4) {
  background:#237d84;
}
#servicios #metodologia .step::before,
#servicios #metodologia .step::after {
  content:"";
  position:absolute;
  top:50%;
  width:42px;
  height:calc(100% - 48px);
  transform:translateY(-50%);
  border:5px solid rgba(243,243,243,.35);
  border-radius:26px;
  background:transparent;
  pointer-events:none;
}
#servicios #metodologia .step::before { left:-26px; border-right:none; }
#servicios #metodologia .step::after { right:-26px; border-left:none; }
#servicios #metodologia .step .inner {
  background:#237d84;
  border-radius:24px;
  min-height:100%;
  padding:26px 26px 24px;
}
#servicios #metodologia .step:nth-child(2) .inner,
#servicios #metodologia .step:nth-child(4) .inner {
  background:transparent;
}
#servicios #metodologia .step .num {
  font-size:92px;
  font-weight:800;
  line-height:.9;
  color:var(--teal-2);
  letter-spacing:-.06em;
}
#servicios #metodologia .step h3 {
  font-size:32px;
  margin:28px 0 18px;
  color:#fff;
  letter-spacing:-.03em;
}
#servicios #metodologia .step p {
  font-size:18px;
  line-height:1.18;
  margin:0;
  max-width:310px;
  color:#e6f7f5;
}

@media (max-width: 900px) {
  #servicios .service-solution-grid { grid-template-columns:1fr; }
  #servicios #metodologia .steps { grid-template-columns:1fr; }
  #servicios #metodologia .step::before,
  #servicios #metodologia .step::after { display:none; }
}

/* ===== V15 AJUSTES SERVICIOS Y CONTACTO ===== */

/* Hero servicios: solo flechas internas de la imagen, animación vertical sutil */
#servicios .services-puzzle-wrap .arrow{
  display:none !important;
}
#servicios .services-puzzle-wrap{
  animation: none !important;
}
#servicios .services-puzzle-wrap img{
  animation: servicesPuzzleFloat 2.6s ease-in-out infinite;
}
@keyframes servicesPuzzleFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}

/* Contacto: animación de personas laterales hacia adentro */
#contacto .hero-visual,
#contacto .contact-hero-visual{
  position:relative;
  overflow:visible;
}
#contacto .contact-group,
#contacto .contact-people{
  position:relative;
  width:min(420px, 90%);
  height:320px;
  margin:0 auto;
}
#contacto .contact-person{
  position:absolute;
  bottom:20px;
  width:115px;
  height:170px;
  display:flex;
  align-items:center;
  justify-content:center;
}
#contacto .contact-person svg{
  width:100%;
  height:100%;
  display:block;
}
#contacto .contact-person.center{
  left:50%;
  transform:translateX(-50%);
  z-index:3;
}
#contacto .contact-person.left{
  left:26px;
  z-index:1;
  animation: contactLeftIn 3.8s ease-in-out infinite;
}
#contacto .contact-person.right{
  right:26px;
  z-index:1;
  animation: contactRightIn 3.8s ease-in-out infinite;
}
@keyframes contactLeftIn{
  0%,100%{ transform: translateX(0); opacity:.9; }
  50%{ transform: translateX(26px); opacity:1; }
}
@keyframes contactRightIn{
  0%,100%{ transform: translateX(0); opacity:.9; }
  50%{ transform: translateX(-26px); opacity:1; }
}
#contacto .contact-ring-glow{
  position:absolute;
  inset:0;
  margin:auto;
  width:300px;
  height:300px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(120,230,208,.14) 0%, rgba(120,230,208,.06) 45%, rgba(120,230,208,0) 72%);
  filter:blur(2px);
}

/* ===== V16 CONTACTO HERO ESTILO SILUETAS CON RESPLANDOR ===== */
#contacto .contact-ring-glow{
  width:420px !important;
  height:420px !important;
  background:radial-gradient(circle, rgba(120,230,208,.30) 0%, rgba(120,230,208,.16) 28%, rgba(120,230,208,.07) 48%, rgba(120,230,208,0) 72%) !important;
  filter: blur(10px);
  opacity:.9;
}
#contacto .contact-group,
#contacto .contact-people{
  width:min(520px, 96%) !important;
  height:360px !important;
}
#contacto .contact-person{
  width:150px !important;
  height:220px !important;
  bottom:10px !important;
}
#contacto .contact-person svg{
  filter: drop-shadow(0 0 8px rgba(120,230,208,.14));
}
#contacto .contact-person.left{
  left:40px !important;
  animation: contactLeftGlow 4.2s ease-in-out infinite;
}
#contacto .contact-person.right{
  right:40px !important;
  animation: contactRightGlow 4.2s ease-in-out infinite;
}
#contacto .contact-person.center{
  width:168px !important;
  height:250px !important;
  bottom:0 !important;
  animation: contactCenterPulse 4.2s ease-in-out infinite;
}
@keyframes contactLeftGlow{
  0%,100%{ transform: translateX(0) translateY(0); }
  50%{ transform: translateX(18px) translateY(-3px); }
}
@keyframes contactRightGlow{
  0%,100%{ transform: translateX(0) translateY(0); }
  50%{ transform: translateX(-18px) translateY(-3px); }
}
@keyframes contactCenterPulse{
  0%,100%{ transform: translateX(-50%) scale(1); }
  50%{ transform: translateX(-50%) scale(1.03); }
}

/* ===== V17 CONTACTO AJUSTE SEGÚN VIDEO ===== */
#contacto .contact-group{
  width:min(540px, 96%) !important;
  height:360px !important;
}
#contacto .contact-person{
  bottom:12px !important;
}
#contacto .contact-person.left{
  left:52px !important;
  animation: contactLeftVideo 4.6s ease-in-out infinite !important;
}
#contacto .contact-person.right{
  right:52px !important;
  animation: contactRightVideo 4.6s ease-in-out infinite !important;
}
#contacto .contact-person.center{
  animation: contactCenterVideo 4.6s ease-in-out infinite !important;
}
@keyframes contactLeftVideo{
  0%, 18%, 100% { transform: translateX(0) scale(1); opacity:1; }
  36%, 52% { transform: translateX(42px) scale(.96); opacity:.0; }
  68% { transform: translateX(20px) scale(.98); opacity:.55; }
}
@keyframes contactRightVideo{
  0%, 18%, 100% { transform: translateX(0) scale(1); opacity:1; }
  36%, 52% { transform: translateX(-42px) scale(.96); opacity:.0; }
  68% { transform: translateX(-20px) scale(.98); opacity:.55; }
}
@keyframes contactCenterVideo{
  0%, 18%, 100% { transform: translateX(-50%) scale(1); }
  36%, 52% { transform: translateX(-50%) scale(1.02); }
  68% { transform: translateX(-50%) scale(1.01); }
}

/* ===== V18: AJUSTES ESPECÍFICOS POR PÁGINA ===== */

/* ---------- 1) INICIO / METODOLOGÍA ---------- */
#inicio .steps{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(240px,1fr)) !important;
  gap:28px !important;
  margin-top:38px !important;
  overflow:hidden !important;
}
#inicio .step{
  position:relative !important;
  min-height:330px !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}
#inicio .step .inner{
  min-height:100% !important;
  border-radius:28px !important;
  padding:26px 24px 24px !important;
  background:#237d84 !important;
}
#inicio .step:nth-child(1),
#inicio .step:nth-child(3){
  background:#000 !important;
  border:5px solid rgba(243,243,243,.45) !important;
  border-radius:34px !important;
  padding:18px !important;
}
#inicio .step:nth-child(1)::before,
#inicio .step:nth-child(1)::after,
#inicio .step:nth-child(3)::before,
#inicio .step:nth-child(3)::after{
  content:"" !important;
  position:absolute !important;
  top:50% !important;
  width:42px !important;
  height:calc(100% - 48px) !important;
  transform:translateY(-50%) !important;
  border:5px solid rgba(243,243,243,.35) !important;
  border-radius:26px !important;
  background:transparent !important;
  pointer-events:none !important;
}
#inicio .step:nth-child(1)::before,
#inicio .step:nth-child(3)::before{left:-26px !important;border-right:none !important;}
#inicio .step:nth-child(1)::after,
#inicio .step:nth-child(3)::after{right:-26px !important;border-left:none !important;}
#inicio .step:nth-child(2),
#inicio .step:nth-child(4){
  background:transparent !important;
}
#inicio .step .num{
  font-size:88px !important;
  line-height:.9 !important;
  color:var(--teal-2) !important;
}
#inicio .step h3{
  font-size:30px !important;
  margin:26px 0 18px !important;
  color:#fff !important;
}
#inicio .step p{
  font-size:17px !important;
  line-height:1.18 !important;
  color:#e6f7f5 !important;
  max-width:300px !important;
}

/* ---------- 1) INICIO / BENEFICIOS CON 3 FLECHAS ---------- */
#inicio .benefit-icon{
  border:6px solid #8a8a8a !important;
  background:rgba(120,230,208,.18) !important;
  overflow:visible !important;
}
#inicio .benefit-icon::before,
#inicio .benefit-icon::after{
  display:none !important;
}
#inicio .benefit-icon .tri-arrows{
  position:absolute;
  inset:-10px;
  animation:inicioArrowsSpin 17s linear infinite;
  pointer-events:none;
}
#inicio .benefit-icon .tri-arrows::before{
  content:"";
  position:absolute;
  inset:12px;
  border:4px solid rgba(138,138,138,.45);
  border-radius:50%;
}
#inicio .benefit-icon .tri-arrows span{
  position:absolute;
  width:18px;
  height:18px;
  border-top:6px solid #8a8a8a;
  border-right:6px solid #8a8a8a;
  border-radius:2px;
  background:transparent;
}
#inicio .benefit-icon .tri-arrows span:nth-child(1){top:0;left:22px;transform:rotate(135deg);}
#inicio .benefit-icon .tri-arrows span:nth-child(2){top:16px;right:-2px;transform:rotate(-45deg);}
#inicio .benefit-icon .tri-arrows span:nth-child(3){bottom:-2px;left:50%;transform:translateX(-50%) rotate(45deg);}
@keyframes inicioArrowsSpin{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}

/* ---------- 2) QUIÉNES SOMOS / LÓGICA ILIPAU ---------- */
#quienes-somos .logic-ilipau{
  padding-top:0 !important;
  padding-bottom:34px !important;
}
#quienes-somos .logic-ilipau .section-title{
  text-align:center !important;
  font-size:clamp(34px,4.5vw,62px) !important;
  letter-spacing:-.045em !important;
  margin-bottom:12px !important;
}
#quienes-somos .logic-ilipau .logic-subtitle{
  text-align:center !important;
  font-size:clamp(18px,2vw,28px) !important;
  line-height:1.18 !important;
  color:#333 !important;
  max-width:1180px !important;
  margin:0 auto 34px !important;
}
#quienes-somos .logic-ilipau .value-grid{
  display:grid !important;
  grid-template-columns:repeat(12,1fr) !important;
  gap:22px !important;
  align-items:stretch !important;
}
#quienes-somos .logic-ilipau .value-card{
  display:grid !important;
  grid-template-columns:64px 1fr 88px !important;
  gap:18px !important;
  padding:28px 34px !important;
  min-height:214px !important;
  border-radius:26px !important;
  background:#b8ece7 !important;
  box-shadow:none !important;
  transition:transform .28s ease, box-shadow .28s ease !important;
}
#quienes-somos .logic-ilipau .value-card:hover{
  transform:translateY(-3px) !important;
  box-shadow:0 16px 32px rgba(0,0,0,.08) !important;
}
#quienes-somos .logic-ilipau .value-card:nth-child(1){grid-column:1 / span 6 !important;}
#quienes-somos .logic-ilipau .value-card:nth-child(2){grid-column:7 / span 6 !important;}
#quienes-somos .logic-ilipau .value-card.productivity-light{
  grid-column:1 / span 3 !important;
  background:#d9d9d9 !important;
  color:#111 !important;
  min-height:260px !important;
  max-width:none !important;
  margin:0 !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card{
  grid-column:4 / span 9 !important;
  background:#2d2a2d !important;
  color:#fff !important;
  min-height:260px !important;
  grid-template-columns:minmax(0,1fr) 160px 88px !important;
  align-items:center !important;
}
#quienes-somos .logic-ilipau .value-card .big-num{
  font-size:clamp(62px,4.9vw,94px) !important;
  line-height:1 !important;
  font-weight:800 !important;
  justify-self:end !important;
  transition:color .25s ease !important;
}
#quienes-somos .logic-ilipau .value-card:nth-child(1) .big-num,
#quienes-somos .logic-ilipau .value-card:nth-child(2) .big-num{
  color:#79e0d6 !important;
}
#quienes-somos .logic-ilipau .value-card.productivity-light .big-num{
  color:#9c9c9c !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card .big-num{
  color:#8a8a8a !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#fff !important;
}
#quienes-somos .logic-ilipau .value-card h4{
  font-size:clamp(24px,2.5vw,42px) !important;
  line-height:1.05 !important;
  margin:8px 0 10px !important;
  letter-spacing:-.03em !important;
}
#quienes-somos .logic-ilipau .value-card p{
  font-size:clamp(16px,1.35vw,26px) !important;
  line-height:1.16 !important;
  margin:0 !important;
}
#quienes-somos .logic-ilipau .value-card.productivity-light h4,
#quienes-somos .logic-ilipau .value-card.productivity-light p{
  text-align:left !important;
}
#quienes-somos .logic-ilipau .growth-visual{
  width:150px !important;
  height:120px !important;
}
#quienes-somos .logic-ilipau .rocket-inline{display:none !important;}

/* ---------- 3) SERVICIOS / HERO ROMPECABEZAS ---------- */
#servicios .services-puzzle-wrap img{
  animation:none !important;
  transform:none !important;
}

/* ---------- 3) SERVICIOS / CARRUSEL DE HERRAMIENTAS ---------- */
#servicios .tools-carousel-section{
  background:#000;
  padding:36px 0;
  overflow-x:clip;
  overflow-y:visible;
}

#servicios .tools-carousel{
  width:100%;
  overflow:hidden;
  position:relative;
  padding:4px 0;
}

#servicios .tools-carousel::before,
#servicios .tools-carousel::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:min(120px,12vw);
  z-index:2;
  pointer-events:none;
}

#servicios .tools-carousel::before{
  left:0;
  background:linear-gradient(90deg,#000,rgba(0,0,0,0));
}

#servicios .tools-carousel::after{
  right:0;
  background:linear-gradient(270deg,#000,rgba(0,0,0,0));
}

#servicios .tools-track{
  display:flex;
  width:max-content;
  animation:toolsMarquee 34s linear infinite;
}

#servicios .tools-carousel:hover .tools-track{
  animation-play-state:paused;
}

#servicios .tools-set{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding-right:18px;
}

#servicios .tool-logo{
  --brand:#79e6d0;
  min-width:168px;
  height:74px;
  padding:0 24px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:#8d9899;
  background:rgba(255,255,255,.025);
  opacity:.78;
  transition:color .25s ease, border-color .25s ease, background .25s ease, opacity .25s ease, transform .25s ease;
}

#servicios .brand-sign{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--brand);
  filter:grayscale(1);
  transition:filter .25s ease, color .25s ease, opacity .25s ease;
}

#servicios .tool-logo > i.brand-sign{
  font-size:30px;
  line-height:1;
}

#servicios .tool-logo span{
  font-size:17px;
  font-weight:800;
  line-height:1;
  letter-spacing:0;
}

#servicios .tool-logo .wordmark{
  font-size:22px;
}

#servicios .tool-logo .word-logo{
  min-width:44px;
  font-size:22px;
  font-weight:900;
  line-height:1;
}

#servicios .tool-logo .google-sign{
  gap:0;
  min-width:62px;
  font-size:20px;
  font-weight:900;
  line-height:1;
}

#servicios .google-sign b:nth-child(1){color:#4285f4}
#servicios .google-sign b:nth-child(2){color:#ea4335}
#servicios .google-sign b:nth-child(3){color:#fbbc05}
#servicios .google-sign b:nth-child(4){color:#4285f4}
#servicios .google-sign b:nth-child(5){color:#34a853}
#servicios .google-sign b:nth-child(6){color:#ea4335}

#servicios .zapier-sign{
  width:34px;
  height:34px;
  position:relative;
}

#servicios .zapier-sign i{
  position:absolute;
  left:15px;
  top:4px;
  width:4px;
  height:26px;
  border-radius:999px;
  background:#ff4f00;
  transform-origin:center;
}

#servicios .zapier-sign i:nth-child(2){transform:rotate(30deg)}
#servicios .zapier-sign i:nth-child(3){transform:rotate(60deg)}
#servicios .zapier-sign i:nth-child(4){transform:rotate(90deg)}
#servicios .zapier-sign i:nth-child(5){transform:rotate(120deg)}
#servicios .zapier-sign i:nth-child(6){transform:rotate(150deg)}

#servicios .airtable-sign{
  width:34px;
  height:30px;
  position:relative;
}

#servicios .airtable-sign i{
  position:absolute;
  width:19px;
  height:15px;
  border-radius:4px;
}

#servicios .airtable-sign i:nth-child(1){left:7px;top:0;background:#fcb400}
#servicios .airtable-sign i:nth-child(2){left:0;bottom:0;background:#18bfff}
#servicios .airtable-sign i:nth-child(3){right:0;bottom:0;background:#f82b60}

#servicios .notion-sign{
  width:32px;
  height:32px;
  border:2px solid currentColor;
  color:#fff;
  font-family:Georgia, serif;
  font-size:22px;
  font-weight:900;
  line-height:1;
}

#servicios .tool-logo:hover{
  color:var(--brand);
  border-color:color-mix(in srgb, var(--brand) 55%, transparent);
  background:rgba(255,255,255,.06);
  opacity:1;
  transform:translateY(-2px);
}

#servicios .tool-logo:hover .brand-sign{
  filter:grayscale(0);
}

#servicios .tool-logo.google{--brand:#4285f4}
#servicios .tool-logo.n8n{--brand:#ea4b71}
#servicios .tool-logo.slack{--brand:#7c3aed}
#servicios .tool-logo.zapier{--brand:#ff4f00}
#servicios .tool-logo.make{--brand:#6d2df6}
#servicios .tool-logo.airtable{--brand:#18bfff}
#servicios .tool-logo.notion{--brand:#ffffff}
#servicios .tool-logo.hubspot{--brand:#ff7a59}
#servicios .tool-logo.salesforce{--brand:#00a1e0}
#servicios .tool-logo.trello{--brand:#0079bf}

@keyframes toolsMarquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

@media (max-width:700px){
  #servicios .tool-logo{
    min-width:140px;
    height:64px;
    padding:0 18px;
  }

  #servicios .tool-logo > i.brand-sign{
    font-size:26px;
  }

  #servicios .notion-sign{
    width:28px;
    height:28px;
  }

  #servicios .zapier-sign{
    width:28px;
    height:28px;
  }

  #servicios .zapier-sign i{
    left:12px;
    top:3px;
    height:22px;
  }

  #servicios .airtable-sign{
    width:30px;
    height:27px;
  }

  #servicios .tool-logo span{
    font-size:15px;
  }
}

/* ---------- 3) SERVICIOS / METODOLOGÍA ---------- */
#servicios #metodologia .steps{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(240px,1fr)) !important;
  gap:28px !important;
  margin-top:38px !important;
  overflow:hidden !important;
}
#servicios #metodologia .step{
  position:relative !important;
  min-height:330px !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}
#servicios #metodologia .step:nth-child(1),
#servicios #metodologia .step:nth-child(3){
  background:#000 !important;
  border:5px solid rgba(243,243,243,.38) !important;
  border-radius:34px !important;
  padding:18px !important;
}
#servicios #metodologia .step:nth-child(1)::before,
#servicios #metodologia .step:nth-child(1)::after,
#servicios #metodologia .step:nth-child(3)::before,
#servicios #metodologia .step:nth-child(3)::after{
  content:"" !important;
  position:absolute !important;
  top:50% !important;
  width:42px !important;
  height:calc(100% - 48px) !important;
  transform:translateY(-50%) !important;
  border:5px solid rgba(243,243,243,.28) !important;
  border-radius:26px !important;
  background:transparent !important;
  pointer-events:none !important;
}
#servicios #metodologia .step:nth-child(1)::before,
#servicios #metodologia .step:nth-child(3)::before{left:-26px !important;border-right:none !important;}
#servicios #metodologia .step:nth-child(1)::after,
#servicios #metodologia .step:nth-child(3)::after{right:-26px !important;border-left:none !important;}
#servicios #metodologia .step:nth-child(2),
#servicios #metodologia .step:nth-child(4){
  background:transparent !important;
}
#servicios #metodologia .step .inner{
  min-height:100% !important;
  border-radius:28px !important;
  padding:26px 24px 24px !important;
  background:#237d84 !important;
}
#servicios #metodologia .step:nth-child(2) .inner,
#servicios #metodologia .step:nth-child(4) .inner{
  background:#237d84 !important;
}
#servicios #metodologia .step .num{
  font-size:88px !important;
  color:var(--teal-2) !important;
  line-height:.9 !important;
}
#servicios #metodologia .step h3{
  font-size:30px !important;
  margin:26px 0 18px !important;
  color:#fff !important;
}
#servicios #metodologia .step p{
  font-size:17px !important;
  line-height:1.18 !important;
  color:#e6f7f5 !important;
  max-width:300px !important;
}

/* ---------- 4) CONTACTO / VIDEO SILUETAS ---------- */
#contacto .contact-ring-glow{
  width:430px !important;
  height:430px !important;
  background:radial-gradient(circle, rgba(120,230,208,.30) 0%, rgba(120,230,208,.14) 34%, rgba(120,230,208,.07) 54%, rgba(120,230,208,0) 74%) !important;
  filter:blur(8px) !important;
}
#contacto .contact-group{
  width:min(520px, 96%) !important;
  height:360px !important;
}
#contacto .contact-person{
  bottom:10px !important;
  width:150px !important;
  height:220px !important;
}
#contacto .contact-person.center{
  width:170px !important;
  height:248px !important;
  bottom:0 !important;
  animation:contactCenterClip 4.8s ease-in-out infinite !important;
}
#contacto .contact-person.left{
  left:42px !important;
  animation:contactSideLeft 4.8s ease-in-out infinite !important;
}
#contacto .contact-person.right{
  right:42px !important;
  animation:contactSideRight 4.8s ease-in-out infinite !important;
}
@keyframes contactSideLeft{
  0%,18%,100%{transform:translateX(0);opacity:1;}
  34%,56%{transform:translateX(44px);opacity:0;}
  72%{transform:translateX(18px);opacity:.55;}
}
@keyframes contactSideRight{
  0%,18%,100%{transform:translateX(0);opacity:1;}
  34%,56%{transform:translateX(-44px);opacity:0;}
  72%{transform:translateX(-18px);opacity:.55;}
}
@keyframes contactCenterClip{
  0%,18%,100%{transform:translateX(-50%) scale(1);}
  34%,56%{transform:translateX(-50%) scale(1.02);}
  72%{transform:translateX(-50%) scale(1.01);}
}

@media (max-width: 900px){
  #inicio .steps,
  #servicios #metodologia .steps{grid-template-columns:1fr !important;}
  #inicio .step:nth-child(1)::before,
  #inicio .step:nth-child(1)::after,
  #inicio .step:nth-child(3)::before,
  #inicio .step:nth-child(3)::after,
  #servicios #metodologia .step:nth-child(1)::before,
  #servicios #metodologia .step:nth-child(1)::after,
  #servicios #metodologia .step:nth-child(3)::before,
  #servicios #metodologia .step:nth-child(3)::after{display:none !important;}
  #quienes-somos .logic-ilipau .value-grid{grid-template-columns:1fr !important;}
  #quienes-somos .logic-ilipau .value-card:nth-child(1),
  #quienes-somos .logic-ilipau .value-card:nth-child(2),
  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{grid-column:auto !important;}
  #quienes-somos .logic-ilipau .value-card.scalability-card{grid-template-columns:1fr !important;}
}

/* ===== V21 SERVICIOS HERO LIMPIO + FLECHAS ESQUINA IZQ ===== */
#servicios .hero-visual .glow{
  display:none !important;
}
#servicios .services-puzzle-wrap img{
  filter:none !important;
  box-shadow:none !important;
  animation:none !important;
}
#servicios .services-puzzle-wrap{
  position:relative !important;
  width:min(430px, 92%) !important;
  aspect-ratio:1/1 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
#servicios .services-puzzle-wrap .arrow{
  position:absolute !important;
  height:12px !important;
  background:var(--teal-2) !important;
  border-radius:999px !important;
  opacity:1 !important;
  z-index:3 !important;
}
#servicios .services-puzzle-wrap .arrow::after{
  content:"" !important;
  position:absolute !important;
  right:-2px !important;
  top:50% !important;
  width:22px !important;
  height:22px !important;
  border-top:8px solid var(--teal-2) !important;
  border-right:8px solid var(--teal-2) !important;
  transform:translateY(-50%) rotate(45deg) !important;
  border-radius:2px !important;
}
#servicios .services-puzzle-wrap .arrow.a1{
  left:14px !important;
  bottom:88px !important;
  width:96px !important;
  transform:rotate(-18deg) !important;
  animation:servLeftArrow1 2.2s ease-in-out infinite !important;
}
#servicios .services-puzzle-wrap .arrow.a2{
  left:52px !important;
  bottom:28px !important;
  width:108px !important;
  transform:rotate(-55deg) !important;
  animation:servLeftArrow2 2.8s ease-in-out infinite !important;
}
#servicios .services-puzzle-wrap .arrow.a3{
  left:148px !important;
  bottom:12px !important;
  width:78px !important;
  transform:rotate(-84deg) !important;
  animation:servLeftArrow3 2.4s ease-in-out infinite !important;
}
@keyframes servLeftArrow1{
  0%,100%{transform:rotate(-18deg) translateY(0);}
  50%{transform:rotate(-18deg) translateY(-9px);}
}
@keyframes servLeftArrow2{
  0%,100%{transform:rotate(-55deg) translateY(0);}
  50%{transform:rotate(-55deg) translateY(11px);}
}
@keyframes servLeftArrow3{
  0%,100%{transform:rotate(-84deg) translateY(0);}
  50%{transform:rotate(-84deg) translateY(-7px);}
}

/* ===== V23 SOLO INICIO / BENEFIT ICONS CON 3 FLECHAS EN CÍRCULO ===== */
#inicio .benefit-icon{
  border:6px solid #8a8a8a !important;
  position:relative !important;
  overflow:visible !important;
}
#inicio .benefit-icon::before,
#inicio .benefit-icon::after{
  display:none !important;
  content:none !important;
}
#inicio .benefit-icon .tri-arrows{
  position:absolute !important;
  inset:-6px !important;
  pointer-events:none !important;
  animation:inicioArrowsSpinV23 14s linear infinite !important;
  transform-origin:center center !important;
  z-index:3 !important;
}
#inicio .benefit-icon .tri-arrows::before{
  display:none !important;
  content:none !important;
}
#inicio .benefit-icon .tri-arrows span{
  position:absolute !important;
  inset:0 !important;
  width:auto !important;
  height:auto !important;
  background:transparent !important;
  border:3px solid transparent !important;
  border-top-color:#8a8a8a !important;
  border-right-color:#8a8a8a !important;
  border-radius:50% !important;
  transform-origin:center center !important;
}
#inicio .benefit-icon .tri-arrows span::after{
  content:"" !important;
  position:absolute !important;
  top:18px !important;
  right:2px !important;
  width:20px !important;
  height:20px !important;
  border-top:5px solid #8a8a8a !important;
  border-right:5px solid #8a8a8a !important;
  transform:rotate(105deg) !important;
  border-radius:2px !important;
  background:transparent !important;
}
#inicio .benefit-icon .tri-arrows span:nth-child(1){
  transform:rotate(0deg) !important;
}
#inicio .benefit-icon .tri-arrows span:nth-child(2){
  transform:rotate(120deg) !important;
}
#inicio .benefit-icon .tri-arrows span:nth-child(3){
  transform:rotate(240deg) !important;
}
@keyframes inicioArrowsSpinV23{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}

/* ===== V24 QUIENES SOMOS / AJUSTE PRODUCTIVIDAD Y ESCALABILIDAD ===== */
#quienes-somos .logic-ilipau .value-grid{
  display:grid !important;
  grid-template-columns:repeat(12,1fr) !important;
  gap:22px !important;
  align-items:stretch !important;
}
#quienes-somos .logic-ilipau .value-card.productivity-light{
  grid-column:1 / span 5 !important;
  background:#d9d9d9 !important;
  color:#111 !important;
  min-height:260px !important;
  max-width:none !important;
  margin:0 !important;
  display:grid !important;
  grid-template-columns:64px 1fr 88px !important;
  gap:18px !important;
  align-items:start !important;
  padding:28px 28px 24px !important;
}
#quienes-somos .logic-ilipau .value-card.productivity-light h4{
  text-align:left !important;
  margin:8px 0 10px !important;
}
#quienes-somos .logic-ilipau .value-card.productivity-light p{
  text-align:left !important;
  max-width:100% !important;
  margin:0 !important;
  line-height:1.14 !important;
  word-break:normal !important;
  overflow-wrap:break-word !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card{
  grid-column:6 / span 7 !important;
  background:#2d2a2d !important;
  color:#fff !important;
  min-height:260px !important;
  grid-template-columns:minmax(0,1fr) 160px 88px !important;
  align-items:center !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card .wide-copy{
  padding-right:8px !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card p{
  max-width:100% !important;
  line-height:1.12 !important;
}
@media (max-width: 900px){
  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-column:auto !important;
  }
}

/* ===== V29 QUIÉNES SOMOS / PRODUCTIVIDAD MÁS ANCHA Y MISMO NIVEL ===== */
#quienes-somos .logic-ilipau .value-grid{
  display:grid !important;
  grid-template-columns:repeat(12,1fr) !important;
  gap:22px !important;
  align-items:start !important;
}

/* PRODUCTIVIDAD: misma fila, más ancha hacia la derecha, contenido dentro */
#quienes-somos .logic-ilipau .value-card.productivity-light{
  grid-column:1 / span 5 !important;
  grid-row:2 !important;
  width:calc(100% + 34px) !important;
  max-width:none !important;
  margin:0 !important;
  justify-self:start !important;
  overflow:hidden !important;

  display:grid !important;
  grid-template-columns:52px minmax(0,1fr) 72px !important;
  gap:14px !important;
  align-items:start !important;
  padding:28px 24px 24px !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light .icon.brand-icon{
  width:52px !important;
  height:52px !important;
  margin:0 !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light > div:nth-child(2){
  min-width:0 !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light h4{
  font-size:clamp(22px, 2vw, 34px) !important;
  line-height:1.02 !important;
  margin:6px 0 10px !important;
  text-align:left !important;
  word-break:normal !important;
  overflow-wrap:anywhere !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light p{
  font-size:clamp(14px, 1.15vw, 20px) !important;
  line-height:1.12 !important;
  margin:0 !important;
  text-align:left !important;
  max-width:100% !important;
  overflow-wrap:anywhere !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light .big-num{
  font-size:clamp(56px, 4.2vw, 84px) !important;
  line-height:.95 !important;
  align-self:start !important;
  justify-self:end !important;
}

/* ESCALABILIDAD: misma fila que productividad, sin bajar */
#quienes-somos .logic-ilipau .value-card.scalability-card{
  grid-column:7 / span 6 !important;
  grid-row:2 !important;
  margin-top:0 !important;
  align-self:start !important;
}

@media (max-width:900px){
  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-column:auto !important;
    grid-row:auto !important;
    width:100% !important;
  }
}

/* ===== V30 HOVER NUMEROS TARJETAS ===== */
#quienes-somos .logic-ilipau .value-card .big-num{
  transition: color .25s ease, opacity .25s ease;
  opacity:.25;
}
#quienes-somos .logic-ilipau .value-card:hover .big-num{
  opacity:.6;
  color:#000 !important;
}
#quienes-somos .logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#fff !important;
  opacity:.5;
}

/* ===== V31 HOVER PREMIUM NUMEROS (GLOW + SUAVE ESCALA) ===== */
#quienes-somos .logic-ilipau .value-card .big-num{
  transition: color .3s ease, opacity .3s ease, transform .3s ease, text-shadow .3s ease;
  opacity:.25;
}

#quienes-somos .logic-ilipau .value-card:hover .big-num{
  opacity:.75;
  color:#000 !important;
  transform: scale(1.05);
  text-shadow: 0 0 8px rgba(0,0,0,0.15);
}

/* versión para tarjeta oscura */
#quienes-somos .logic-ilipau .value-card.scalability-card:hover .big-num{
  color:#ffffff !important;
  opacity:.7;
  transform: scale(1.05);
  text-shadow: 0 0 10px rgba(255,255,255,0.25);
}


/* ===== V32 LIMPIEZA CONSERVADORA + RESPONSIVE FINAL ===== */

/* Limpieza visual global */
body{
  overflow-x:hidden;
}
img, svg{
  max-width:100%;
  height:auto;
}

/* Mantener navbar consistente y usable */
.navbar .container{
  gap:16px;
}
.brand img{
  height:auto;
  max-width:100%;
}

/* Logo fluido: grande en escritorio, más compacto en tablet y mobile */
.brand img{
  width:164px !important;
  height:auto !important;
  max-height:164px !important;
  object-fit:contain;
}

/* Asegurar que textos largos no rompan tarjetas */
.card h4,
.value-card h4,
.quick-card h3,
.step h3,
.form-card h3{
  overflow-wrap:anywhere;
}
.card p,
.value-card p,
.quick-card p,
.step p{
  overflow-wrap:anywhere;
}

/* Mejoras generales de grid */
.cards,
.benefits,
.value-grid,
.quick-cards{
  align-items:stretch;
}

/* Inicio */
#inicio .hero-grid{
  align-items:center;
}
#inicio .benefits{
  align-items:start;
}
#inicio .benefit{
  min-width:0;
}
#inicio .benefit p{
  max-width:260px;
  margin:0 auto;
}

/* Quiénes Somos */
#quienes-somos .mission-grid{
  align-items:start;
}
#quienes-somos .logic-ilipau .value-card{
  min-width:0;
}
#quienes-somos .logic-ilipau .value-card.productivity-light h4,
#quienes-somos .logic-ilipau .value-card.productivity-light p,
#quienes-somos .logic-ilipau .value-card.scalability-card h4,
#quienes-somos .logic-ilipau .value-card.scalability-card p{
  overflow-wrap:anywhere;
}
#quienes-somos .logic-ilipau .value-card.productivity-light .big-num,
#quienes-somos .logic-ilipau .value-card.scalability-card .big-num{
  white-space:nowrap;
}

/* Servicios */
#servicios .service-solution-grid{
  align-items:stretch;
}
#servicios .service-card{
  min-width:0;
}
#servicios .service-card .chips{
  row-gap:10px;
}
#servicios #metodologia .step{
  min-width:0;
}

/* Contacto */
#contacto .contact-card-layout,
#contacto .contact-wrap{
  align-items:start;
}
#contacto .form-card,
#contacto .quick-card{
  min-width:0;
}

/* ===== TABLET ===== */
@media (max-width: 1180px){
  .brand img{
    width:142px !important;
    max-height:142px !important;
  }

  .container{
    padding:0 22px !important;
  }

  .hero h1,
  .hero-contact h1{
    font-size:clamp(48px, 6vw, 64px) !important;
  }

  .cards{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }

  #inicio .benefits{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:24px !important;
  }

  #quienes-somos .mission-grid{
    grid-template-columns:1fr 1fr !important;
    gap:28px !important;
  }

  #servicios .service-solution-grid{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }

  #servicios #metodologia .steps,
  #inicio .steps{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }

  #contacto .contact-card-layout{
    grid-template-columns:1fr !important;
    gap:28px !important;
  }
}

/* ===== MOBILE ===== */
@media (max-width: 860px){
  .navbar .container{
    min-height:auto !important;
    height:auto !important;
    padding-top:10px !important;
    padding-bottom:10px !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:space-between !important;
    flex-wrap:wrap !important;
  }

  .brand{
    display:flex;
    justify-content:flex-start;
    width:auto;
  }

  .brand img{
    width:92px !important;
    max-height:92px !important;
  }

  .menu-toggle{
    width:46px;
    height:46px;
    border:0;
    border-radius:12px;
    background:var(--teal-2);
    color:#041416;
    display:grid;
    place-items:center;
    gap:4px;
    padding:11px;
    cursor:pointer;
    box-shadow:0 10px 24px rgba(0,0,0,.12);
  }

  .menu-toggle span{
    width:24px;
    height:3px;
    border-radius:999px;
    background:currentColor;
    display:block;
    transition:transform .24s ease, opacity .24s ease;
  }

  .menu-toggle[aria-expanded="true"] span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }

  .menu-toggle[aria-expanded="true"] span:nth-child(2){
    opacity:0;
  }

  .menu-toggle[aria-expanded="true"] span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }

  .navlinks{
    width:100%;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:flex-start !important;
    gap:0 !important;
    max-height:0;
    overflow:hidden;
    opacity:0;
    pointer-events:none;
    transition:max-height .28s ease, opacity .2s ease, padding-top .28s ease;
  }

  .navlinks.is-open{
    max-height:320px;
    opacity:1;
    pointer-events:auto;
    padding-top:12px;
  }

  .navlinks a{
    font-size:16px !important;
    padding:14px 4px;
    text-align:center;
    border-top:1px solid rgba(10, 127, 138, .16);
  }

  .navlinks a.active::after{
    display:none;
  }

  .hero-grid,
  .contact-wrap,
  .contact-card-layout,
  .mission-grid{
    grid-template-columns:1fr !important;
    gap:24px !important;
  }

  .hero-visual,
  .hero-visual.nodos-hero{
    height:auto !important;
    min-height:280px !important;
  }

  .hero,
  .hero-contact{
    padding-top:24px !important;
    padding-bottom:36px !important;
  }

  .hero h1,
  .hero-contact h1{
    font-size:clamp(40px, 11vw, 56px) !important;
    line-height:0.98 !important;
  }

  .hero p,
  .hero-contact p{
    font-size:18px !important;
  }

  .cta-row{
    width:100%;
  }

  .btn{
    width:100%;
    min-height:52px;
  }

  .cards,
  #inicio .benefits,
  .quick-cards,
  .value-grid,
  #servicios .service-solution-grid,
  #inicio .steps,
  #servicios #metodologia .steps{
    grid-template-columns:1fr !important;
  }

  .step::before,
  .step::after,
  #inicio .step:nth-child(1)::before,
  #inicio .step:nth-child(1)::after,
  #inicio .step:nth-child(3)::before,
  #inicio .step:nth-child(3)::after,
  #servicios #metodologia .step:nth-child(1)::before,
  #servicios #metodologia .step:nth-child(1)::after,
  #servicios #metodologia .step:nth-child(3)::before,
  #servicios #metodologia .step:nth-child(3)::after{
    display:none !important;
  }

  #quienes-somos .logic-ilipau .value-grid{
    grid-template-columns:1fr !important;
  }

  #quienes-somos .logic-ilipau .value-card:nth-child(1),
  #quienes-somos .logic-ilipau .value-card:nth-child(2),
  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-column:auto !important;
    grid-row:auto !important;
    width:100% !important;
    max-width:100% !important;
  }

  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-template-columns:52px minmax(0,1fr) 72px !important;
    padding:24px 20px !important;
  }

  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-template-columns:1fr !important;
  }

  #quienes-somos .logic-ilipau .growth-visual{
    width:110px !important;
    height:86px !important;
    margin:8px auto 0 !important;
  }

  .footer .container{
    flex-direction:column !important;
    text-align:center !important;
  }
}

@media (max-width: 560px){
  .brand img{
    width:76px !important;
    max-height:76px !important;
  }

  .container{
    padding:0 16px !important;
  }

  .section-title{
    font-size:32px !important;
  }

  .section-sub,
  .logic-ilipau .logic-subtitle{
    font-size:17px !important;
  }

  .hero h1,
  .hero-contact h1{
    font-size:42px !important;
  }

  .hero p,
  .hero-contact p,
  .card p,
  .quick-card p,
  .step p,
  .benefit p{
    font-size:16px !important;
  }

  .card h4,
  .benefit h3{
    font-size:20px !important;
  }

  .step .num{
    font-size:72px !important;
  }

  .step h3{
    font-size:26px !important;
  }

  .form-card h3{
    font-size:24px !important;
  }

  #inicio .benefit-icon{
    width:118px !important;
    height:118px !important;
  }

  #quienes-somos .logic-ilipau .value-card .big-num{
    font-size:54px !important;
  }
}

/* Referencia visual example1.png: metodologia de inicio */
#inicio .steps{
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  gap:24px !important;
  margin-top:28px !important;
  overflow:visible !important;
}

#inicio .step{
  min-height:280px !important;
  padding:0 !important;
  border:4px solid #f3f3f3 !important;
  border-radius:24px !important;
  background:#103f43 !important;
  box-shadow:none !important;
  transform:none !important;
}

#inicio .step:hover{
  transform:none !important;
  box-shadow:none !important;
}

#inicio .step .inner{
  min-height:280px !important;
  height:100% !important;
  padding:38px 22px 30px !important;
  border-radius:24px !important;
  background:#103f43 !important;
}

#inicio .step:nth-child(1),
#inicio .step:nth-child(3){
  z-index:2;
  margin-left:0 !important;
  margin-right:0 !important;
  border:4px solid #f3f3f3 !important;
  background:#000 !important;
}

#inicio .step:nth-child(1) .inner,
#inicio .step:nth-child(3) .inner{
  background:#000 !important;
}

#inicio .step:nth-child(2),
#inicio .step:nth-child(4){
  background:#103f43 !important;
}

#inicio .step:nth-child(2) .inner,
#inicio .step:nth-child(4) .inner{
  background:#103f43 !important;
}

#inicio .step::before,
#inicio .step::after{
  display:none !important;
}

#inicio .step .num{
  font-size:62px !important;
  line-height:.85 !important;
  letter-spacing:0 !important;
  color:#1ed8cf !important;
}

#inicio .step h3{
  font-size:21px !important;
  line-height:1.05 !important;
  margin:34px 0 20px !important;
  letter-spacing:0 !important;
  color:#fff !important;
}

#inicio .step:nth-child(2) h3,
#inicio .step:nth-child(4) h3,
#inicio .step:nth-child(2) p,
#inicio .step:nth-child(4) p{
  color:#c7e7e5 !important;
}

#inicio .step p{
  font-size:15px !important;
  line-height:1.16 !important;
  max-width:220px !important;
  color:#fff !important;
}

@media (max-width:1180px){
  #inicio .steps{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:22px !important;
  }
}

@media (max-width:640px){
  #inicio .steps{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }

  #inicio .step,
  #inicio .step .inner{
    min-height:250px !important;
  }
}

/* Quienes somos: productividad 4/12 y escalabilidad 8/12 */
#quienes-somos .logic-ilipau .value-card.productivity-light{
  grid-column:1 / span 4 !important;
  grid-row:2 !important;
  width:100% !important;
}

#quienes-somos .logic-ilipau .value-card.scalability-card{
  grid-column:5 / span 8 !important;
  grid-row:2 !important;
  width:100% !important;
}

@media (max-width:900px){
  #quienes-somos .logic-ilipau .value-card.productivity-light,
  #quienes-somos .logic-ilipau .value-card.scalability-card{
    grid-column:auto !important;
    grid-row:auto !important;
  }
}

/* Quienes somos: centrar contenido y uniformar textos de value cards */
#quienes-somos .logic-ilipau .value-card{
  align-items:center !important;
  justify-items:center !important;
  text-align:center !important;
  min-height:240px !important;
  position:relative !important;
  padding-right:92px !important;
}

#quienes-somos .logic-ilipau .value-card > div{
  align-self:center !important;
}

#quienes-somos .logic-ilipau .value-card .icon.brand-icon{
  justify-self:center !important;
  align-self:center !important;
  margin:0 !important;
}

#quienes-somos .logic-ilipau .value-card:not(.scalability-card),
#quienes-somos .logic-ilipau .value-card.productivity-light{
  grid-template-columns:64px minmax(0,1fr) !important;
}

#quienes-somos .logic-ilipau .value-card h4,
#quienes-somos .logic-ilipau .value-card.productivity-light h4,
#quienes-somos .logic-ilipau .value-card.scalability-card h4{
  font-size:25px !important;
  line-height:1.08 !important;
  margin:0 0 12px !important;
  text-align:left !important;
}

#quienes-somos .logic-ilipau .value-card p,
#quienes-somos .logic-ilipau .value-card.productivity-light p,
#quienes-somos .logic-ilipau .value-card.scalability-card p{
  font-size:16px !important;
  line-height:1.22 !important;
  margin:0 !important;
  max-width:420px !important;
  text-align:left !important;
  text-align-last:auto !important;
}

#quienes-somos .logic-ilipau .value-card .big-num{
  position:absolute !important;
  top:20px !important;
  right:24px !important;
  align-self:auto !important;
  justify-self:auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:0 !important;
  font-size:58px !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  text-align:center !important;
  margin:0 !important;
}

#quienes-somos .logic-ilipau .value-card.productivity-light .big-num{
  position:absolute !important;
  top:20px !important;
  right:24px !important;
  align-self:auto !important;
  justify-self:auto !important;
  width:auto !important;
  min-width:0 !important;
  font-size:58px !important;
  line-height:1 !important;
  margin:0 !important;
}

#quienes-somos .logic-ilipau .value-card.scalability-card .wide-copy{
  align-self:center !important;
  justify-self:center !important;
  padding:0 !important;
}

#quienes-somos .logic-ilipau .value-card.scalability-card .growth-visual{
  align-self:center !important;
  justify-self:center !important;
}

@media (max-width:640px){
  #quienes-somos .logic-ilipau .value-card{
    grid-template-columns:1fr !important;
    gap:18px !important;
    padding-right:20px !important;
    padding-top:72px !important;
  }

  #quienes-somos .logic-ilipau .value-card h4,
  #quienes-somos .logic-ilipau .value-card.productivity-light h4,
  #quienes-somos .logic-ilipau .value-card.scalability-card h4{
    font-size:24px !important;
  }

  #quienes-somos .logic-ilipau .value-card p,
  #quienes-somos .logic-ilipau .value-card.productivity-light p,
  #quienes-somos .logic-ilipau .value-card.scalability-card p{
    font-size:16px !important;
  }
}

/* Extracted inline styles */
.inline-style-01{padding-top:18px;}
.inline-style-02{text-align:center;}
.inline-style-03{font-size:20px;color:#5b5b5b;max-width:760px;margin:0 auto;}
.inline-style-04{padding-top:46px;padding-bottom:58px;}
.inline-style-05{color:#dffefe;}
.inline-style-06{padding-top:0;}
.inline-style-07{padding-top:50px;}
.inline-style-08{max-width:900px;}
.inline-style-09{background:#3f3f40;color:#fff;}
.inline-style-10{color:#6fe6e3;}
.inline-style-11{color:#bfc7c7;}
.inline-style-12{background:#7be7de;color:#183b3c;}
.inline-style-13{border-color:rgba(17,78,81,.2);}
.inline-style-14{background:#63d6ce;color:#114e51;}
.inline-style-15{background:#83cfc8;color:#114e51;}
.inline-style-16{color:#2b5a5d;}
.inline-style-17{font-weight:800;margin-top:18px;}
.inline-style-18{max-width:980px;}
.inline-style-19{font-size:46px;}
.inline-style-20{background:#24d8cf1f;color:#23c7c0;}
.inline-style-21{font-size:42px;margin-top:10px;}
.inline-style-22{font-size:18px;color:#2c2c2c;margin:0 0 16px;}
.inline-style-23{font-size:18px;color:#2c2c2c;margin:0;}

/* Formularios: separar texto y placeholder de los bordes */
input,
textarea{
  padding-left:10px !important;
  padding-right:10px !important;
  color:#000;
}

input::placeholder,
textarea::placeholder{
  padding-left:2px;
  color:rgba(30,30,30,.58);
}

.form-alert{
  display:none;
  margin:12px 0 14px;
  padding:11px 14px;
  border-radius:12px;
  font-size:14px;
  font-weight:800;
  line-height:1.25;
}

.form-alert.is-success{
  display:block;
  color:#0f3d38;
  background:#baf4e9;
  border:1px solid rgba(38,214,203,.55);
}

.form-alert.is-error{
  display:block;
  color:#5d1717;
  background:#ffdada;
  border:1px solid rgba(190,38,38,.28);
}

.submit[disabled]{
  cursor:not-allowed;
  opacity:.65;
}

/* Servicios: metodologia sin bordes y con tarjetas escalonadas */
body[data-page="servicios"] #metodologia .steps{
  align-items:start !important;
  overflow:visible !important;
  padding-top:18px !important;
  padding-bottom:54px !important;
}

body[data-page="servicios"] #metodologia .step{
  border:0 !important;
  border-radius:28px !important;
  padding:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  min-height:360px !important;
  width:100% !important;
}

body[data-page="servicios"] #metodologia .step::before,
body[data-page="servicios"] #metodologia .step::after{
  display:none !important;
  content:none !important;
}

body[data-page="servicios"] #metodologia .step .inner{
  min-height:360px !important;
  height:360px !important;
  width:100% !important;
  border:0 !important;
  border-radius:28px !important;
  padding:38px 24px 30px !important;
  background:#237d84 !important;
  overflow:hidden !important;
}

body[data-page="servicios"] #metodologia .step .num{
  font-size:78px !important;
  line-height:.9 !important;
  margin:0 0 28px !important;
}

body[data-page="servicios"] #metodologia .step h3{
  font-size:28px !important;
  line-height:1.08 !important;
  margin:0 0 18px !important;
}

body[data-page="servicios"] #metodologia .step p{
  font-size:16px !important;
  line-height:1.18 !important;
  max-width:100% !important;
}

body[data-page="servicios"] #metodologia .step:nth-child(odd){
  transform:translateY(0) !important;
}

body[data-page="servicios"] #metodologia .step:nth-child(even){
  transform:translateY(54px) !important;
}

body[data-page="servicios"] #metodologia .step:hover{
  transform:translateY(-4px) !important;
}

body[data-page="servicios"] #metodologia .step:nth-child(even):hover{
  transform:translateY(50px) !important;
}

@media (max-width:900px){
  body[data-page="servicios"] #metodologia .steps{
    padding-top:0 !important;
  }

  body[data-page="servicios"] #metodologia .step,
  body[data-page="servicios"] #metodologia .step:nth-child(odd),
  body[data-page="servicios"] #metodologia .step:nth-child(even),
  body[data-page="servicios"] #metodologia .step:hover,
  body[data-page="servicios"] #metodologia .step:nth-child(even):hover{
    transform:none !important;
  }
}

/* Servicios: override fuerte para tarjetas uniformes sin contornos */
body[data-page="servicios"] #servicios #metodologia .steps{
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  align-items:start !important;
  gap:28px !important;
  overflow:visible !important;
  padding-top:18px !important;
  padding-bottom:54px !important;
}

body[data-page="servicios"] #servicios #metodologia .step,
body[data-page="servicios"] #servicios #metodologia .step:nth-child(1),
body[data-page="servicios"] #servicios #metodologia .step:nth-child(2),
body[data-page="servicios"] #servicios #metodologia .step:nth-child(3),
body[data-page="servicios"] #servicios #metodologia .step:nth-child(4){
  width:100% !important;
  min-height:360px !important;
  padding:0 !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}

body[data-page="servicios"] #servicios #metodologia .step::before,
body[data-page="servicios"] #servicios #metodologia .step::after,
body[data-page="servicios"] #servicios #metodologia .step:nth-child(1)::before,
body[data-page="servicios"] #servicios #metodologia .step:nth-child(1)::after,
body[data-page="servicios"] #servicios #metodologia .step:nth-child(3)::before,
body[data-page="servicios"] #servicios #metodologia .step:nth-child(3)::after{
  display:none !important;
  content:none !important;
  border:0 !important;
}

body[data-page="servicios"] #servicios #metodologia .step .inner{
  width:100% !important;
  height:360px !important;
  min-height:360px !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  border-radius:28px !important;
  background:#237d84 !important;
  padding:38px 24px 30px !important;
}

body[data-page="servicios"] #servicios #metodologia .step:nth-child(odd){
  transform:translateY(0) !important;
}

body[data-page="servicios"] #servicios #metodologia .step:nth-child(even){
  transform:translateY(54px) !important;
}

@media (max-width:900px){
  body[data-page="servicios"] #servicios #metodologia .steps{
    grid-template-columns:1fr !important;
    padding-top:0 !important;
    padding-bottom:0 !important;
  }

  body[data-page="servicios"] #servicios #metodologia .step,
  body[data-page="servicios"] #servicios #metodologia .step:nth-child(odd),
body[data-page="servicios"] #servicios #metodologia .step:nth-child(even){
    transform:none !important;
  }
}

/* Heroes: bloque de texto uniforme entre paginas */
.hero-copy{
  max-width:620px !important;
  align-self:center !important;
}

.hero-copy h1{
  font-size:clamp(48px, 6.4vw, 80px) !important;
  line-height:.96 !important;
  letter-spacing:-.055em !important;
  margin:18px 0 18px !important;
}

.hero-copy p{
  font-size:20px !important;
  line-height:1.18 !important;
  max-width:590px !important;
  margin:0 0 30px !important;
}

@media (max-width:860px){
  .hero-copy h1{
    font-size:clamp(40px, 11vw, 56px) !important;
  }

  .hero-copy p{
    font-size:18px !important;
  }
}

@media (max-width:560px){
  .hero-copy h1{
    font-size:42px !important;
  }

  .hero-copy p{
    font-size:16px !important;
  }
}
