/* ═══════════════════════════════════════════════════════════════
   TS3+ STYLES v5
═══════════════════════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --dark:#0c0d14;--dark2:#101118;--dark3:#161722;
  --white:#fff;--off:#f7f8fc;--border:#eaecf2;--border-d:rgba(255,255,255,0.08);
  --blue:#3a5af5;--blue-l:#5c88ff;--blue-bg:rgba(58,90,245,0.10);
  --orange:#f05a1e;--orange-l:#ff7a42;--orange-bg:rgba(240,90,30,0.10);
  --text:#0d0f14;--muted:#6b7280;--muted-d:#8892a4;
  --font:'Outfit',system-ui,sans-serif;--mono:'JetBrains Mono','Courier New',monospace;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:var(--font)}
img{display:block;max-width:100%}

/* ── Animations ─────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulseRing{0%{transform:scale(1);opacity:.7}100%{transform:scale(2.2);opacity:0}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes blob1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.08)}66%{transform:translate(-20px,20px) scale(0.95)}}
@keyframes blob2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-35px,25px) scale(1.05)}66%{transform:translate(30px,-15px) scale(0.97)}}
@keyframes blob3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-25px,-35px) scale(1.06)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.fade-up{animation:fadeUp .7s ease both}
.fade-in{animation:fadeIn .6s ease both}
.delay-1{animation-delay:.1s}.delay-2{animation-delay:.22s}
.delay-3{animation-delay:.34s}.delay-4{animation-delay:.46s}

/* ── Reveal on scroll ───────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .65s ease,transform .65s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.94);transition:opacity .55s ease,transform .55s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* ── NAV ────────────────────────────────────────────────────── */
.ts3-nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,0.93);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 3rem;height:64px;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
/* nav icon replaced by real logo */
.nav-links{display:flex;align-items:center;gap:1.75rem}
.nav-link{font-size:14px;color:var(--muted);font-weight:400;transition:color .2s}
.nav-link:hover{color:var(--text)}
.nav-cta{background:var(--orange);color:#fff;padding:9px 22px;border-radius:8px;font-size:14px;font-weight:500;border:none;transition:background .2s}
.nav-cta:hover{background:var(--orange-l)}
.nav-mobile-toggle{display:none;background:none;border:none;font-size:22px;color:var(--text)}

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary{background:var(--orange);color:#fff;padding:14px 30px;border-radius:10px;font-size:15px;font-weight:500;border:none;transition:background .2s,transform .15s;display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{background:var(--orange-l);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.05);color:#fff;padding:14px 30px;border-radius:10px;font-size:15px;font-weight:400;border:1px solid rgba(255,255,255,.13);transition:background .2s;display:inline-flex;align-items:center;gap:8px}
.btn-ghost:hover{background:rgba(255,255,255,.09)}
.btn-outline{background:transparent;color:var(--text);padding:12px 26px;border-radius:9px;font-size:14px;font-weight:500;border:1.5px solid var(--border);transition:border-color .2s;display:inline-flex;align-items:center;gap:8px}
.btn-outline:hover{border-color:var(--blue)}

/* ── Pills ──────────────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;font-weight:500;padding:5px 13px;border-radius:20px;letter-spacing:.3px}
.pill-blue{background:rgba(58,90,245,.12);border:1px solid rgba(92,127,255,.3);color:#7ba0ff}
.pill-orange{background:rgba(240,90,30,.12);border:1px solid rgba(240,90,30,.3);color:#ff9470}
.pill-live{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25);color:#4ade80}
.live-dot{width:7px;height:7px;background:#22c55e;border-radius:50%;display:inline-block;position:relative}
.live-dot::after{content:'';position:absolute;inset:-2px;border-radius:50%;background:#22c55e;animation:pulseRing 1.8s ease-out infinite}

/* ── HERO ───────────────────────────────────────────────────── */
.ts3-hero{background:var(--dark);padding:3.25rem 3rem 3rem;overflow:hidden;position:relative}
.hero-glow{position:absolute;border-radius:50%;pointer-events:none}
.hero-glow-1{width:600px;height:600px;top:-150px;left:-100px;background:radial-gradient(circle,rgba(58,90,245,.11) 0%,transparent 65%)}
.hero-glow-2{width:450px;height:450px;bottom:-100px;right:-50px;background:radial-gradient(circle,rgba(240,90,30,.09) 0%,transparent 65%)}
.hero-layout{display:grid;grid-template-columns:1fr 460px;gap:3rem;align-items:center;position:relative;z-index:1}
.hero-eyebrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:1.25rem}
.hero-h1{font-size:clamp(34px,4.2vw,58px);font-weight:600;letter-spacing:-2px;line-height:1.05;color:#fff;margin-bottom:1rem}
.hero-h1 .c-blue{color:#5c88ff}.hero-h1 .c-orange{color:var(--orange)}
.hero-sub{font-size:17px;color:var(--muted-d);max-width:520px;line-height:1.75;margin-bottom:1.5rem;font-weight:300}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);border-radius:14px;overflow:hidden}
.hstat{background:var(--dark);padding:1.25rem 1.25rem}
.hstat-n{font-size:32px;font-weight:600;letter-spacing:-1.5px;color:#fff;line-height:1;margin-bottom:4px}
.hstat-n em{color:var(--orange);font-style:normal}
.hstat-l{font-size:13px;color:#6b7a94;letter-spacing:.3px}
.hero-canvas-wrap{width:100%;position:relative;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.07);border-radius:20px;overflow:hidden}
.hero-canvas-wrap::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.02) 39px,rgba(255,255,255,.02) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.02) 39px,rgba(255,255,255,.02) 40px);pointer-events:none;z-index:0;border-radius:20px}
#hero-canvas{width:100%;height:480px;display:block;position:relative;z-index:1}

/* ── Cert Marquee ───────────────────────────────────────────── */
.cert-strip{background:var(--off);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1rem 0;overflow:hidden;display:flex;align-items:center}
.cs-label-fixed{font-family:var(--mono);font-size:10px;color:#9ca3af;letter-spacing:1.5px;text-transform:uppercase;font-weight:500;white-space:nowrap;padding:0 1.5rem;border-right:1px solid var(--border);flex-shrink:0}
.cs-track-wrap{overflow:hidden;flex:1}
.cs-track{display:flex;gap:12px;animation:marquee 30s linear infinite;width:max-content;padding:0 12px}
.cs-track:hover{animation-play-state:paused}
.cert-badge{display:inline-flex;align-items:center;gap:7px;background:var(--white);border:1px solid var(--border);border-radius:7px;padding:7px 16px;font-size:13px;font-weight:500;color:#374151;white-space:nowrap;flex-shrink:0;transition:border-color .2s}
.cert-badge:hover{border-color:var(--blue)}
.cert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cd-ms{background:#0078d4}.cd-iso{background:#16a34a}.cd-sec{background:var(--orange)}.cd-pen{background:#7c3aed}

/* ── Shared section ─────────────────────────────────────────── */
.ts3-sec{padding:5.5rem 3rem}
.sec-off{background:var(--off)}.sec-white{background:var(--white)}
.sec-lbl{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;margin-bottom:1rem}
.lbl-blue{color:var(--blue-l)}.lbl-orange{color:var(--orange)}.lbl-dim{color:rgba(255,255,255,.35)}
.sec-h{font-size:clamp(28px,3.8vw,50px);font-weight:600;letter-spacing:-1.5px;line-height:1.1;margin-bottom:1rem}
.sec-h-light{color:var(--text)}.sec-h-dark{color:#fff}
.sec-p{font-size:17px;line-height:1.8;font-weight:300;max-width:480px}
.sec-p-light{color:var(--muted)}.sec-p-dark{color:var(--muted-d)}
.sec-header{margin-bottom:3.5rem}
.divider{height:1px;background:var(--border);margin:0 3rem}

/* ── SVG Icons ──────────────────────────────────────────────── */
.icon-box{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;flex-shrink:0}
.icon-box svg{width:22px;height:22px}
.ib-blue{background:var(--blue-bg);color:var(--blue-l)}
.ib-orange{background:var(--orange-bg);color:var(--orange)}
.ib-sky{background:rgba(3,105,161,.10);color:#38bdf8}
.ib-amber{background:rgba(217,119,6,.10);color:#f59e0b}
.ib-purple{background:rgba(124,58,237,.10);color:#a78bf5}
.ib-green{background:rgba(34,197,94,.10);color:#4ade80}
.ib-teal{background:rgba(20,184,166,.10);color:#2dd4bf}

/* ── Animated dark section BG ───────────────────────────────── */
.sec-dark-animated{position:relative;overflow:hidden}
.sec-dark-animated > *{position:relative;z-index:1}
.blob-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.18}
.blob-1{width:500px;height:500px;background:var(--blue);top:-120px;left:-80px;animation:blob1 18s ease-in-out infinite}
.blob-2{width:400px;height:400px;background:var(--orange);bottom:-100px;right:-60px;animation:blob2 22s ease-in-out infinite}
.blob-3{width:350px;height:350px;background:#7c3aed;top:40%;left:40%;animation:blob3 26s ease-in-out infinite}

/* ── Azure section ──────────────────────────────────────────── */
.az-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1px;background:rgba(255,255,255,.06);border-radius:14px;overflow:hidden}
.az-card{background:rgba(12,13,20,.85);padding:2rem;border-bottom:2px solid transparent;transition:border-color .25s,background .25s}
.az-card:hover{border-bottom-color:var(--blue);background:var(--dark3)}
.az-t{font-size:16px;font-weight:600;color:#fff;margin-bottom:.5rem}
.az-d{font-size:15px;color:#6b7a94;line-height:1.65;margin-bottom:1rem}
.az-cert{font-family:var(--mono);font-size:11px;font-weight:500;padding:4px 10px;border-radius:5px;background:rgba(58,90,245,.15);color:#7ba0ff;border:1px solid rgba(58,90,245,.25);display:inline-block}
.az-feat{background:rgba(58,90,245,.06);border:1px solid rgba(58,90,245,.18);border-radius:14px;padding:2.5rem;margin-top:3rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.az-feat-title{font-size:24px;font-weight:600;color:#fff;letter-spacing:-.5px;margin-bottom:.75rem}
.az-feat-p{font-size:16px;color:#8892a4;line-height:1.75;margin-bottom:1.5rem}
.az-feat-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.az-feat-list li{font-size:15px;color:#c4cfdf;display:flex;align-items:center;gap:10px}
.az-feat-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0}
.az-badges{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.az-badge-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:1.25rem;text-align:center;transition:border-color .2s}
.az-badge-card:hover{border-color:rgba(58,90,245,.4)}
.az-badge-code{font-family:var(--mono);font-size:20px;font-weight:500;color:#5c88ff;margin-bottom:5px}
.az-badge-name{font-size:13px;color:#6b7a94;line-height:1.4}

/* ── Services ───────────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:20px}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s,transform .2s;cursor:default}
.svc-card:hover{border-color:var(--blue);transform:translateY(-4px);box-shadow:0 12px 40px rgba(58,90,245,.1)}
/* image-topped card */
.svc-img-wrap{position:relative;height:168px;overflow:hidden}
.svc-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.svc-card:hover .svc-img{transform:scale(1.04)}
.svc-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.08) 0%,rgba(0,0,0,.55) 100%)}
.svc-img-num{position:absolute;top:12px;left:14px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.7);font-weight:500;letter-spacing:1px}
.svc-img-badge{position:absolute;bottom:12px;right:12px}
.svc-body{padding:1.75rem}
/* fallback for non-image cards */
.svc-num{font-family:var(--mono);font-size:11px;color:#c4c9d4;font-weight:500;letter-spacing:1px;margin-bottom:1.25rem}
.svc-t{font-size:16px;font-weight:600;color:var(--text);margin-bottom:.6rem}
.svc-d{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:1.25rem}
.tag-row{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:12px;padding:4px 10px;border-radius:5px;font-weight:500;background:var(--off);color:var(--muted)}
.tag-blue{background:rgba(58,90,245,.08);color:var(--blue)}
.tag-orange{background:rgba(240,90,30,.08);color:var(--orange)}
.tag-purple{background:rgba(124,58,237,.08);color:#7c3aed}
.tag-green{background:rgba(34,197,94,.08);color:#16a34a}

/* ── ERPNext featured card ──────────────────────────────────── */
.erpnext-card{background:linear-gradient(135deg,rgba(58,90,245,.06) 0%,rgba(124,58,237,.06) 100%);border:1px solid rgba(58,90,245,.2);border-radius:14px;padding:2rem;grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.erpnext-badge{display:inline-block;background:rgba(58,90,245,.12);border:1px solid rgba(58,90,245,.25);color:#7ba0ff;font-family:var(--mono);font-size:11px;padding:4px 12px;border-radius:6px;margin-bottom:1rem;letter-spacing:.5px}
.erpnext-h{font-size:20px;font-weight:600;color:var(--text);margin-bottom:.75rem;letter-spacing:-.3px}
.erpnext-p{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:1.5rem}
.erpnext-features{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.erpnext-feat{display:flex;align-items:center;gap:8px;font-size:13px;color:#374151;font-weight:500}
.erpnext-feat::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0}
.erpnext-visual{background:rgba(58,90,245,.06);border:1px solid rgba(58,90,245,.12);border-radius:12px;padding:1.75rem;text-align:center}
.erpnext-logo{font-size:28px;font-weight:700;color:var(--blue);letter-spacing:-1px;margin-bottom:.5rem}
.erpnext-tagline{font-size:12px;color:var(--muted);margin-bottom:1.5rem}
.erpnext-modules{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.erpnext-mod{font-size:11px;padding:4px 10px;border-radius:5px;background:rgba(58,90,245,.08);color:var(--blue);font-weight:500}

/* ── Consultancies ──────────────────────────────────────────── */
.consult-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.consult-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.75rem;transition:border-color .2s,transform .2s}
.consult-card:hover{border-color:var(--blue);transform:translateY(-2px)}
.consult-vendor{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:1px;margin-bottom:1rem;display:flex;align-items:center;gap:8px}
.vendor-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.consult-t{font-size:15px;font-weight:600;color:var(--text);margin-bottom:.4rem}
.consult-d{font-size:15px;color:var(--muted);line-height:1.65;margin-bottom:1rem}
.consult-items{list-style:none;display:flex;flex-direction:column;gap:5px}
.consult-items li{font-size:14px;color:#374151;display:flex;align-items:center;gap:7px}
.consult-items li::before{content:'→';color:var(--blue);font-size:11px;font-weight:700}

/* ── Mid canvas section ─────────────────────────────────────── */
.mid-anim-sec{background:var(--off);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:4rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.mid-text .sec-lbl{margin-bottom:.75rem}
.mid-text .sec-h{margin-bottom:.75rem}
.mid-text .sec-p{margin-bottom:2rem}
.mid-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.mid-list li{font-size:15px;color:var(--text);display:flex;align-items:center;gap:10px}
.mid-list li .ml-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0}
.mid-canvas-wrap{background:#0c0d14;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.07);position:relative}
.mid-canvas-wrap::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 29px,rgba(255,255,255,.02) 29px,rgba(255,255,255,.02) 30px),repeating-linear-gradient(90deg,transparent,transparent 29px,rgba(255,255,255,.02) 29px,rgba(255,255,255,.02) 30px);pointer-events:none;z-index:0}
#mid-canvas{width:100%;height:340px;display:block;position:relative;z-index:1}

/* ── Tercerización ──────────────────────────────────────────── */
.t3-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-bottom:3.5rem}
.t3-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1.75rem;margin-bottom:1.25rem}
.t3-box:last-child{margin-bottom:0}
.t3-box-q{font-size:16px;font-weight:600;color:#fff;margin-bottom:.75rem}
.t3-box-a{font-size:15px;color:#8892a4;line-height:1.7}
.t3-model{background:rgba(58,90,245,.06);border:1px solid rgba(58,90,245,.18);border-radius:14px;padding:2rem}
.t3-model-label{font-family:var(--mono);font-size:11px;color:#8892a4;letter-spacing:.5px;margin-bottom:1.25rem}
.t3-model-h{font-size:32px;font-weight:600;color:#fff;letter-spacing:-1px;line-height:1.1;margin-bottom:.5rem}
.t3-model-h span{color:var(--blue)}
.t3-model-sub{font-size:15px;color:#8892a4;margin-bottom:2rem}
.t3-model-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.t3-model-list li{font-size:15px;color:#c4cfdf;display:flex;align-items:center;gap:10px}
.t3-model-list li::before{content:'✓';color:var(--blue);font-weight:700;font-size:14px;flex-shrink:0}
.t3-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.t3c{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:2rem;position:relative;overflow:hidden;transition:border-color .2s}
.t3c:hover{border-color:rgba(255,255,255,.18)}
.t3c::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.t3c.c1::before{background:var(--blue)}.t3c.c2::before{background:var(--orange)}.t3c.c3::before{background:#7c3aed}
.t3c-t{font-size:16px;font-weight:600;color:#fff;margin-bottom:.5rem}
.t3c-d{font-size:15px;color:#8892a4;line-height:1.65;margin-bottom:1.5rem}
.t3c-items{list-style:none}
.t3c-items li{font-size:15px;color:#c4cfdf;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:9px}
.t3c-items li::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.t3c.c1 .t3c-items li::before{background:var(--blue)}
.t3c.c2 .t3c-items li::before{background:var(--orange)}
.t3c.c3 .t3c-items li::before{background:#7c3aed}

/* ── Why ────────────────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2.5rem}
.why-line{height:2px;width:40px;margin-bottom:1.25rem}
.why-item:nth-child(odd) .why-line{background:var(--blue)}
.why-item:nth-child(even) .why-line{background:var(--orange)}
.why-n{font-family:var(--mono);font-size:11px;color:#6b7a94;letter-spacing:1px;margin-bottom:.75rem}
.why-t{font-size:16px;font-weight:600;color:#fff;margin-bottom:.5rem}
.why-p{font-size:15px;color:#8892a4;line-height:1.7}

/* ── CTA ────────────────────────────────────────────────────── */
.ts3-cta{background:var(--dark);padding:6rem 3rem;text-align:center;position:relative;overflow:hidden}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:300px;background:radial-gradient(ellipse,rgba(240,90,30,.08) 0%,transparent 70%);pointer-events:none}
.cta-inner{position:relative;z-index:1}
.cta-h{font-size:clamp(28px,4.5vw,54px);font-weight:600;letter-spacing:-2px;color:#fff;line-height:1.08;margin-bottom:1.25rem}
.cta-h span{color:var(--orange)}
.cta-p{font-size:15px;color:var(--muted-d);margin-bottom:3rem;font-weight:300}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-note{margin-top:1.75rem;font-family:var(--mono);font-size:12px;color:#4b5563;letter-spacing:.5px}

/* ── CONTACT MODAL ──────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:500;align-items:center;justify-content:center;padding:1.5rem}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:16px;width:100%;max-width:560px;overflow:hidden;box-shadow:0 25px 60px rgba(0,0,0,.3)}
.modal-header{background:var(--dark);padding:1.75rem 2rem;display:flex;justify-content:space-between;align-items:center}
.modal-title{font-size:18px;font-weight:600;color:#fff;letter-spacing:-.3px}
.modal-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:22px;line-height:1;cursor:pointer;transition:color .2s;padding:4px}
.modal-close:hover{color:#fff}
.modal-body{padding:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:1rem}
.form-group label{font-size:13px;font-weight:500;color:#374151}
.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font);font-size:14px;color:var(--text);transition:border-color .2s;outline:none;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;background:var(--orange);color:#fff;padding:13px;border-radius:9px;font-size:15px;font-weight:500;border:none;cursor:pointer;transition:background .2s;margin-top:.5rem}
.form-submit:hover{background:var(--orange-l)}
.form-success{display:none;text-align:center;padding:2rem}
.form-success-icon{font-size:48px;margin-bottom:1rem}
.form-success-t{font-size:18px;font-weight:600;color:var(--text);margin-bottom:.5rem}
.form-success-p{font-size:14px;color:var(--muted)}

/* ── Footer ─────────────────────────────────────────────────── */
.ts3-footer{background:#07080e;border-top:1px solid rgba(255,255,255,.05);padding:3.5rem 3rem 2.5rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:2rem}
.footer-logo{font-size:20px;font-weight:600;color:#fff;margin-bottom:.75rem}
.footer-logo span{color:var(--orange)}
.footer-tagline{font-size:15px;color:#4b5563;line-height:1.65;max-width:220px;margin-bottom:1.25rem}
.footer-contact{font-size:14px;color:#6b7280}
.footer-contact p{margin-bottom:4px}
.footer-contact a{color:var(--blue-l);transition:color .2s}
.footer-contact a:hover{color:#fff}
.footer-col-title{font-size:13px;font-weight:600;color:#9ca3af;letter-spacing:.5px;margin-bottom:1rem;text-transform:uppercase}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:14px;color:#4b5563;transition:color .2s}
.footer-links a:hover{color:#9ca3af}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:13px;color:#374151}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{font-size:12px;color:#374151;transition:color .2s}
.footer-legal a:hover{color:#6b7280}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1200px){.hero-layout{grid-template-columns:1fr 380px;gap:2rem}.erpnext-card{grid-column:span 1}}
@media(max-width:1024px){.ts3-nav,.ts3-hero,.ts3-sec,.ts3-cta,.ts3-footer,.mid-anim-sec{padding-left:1.75rem;padding-right:1.75rem}.divider{margin:0 1.75rem}}
@media(max-width:900px){.hero-layout{grid-template-columns:1fr}.hero-visual{display:none}.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:fixed;top:64px;left:0;right:0;background:#fff;padding:1.5rem 1.75rem;border-bottom:1px solid var(--border);gap:1rem;z-index:199}.nav-mobile-toggle{display:block}.hero-stats{grid-template-columns:repeat(2,1fr)}.az-feat{grid-template-columns:1fr}.t3-intro{grid-template-columns:1fr;gap:2rem}.t3-grid{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr 1fr;gap:2rem}.mid-anim-sec{grid-template-columns:1fr}.erpnext-card{grid-template-columns:1fr}}
@media(max-width:600px){.hero-h1{letter-spacing:-1.5px}.hero-stats{grid-template-columns:1fr 1fr}.svc-grid{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:flex-start}.az-badges{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}}

/* ── Real logo ─────────────────────────────────────────────────── */
.nav-logo-img{height:40px;width:auto;display:block}
.footer-logo-img{height:34px;width:auto;display:block;margin-bottom:.75rem}

/* ── Section background patterns ───────────────────────────────── */
/* Dot grid — for light sections */
.pattern-dots{background-image:radial-gradient(circle,rgba(58,90,245,.12) 1px,transparent 1px);background-size:22px 22px}
/* Fine grid — for white sections */
.pattern-grid{background-image:linear-gradient(rgba(58,90,245,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(58,90,245,.055) 1px,transparent 1px);background-size:38px 38px}
/* Diagonal lines — for dark sections */
.pattern-lines{background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0px,rgba(255,255,255,.025) 1px,transparent 1px,transparent 18px)}
/* Crosshair dots — very subtle for off-white */
.pattern-cross{background-image:radial-gradient(circle,rgba(0,0,0,.07) 1px,transparent 1px);background-size:28px 28px}

/* ── Contact Bar ───────────────────────────────────────── */
.contact-bar{background:#0d0f14;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);padding:2.25rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem}
.cb-label{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.35);letter-spacing:2px;text-transform:uppercase;margin-bottom:.5rem}
.cb-items{display:flex;gap:2.5rem;flex-wrap:wrap;align-items:center}
.cb-item{display:flex;align-items:center;gap:12px}
.cb-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cb-icon-tel{background:rgba(240,90,30,.12);border:1px solid rgba(240,90,30,.25)}
.cb-icon-mail{background:rgba(58,90,245,.12);border:1px solid rgba(58,90,245,.25)}
.cb-icon svg{width:20px;height:20px}
.cb-detail{}
.cb-type{font-size:11px;color:#6b7a94;font-family:var(--mono);letter-spacing:.5px;margin-bottom:2px}
.cb-value{font-size:18px;font-weight:600;letter-spacing:-.3px;line-height:1}
.cb-value a{color:#fff;transition:color .2s}
.cb-value a:hover{color:var(--orange)}
.cb-value-mail a{color:#7ba0ff}
.cb-value-mail a:hover{color:#fff}
.cb-cta{flex-shrink:0}
.cb-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;padding:13px 26px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .15s;white-space:nowrap}
.cb-cta-btn:hover{background:var(--orange-l);transform:translateY(-2px)}

/* ── Floating contact pill ─────────────────────────────── */
@keyframes floatBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes ripple{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.4);opacity:0}}
.float-contact{position:fixed;bottom:2rem;right:2rem;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.float-btn{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.35);transition:transform .2s;position:relative;animation:floatBadge 3.5s ease-in-out infinite}
.float-btn::before{content:'';position:absolute;inset:0;border-radius:50%;animation:ripple 2.2s ease-out infinite}
.float-tel{background:var(--orange)}
.float-tel::before{background:var(--orange)}
.float-tel svg{width:22px;height:22px;color:#fff}
.float-label{background:rgba(13,15,20,.9);color:#fff;font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity .2s,transform .2s;pointer-events:none;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1)}
.float-contact:hover .float-label{opacity:1;transform:translateX(0)}

/* ── Enhanced scroll reveals ───────────────────────────── */
.reveal-up   {opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-up.visible{opacity:1;transform:translateY(0)}
.reveal-left {opacity:0;transform:translateX(-32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.93);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
/* stagger helpers */
.sd-1{transition-delay:.07s!important}
.sd-2{transition-delay:.14s!important}
.sd-3{transition-delay:.21s!important}
.sd-4{transition-delay:.28s!important}
.sd-5{transition-delay:.35s!important}
.sd-6{transition-delay:.42s!important}

/* ── Highlight banner strip ────────────────────────────── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.highlight-banner{background:linear-gradient(135deg,#0d0f14 0%,#161722 50%,#0d0f14 100%);border-top:1px solid rgba(58,90,245,.2);border-bottom:1px solid rgba(58,90,245,.2);padding:3rem;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;position:relative;overflow:hidden}
.highlight-banner::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue));background-size:400px 2px;animation:shimmer 3s linear infinite}
.hb-text{}
.hb-eyebrow{font-family:var(--mono);font-size:11px;color:var(--orange);letter-spacing:2px;text-transform:uppercase;margin-bottom:.75rem}
.hb-title{font-size:clamp(20px,2.8vw,32px);font-weight:600;color:#fff;letter-spacing:-.5px;line-height:1.2;margin-bottom:.6rem}
.hb-title span{color:var(--orange)}
.hb-sub{font-size:15px;color:#8892a4;font-weight:300}
.hb-action{text-align:right;flex-shrink:0}
.hb-stat{margin-bottom:1rem;text-align:center}
.hb-stat-n{font-size:40px;font-weight:700;color:#fff;letter-spacing:-2px;line-height:1}
.hb-stat-n em{color:var(--orange);font-style:normal}
.hb-stat-l{font-size:12px;color:#6b7a94;margin-top:4px;letter-spacing:.5px}


/* ── Contact Bar v2 ─────────────────────────────────────────── */
@keyframes waveFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.contact-bar-v2{background:linear-gradient(135deg,#f0f4ff 0%,#e8eef8 40%,#f5f0ff 100%);border-top:1px solid rgba(58,90,245,.12);border-bottom:1px solid rgba(58,90,245,.12);position:relative;overflow:hidden}
.cb2-wave{position:absolute;top:0;left:0;right:0;height:80px;animation:waveFloat 6s ease-in-out infinite}
.cb2-wave svg{width:100%;height:100%}
.cb2-inner{position:relative;z-index:1;padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem}
.cb2-eyebrow{font-family:var(--mono);font-size:11px;color:var(--blue);letter-spacing:2px;text-transform:uppercase;margin-bottom:.5rem}
.cb2-title{font-size:22px;font-weight:600;color:var(--text);letter-spacing:-.5px;margin-bottom:.3rem}
.cb2-sub{font-size:14px;color:var(--muted)}
.cb2-contacts{display:flex;gap:1.5rem;flex-wrap:wrap}
.cb2-item{display:flex;align-items:center;gap:14px;padding:1.1rem 1.75rem;background:#fff;border-radius:14px;border:1.5px solid rgba(58,90,245,.14);text-decoration:none;color:var(--text);transition:all .2s;box-shadow:0 2px 12px rgba(58,90,245,.06)}
.cb2-item:hover{border-color:var(--blue);box-shadow:0 4px 20px rgba(58,90,245,.14);transform:translateY(-2px)}
.cb2-tel .cb2-icon-wrap{color:var(--orange)}
.cb2-mail .cb2-icon-wrap{color:var(--blue)}
.cb2-type{font-size:11px;color:var(--muted);letter-spacing:.3px;margin-bottom:3px}
.cb2-value{font-size:16px;font-weight:600;letter-spacing:-.3px}

/* ── Clients section ─────────────────────────────────────────── */
@keyframes scrollLeft{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.clients-sec{background:var(--off);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:4rem 0;overflow:hidden}
.clients-header{text-align:center;padding:0 3rem;margin-bottom:3rem}
.clients-track-wrap{overflow:hidden;padding:1rem 0}
.clients-track{display:flex;gap:20px;animation:scrollLeft 32s linear infinite;width:max-content}
.clients-track:hover{animation-play-state:paused}

.client-card-text{font-size:13px;font-weight:600;color:#374151;line-height:1.3;text-align:center}
.client-card-text span{display:block;font-size:11px;font-weight:400;color:var(--muted);margin-top:2px}
.cc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-right:10px}

/* ── Sectors section ─────────────────────────────────────────── */
.sectors-sec{background:#fff;padding:5.5rem 3rem}
.sectors-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:3rem}
.sector-card{border:1.5px solid var(--border);border-radius:16px;padding:2rem;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:default;position:relative;overflow:hidden}
.sector-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.sector-card:hover{border-color:transparent;transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.08)}
.sc-agro::before{background:linear-gradient(90deg,#16a34a,#4ade80)}
.sc-fin::before{background:linear-gradient(90deg,#3a5af5,#7ba0ff)}
.sc-sal::before{background:linear-gradient(90deg,#dc2626,#f87171)}
.sc-com::before{background:linear-gradient(90deg,#d97706,#fbbf24)}
.sc-edu::before{background:linear-gradient(90deg,#7c3aed,#a78bf5)}
.sc-tec::before{background:linear-gradient(90deg,#0369a1,#38bdf8)}
.sector-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;font-size:24px}
.si-agro{background:#f0fdf4}.si-fin{background:#eef1fe}.si-sal{background:#fef2f2}.si-com{background:#fffbeb}.si-edu{background:#f5f0fe}.si-tec{background:#f0f9ff}
.sector-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:.4rem}
.sector-sub{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.sector-tags{display:flex;flex-wrap:wrap;gap:5px}
.stag{font-size:11px;padding:3px 8px;border-radius:5px;background:var(--off);color:var(--muted);font-weight:500}

/* ── Service detail modal ────────────────────────────────────── */
.svc-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);z-index:600;align-items:center;justify-content:center;padding:1.5rem}
.svc-modal-overlay.open{display:flex}
.svc-modal-box{background:#fff;border-radius:20px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.25)}
.svc-modal-header{padding:2rem 2rem 1.25rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;position:sticky;top:0;background:#fff;z-index:1;border-radius:20px 20px 0 0}
.svc-modal-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px}
.svc-modal-close{background:var(--off);border:none;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .2s;flex-shrink:0}
.svc-modal-close:hover{background:var(--border);color:var(--text)}
.svc-modal-body{padding:1.75rem 2rem 2rem}
.svc-modal-desc{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:1.75rem}
.svc-modal-section{margin-bottom:1.5rem}
.svc-modal-section-title{font-size:12px;font-weight:700;color:var(--text);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:1rem;display:flex;align-items:center;gap:8px}
.svc-modal-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.svc-deliverable{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--off);font-size:14px;color:#374151}
.svc-deliverable-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:6px}
.svc-tech-row{display:flex;flex-wrap:wrap;gap:8px}
.svc-tech{font-size:12px;padding:5px 12px;border-radius:6px;background:var(--off);color:#374151;font-weight:500;border:1px solid var(--border)}
.svc-modal-cta{margin-top:2rem;display:flex;gap:12px;flex-wrap:wrap}

/* svc-card gets cursor pointer + "Ver detalle" link */
.svc-card{cursor:pointer}
.svc-more{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--blue);font-weight:500;margin-top:.75rem;padding:0;background:none;border:none;cursor:pointer;transition:gap .2s}
.svc-more:hover{gap:8px}

/* responsive additions */
@media(max-width:900px){.cb2-inner{padding:2rem 1.75rem}.sectors-sec{padding:4rem 1.75rem}.clients-sec{padding:3rem 0}}
@media(max-width:600px){.cb2-contacts{flex-direction:column}.cb2-item{width:100%}}


/* ── Dot texture for clients ─────────────────────────────────── */
.clients-sec{
  background-color:#f8f9fc;
  background-image:radial-gradient(circle,#c7d0e8 1px,transparent 1px);
  background-size:22px 22px;
  border-top:1px solid rgba(58,90,245,.1);
  border-bottom:1px solid rgba(58,90,245,.1);
  padding:4.5rem 0;
}


.client-card:hover 

/* ── Grid/line texture for sectors ──────────────────────────── */
.sectors-sec{
  background-color:#fafbff;
  background-image:
    linear-gradient(rgba(58,90,245,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(58,90,245,.06) 1px,transparent 1px);
  background-size:40px 40px;
  padding:5.5rem 3rem;
}

/* ── Hero canvas — bigger ─────────────────────────────────────── */
#hero-canvas{width:100%!important;height:520px!important;display:block}
.hero-canvas-wrap{max-width:560px}

/* ── Hero text on top layout option ──────────────────────────── */

/* hero grid handled by .hero-layout */
@media(max-width:900px){#hero-canvas{height:340px!important}}




.client-card:hover .clients-track{display:flex;gap:22px;animation:scrollLeft 38s linear infinite;width:max-content}
.clients-track:hover{animation-play-state:paused}


/* ── Language toggle ─────────────────────────────────────────── */
.lang-toggle{
  display:inline-flex;align-items:center;gap:0;
  border:1.5px solid rgba(255,255,255,.2);
  border-radius:8px;overflow:hidden;
  font-family:var(--mono);font-size:12px;
  cursor:pointer;flex-shrink:0;
}
.lang-btn{
  padding:6px 11px;background:transparent;border:none;
  color:rgba(255,255,255,.45);cursor:pointer;
  font-family:var(--mono);font-size:12px;letter-spacing:.5px;
  font-weight:600;transition:all .2s;
}
.lang-btn.active{background:var(--orange);color:#fff;}
.lang-btn:hover:not(.active){color:rgba(255,255,255,.8);}
[data-lang-hidden]{display:none!important}


/* ── Client logos ────────────────────────────────────────────── */
.clients-track{display:flex;gap:24px;animation:scrollLeft 40s linear infinite;width:max-content}
.clients-track:hover{animation-play-state:paused}
.client-card{
  background:#fff;border:1.5px solid rgba(58,90,245,.1);border-radius:16px;
  padding:1.2rem 2rem;min-width:220px;height:110px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 2px 10px rgba(0,0,0,.05);transition:border-color .25s,box-shadow .25s;
}
.client-card:hover{border-color:rgba(58,90,245,.3);box-shadow:0 4px 22px rgba(58,90,245,.1);}
.client-logo{
  max-height:80px;max-width:200px;width:auto;height:auto;
  object-fit:contain;filter:grayscale(0%) opacity(.9);
  transition:filter .25s,transform .22s;display:block;margin:auto;
}
.client-card:hover .client-logo{filter:grayscale(0%) opacity(1);transform:scale(1.05)}


/* ── Lang toggle ─────────────────────────────────────────────── */
.lang-toggle{display:inline-flex;border:1.5px solid rgba(255,255,255,.22);border-radius:8px;overflow:hidden;flex-shrink:0}
.lang-btn{padding:5px 11px;background:transparent;border:none;color:#9ca3af;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.8px;font-weight:700;transition:all .2s}
.lang-btn.active{background:var(--orange);color:#fff}
.lang-btn:hover:not(.active){color:rgba(255,255,255,.85)}