:root{
  --blue:#073C66;
  --blue-2:#0E4A7B;
  --teal:#10806F;
  --teal-2:#1C6F63;
  --mint:#DDF3EE;
  --gray:#A7B0B7;
  --soft:#F7F8F6;
  --ink:#0C1720;
  --graphite:#111820;
  --line:rgba(7,60,102,.14);
  --shadow:0 24px 70px rgba(7,60,102,.14);
  --shadow-soft:0 12px 34px rgba(7,60,102,.08);
  --radius:28px;
  --radius-sm:16px;
  --max:1180px;
  --header-h:74px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 20px)}
body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:var(--soft);color:var(--ink);line-height:1.55;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}p{margin:0;color:rgba(12,23,32,.72)}h1,h2,h3{margin:0;line-height:1.06;letter-spacing:-.04em}h1{font-size:clamp(1.9rem,4.2vw,4.1rem);max-width:790px;color:#fff}h2{font-size:clamp(2rem,3.7vw,4.05rem);max-width:850px}h3{font-size:1.05rem;letter-spacing:-.02em}.container{width:min(var(--max),calc(100% - 44px));margin:0 auto}.section{padding:110px 0}.section-soft{padding:95px 0;background:linear-gradient(180deg,#fff 0%,#F7F8F6 100%)}.section-dark{position:relative;background:var(--graphite);color:#fff;overflow:hidden}.skip-link{position:absolute;left:14px;top:-60px;padding:12px 16px;background:#fff;color:var(--blue);z-index:1000;border-radius:12px}.skip-link:focus{top:14px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.eyebrow{font-weight:800;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:18px}.eyebrow.teal{color:var(--teal)}.eyebrow.light{color:var(--mint)}.lead{font-size:clamp(1rem,1.5vw,1.28rem);color:rgba(255,255,255,.86);max-width:660px;margin-top:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 22px;border-radius:12px;font-weight:800;font-size:.9rem;border:1px solid transparent;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,border-color .25s ease;color:var(--ink);cursor:pointer}.btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(7,60,102,.16)}.btn-primary{background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff}.btn-light{background:#fff;color:var(--blue)}.btn-outline-light{color:#fff;border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.08);backdrop-filter:blur(10px)}.btn-outline{border-color:rgba(7,60,102,.25);background:#fff;color:var(--blue)}.btn-small{min-height:42px;padding:0 18px;font-size:.82rem;border-radius:10px}.text-link{display:inline-flex;margin-top:28px;font-weight:850;color:var(--teal);align-items:center;gap:7px}.text-link span{transition:transform .2s ease}.text-link:hover span{transform:translateX(5px)}
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:100;background:rgba(247,248,246,.86);backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid rgba(7,60,102,.08);transition:background .25s ease,box-shadow .25s ease}.site-header.is-scrolled{background:rgba(247,248,246,.96);box-shadow:0 10px 40px rgba(7,60,102,.08)}.nav-shell{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;min-width:190px}.brand img{width:205px;max-height:48px;object-fit:contain}.main-nav{display:flex;align-items:center;gap:28px;font-weight:800;font-size:.86rem;color:var(--ink)}.main-nav a:not(.btn){position:relative;opacity:.86}.main-nav a:not(.btn)::after{content:"";position:absolute;left:0;right:0;bottom:-9px;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.main-nav a:hover::after{transform:scaleX(1)}.nav-toggle{display:none;background:transparent;border:0;width:42px;height:42px;border-radius:12px}.nav-toggle span{display:block;width:23px;height:2px;background:var(--blue);margin:5px auto;transition:.25s ease}
.hero{min-height:760px;padding:calc(var(--header-h) + 120px) 0 120px}.hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 10% 30%,rgba(16,128,111,.35),transparent 28%),linear-gradient(90deg,rgba(4,34,55,.98) 0%,rgba(7,60,102,.9) 44%,rgba(7,60,102,.62) 100%),linear-gradient(135deg,#02111E,#0B314D 50%,#0D5B55 100%)}.hero-bg::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.22),transparent 45%),repeating-linear-gradient(105deg,rgba(255,255,255,.05) 0 1px,transparent 1px 22px);opacity:.45}.tire-orbit{position:absolute;left:-140px;top:130px;width:520px;height:520px;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,rgba(255,255,255,.06) 0 4px,transparent 4px 18px);filter:blur(.2px);opacity:.56;animation:rotateSlow 28s linear infinite}.industrial-line{position:absolute;right:13%;bottom:13%;width:540px;height:250px;opacity:.34;background:linear-gradient(to top,rgba(255,255,255,.12),transparent 2px),linear-gradient(to right,transparent 0 6%,rgba(255,255,255,.18) 6% 7%,transparent 7% 17%,rgba(255,255,255,.15) 17% 19%,transparent 19% 35%,rgba(255,255,255,.18) 35% 36%,transparent 36%);clip-path:polygon(0 100%,0 70%,10% 70%,10% 48%,15% 48%,15% 85%,27% 85%,27% 35%,31% 35%,31% 85%,45% 85%,45% 17%,48% 17%,48% 100%,100% 100%)}.flow{position:absolute;border:1px solid rgba(125,225,213,.28);border-left:0;border-bottom:0;border-radius:50%;transform:rotate(-14deg);animation:drift 10s ease-in-out infinite}.flow-1{right:-8%;top:7%;width:720px;height:260px}.flow-2{right:-13%;top:23%;width:840px;height:320px;animation-delay:-2s}.flow-3{right:1%;top:40%;width:520px;height:190px;animation-delay:-4s}.node{position:absolute;width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 10px rgba(16,128,111,.12);animation:pulse 2.6s ease-in-out infinite}.n1{right:22%;top:30%}.n2{right:36%;top:47%;animation-delay:.4s}.n3{right:11%;top:55%;animation-delay:.8s}.hero-grid{position:relative;display:block;}.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px}.hero-panel{min-height:430px;border-radius:var(--radius);background:linear-gradient(155deg,rgba(255,255,255,.17),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.18);box-shadow:0 30px 90px rgba(0,0,0,.22);position:relative;overflow:hidden;backdrop-filter:blur(8px);display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:28px}.hero-panel::before{content:"";position:absolute;inset:28px;border:1px solid rgba(255,255,255,.16);border-radius:20px}.hero-panel::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 40% 45%,rgba(16,128,111,.35),transparent 25%),linear-gradient(135deg,transparent 0 44%,rgba(255,255,255,.09) 45%,transparent 46%);opacity:.8}.hero-panel span{position:relative;z-index:1;align-self:end;padding:18px;border-radius:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);font-weight:800;color:rgba(255,255,255,.9)}.panel-topline{position:absolute;left:38px;top:38px;width:44%;height:3px;background:linear-gradient(90deg,#fff,var(--teal));border-radius:4px}.scroll-cue{position:absolute;left:50%;bottom:34px;width:36px;height:36px;border:1px solid rgba(255,255,255,.35);border-radius:50%;transform:translateX(-50%);display:grid;place-items:center}.scroll-cue span{width:9px;height:9px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg);margin-top:-4px;animation:bounce 1.6s infinite}
.split-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);gap:84px;align-items:center}.section-copy p:not(.eyebrow){font-size:1.08rem;max-width:610px;margin-top:24px}.orbital-card{position:relative;min-height:460px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);overflow:hidden}.orbital-card::before,.orbital-card::after{content:"";position:absolute;border:1px dashed rgba(16,128,111,.32);border-radius:50%;inset:80px}.orbital-card::after{inset:120px;border-style:solid;opacity:.35}.orbital-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:156px;height:156px;border-radius:50%;background:#fff;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;z-index:2}.orbital-center img{width:86px}.orbital-center strong{font-size:.78rem;color:var(--blue);letter-spacing:.04em}.orbit-pill{position:absolute;z-index:3;background:rgba(255,255,255,.94);border:1px solid rgba(16,128,111,.24);box-shadow:0 14px 24px rgba(7,60,102,.08);padding:10px 16px;border-radius:999px;font-size:.82rem;font-weight:850;color:var(--blue);white-space:nowrap}.top{top:48px;left:50%;transform:translateX(-50%)}.bottom{bottom:48px;left:50%;transform:translateX(-50%)}.left-top{left:38px;top:34%}.right-top{right:38px;top:34%}.left-bottom{left:52px;bottom:30%}.right-bottom{right:52px;bottom:30%}.center-title{text-align:center;max-width:850px;margin:0 auto 50px}.center-title p:not(.eyebrow){margin:18px auto 0;max-width:650px}.company-system{position:relative;min-height:470px;display:grid;place-items:center}.company-system::before{content:"";position:absolute;width:min(720px,74vw);height:min(330px,42vw);border:1px dashed rgba(16,128,111,.3);border-radius:50%;animation:rotateSlow 42s linear infinite}.system-core{width:164px;height:164px;border-radius:50%;background:#fff;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:3;border:1px solid rgba(7,60,102,.1)}.system-core img{width:90px}.system-core strong{font-size:.8rem;color:var(--blue);letter-spacing:.04em}.system-node{position:absolute;width:170px;min-height:142px;background:rgba(255,255,255,.92);border:1px solid rgba(7,60,102,.11);box-shadow:var(--shadow-soft);border-radius:22px;padding:19px;text-align:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.system-node:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(16,128,111,.35)}.system-node .icon,.card-icon,.metric-icon{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,rgba(7,60,102,.08),rgba(16,128,111,.12));color:var(--teal);font-weight:900;margin-bottom:12px}.system-node h3{font-size:.95rem;color:var(--blue)}.system-node p{font-size:.78rem;margin-top:7px}.node-insamar{top:18px;left:50%;transform:translateX(-50%)}.node-logistica{top:112px;right:84px}.node-sustrend{bottom:112px;right:84px}.node-lab{bottom:18px;left:50%;transform:translateX(-50%)}.node-efilabs{bottom:112px;left:84px}.node-tphite{top:112px;left:84px}.node-volltech{top:50%;left:0;transform:translateY(-50%)}
.cards-grid{display:grid;gap:20px}.capability-grid{grid-template-columns:repeat(7,1fr)}.cap-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:26px 22px;min-height:230px;box-shadow:0 10px 30px rgba(7,60,102,.05);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.cap-card:hover{transform:translateY(-6px);border-color:rgba(16,128,111,.36);box-shadow:var(--shadow-soft)}.cap-card h3{color:var(--blue);font-size:1rem}.cap-card p{font-size:.88rem;margin-top:12px}.company-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:18px}.company-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .25s ease,box-shadow .25s ease}.company-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}.visual{height:145px;position:relative;overflow:hidden;background:var(--blue)}.visual::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,60,102,.15),rgba(16,128,111,.22)),repeating-linear-gradient(115deg,rgba(255,255,255,.08) 0 1px,transparent 1px 18px)}.visual-insamar{background:radial-gradient(circle at 70% 30%,#7B8A94,transparent 30%),linear-gradient(135deg,#172B38,#0E4A7B 65%,#1C6F63)}.visual-logistica{background:linear-gradient(165deg,#E8F0F2 0 38%,#0E4A7B 39% 100%)}.visual-sustrend{background:linear-gradient(150deg,#9ABFAE,#EEF4F0 45%,#0E4A7B)}.visual-lab{background:radial-gradient(circle at 44% 32%,rgba(255,255,255,.75),transparent 9%),radial-gradient(circle at 67% 58%,rgba(255,255,255,.55),transparent 11%),linear-gradient(135deg,#DBEEF0,#0E4A7B)}.visual-efilabs,.visual-volltech{background:linear-gradient(135deg,#071827,#0E4A7B),repeating-linear-gradient(90deg,rgba(16,128,111,.35) 0 3px,transparent 3px 18px)}.visual-tphite{background:radial-gradient(circle at 30% 40%,#31363B,transparent 8%),radial-gradient(circle at 58% 52%,#202529,transparent 7%),linear-gradient(135deg,#070B0E,#444B50)}.company-card h3{padding:20px 20px 4px;color:var(--blue)}.company-card p{padding:0 20px;min-height:64px;font-size:.83rem}.company-card a{display:inline-flex;margin:18px 20px 22px;color:var(--teal);font-weight:850;font-size:.86rem}.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.case-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .25s ease,box-shadow .25s ease}.case-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}.case-image{height:190px;background:linear-gradient(135deg,#233748,#0E4A7B);position:relative;overflow:hidden}.case-image::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.28),transparent 17%),linear-gradient(145deg,rgba(16,128,111,.35),transparent 50%),repeating-linear-gradient(120deg,rgba(255,255,255,.08) 0 1px,transparent 1px 20px)}.case-mining{background:linear-gradient(135deg,#64513B,#263444)}.case-coop{background:linear-gradient(135deg,#BECED8,#0E4A7B)}.case-graphite{background:linear-gradient(135deg,#0E1115,#575F64)}.case-energy{background:linear-gradient(135deg,#BFD6D8,#0C6370)}.case-engineering{background:linear-gradient(135deg,#464A4F,#0E4A7B)}.case-port{background:linear-gradient(135deg,#7BA6BF,#0E4A7B)}.case-content{padding:22px}.case-content span{display:inline-block;font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;font-weight:900;color:var(--teal);margin-bottom:10px}.case-content h3{color:var(--blue);font-size:1.18rem}.case-content p{margin-top:12px;font-size:.9rem}.case-content a{display:inline-flex;margin-top:18px;color:var(--teal);font-weight:900}.impact-panel{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-soft);overflow:hidden}.metric{padding:34px 28px;text-align:center;border-right:1px solid var(--line)}.metric:last-child{border-right:0}.metric strong{display:block;font-size:clamp(1.6rem,3vw,2.45rem);color:var(--blue);line-height:1;font-weight:900;letter-spacing:-.05em}.metric p{margin:8px auto 0;max-width:180px;font-size:.9rem}.future{padding:80px 0;background:radial-gradient(circle at 80% 20%,rgba(16,128,111,.32),transparent 26%),linear-gradient(135deg,#061927,#073C66 62%,#0E4A7B)}.future-panel{display:grid;grid-template-columns:.9fr 1fr auto;gap:38px;align-items:center;position:relative}.future-panel::after{content:"";position:absolute;right:-12%;top:-40%;width:520px;height:280px;border:1px solid rgba(255,255,255,.18);border-radius:50%;transform:rotate(-14deg)}.future h2{color:#fff;font-size:clamp(2.3rem,4.2vw,4.2rem)}.future p:not(.eyebrow){color:rgba(255,255,255,.78);font-size:1.03rem}.contact-cta{position:relative;overflow:hidden}.contact-cta::before{content:"";position:absolute;inset:auto -10% 8% -10%;height:260px;background:repeating-linear-gradient(165deg,rgba(16,128,111,.12) 0 1px,transparent 1px 18px);transform:rotate(-3deg);opacity:.5}.cta-card{position:relative;text-align:center;max-width:900px;background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow-soft);padding:58px 34px;backdrop-filter:blur(10px)}.cta-card img{width:82px;margin:0 auto 18px}.cta-card h2{margin:0 auto;font-size:clamp(2rem,3vw,3.25rem);color:var(--blue)}.cta-card p{max-width:650px;margin:18px auto 0}.contact-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}.footer{background:#061927;color:#fff;padding:70px 0 28px}.footer-grid{display:grid;grid-template-columns:1.35fr .8fr .9fr 1.1fr;gap:52px;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:44px}.footer img{width:210px;filter:brightness(1.2)}.footer h2{font-size:1rem;letter-spacing:0;line-height:1.5;color:rgba(255,255,255,.78);margin-top:18px}.footer h3{font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;color:#fff;margin-bottom:16px}.footer a,.footer span{display:block;color:rgba(255,255,255,.68);font-style:normal;font-size:.9rem;margin:8px 0}.footer a:hover{color:#fff}.socials{display:flex;gap:10px;margin-top:18px}.socials a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.22);margin:0}.footer-bottom{display:flex;justify-content:space-between;gap:24px;align-items:center;padding-top:24px}.footer-bottom p,.footer-bottom a{color:rgba(255,255,255,.58);font-size:.82rem;margin:0}.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s cubic-bezier(.2,.8,.2,1)}.reveal.is-visible{opacity:1;transform:none}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}
@keyframes rotateSlow{to{transform:rotate(360deg)}}@keyframes drift{50%{transform:rotate(-10deg) translateY(16px)}}@keyframes pulse{50%{transform:scale(1.25);opacity:.7}}@keyframes bounce{50%{transform:rotate(45deg) translate(3px,3px)}}
@media (max-width:1180px){.capability-grid,.company-grid{grid-template-columns:repeat(3,1fr)}.company-system{min-height:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.company-system::before,.system-core{display:none}.system-node{position:static;width:auto;min-height:unset;transform:none!important}.case-grid{grid-template-columns:repeat(2,1fr)}.future-panel{grid-template-columns:1fr}.impact-panel{grid-template-columns:repeat(2,1fr)}.metric:nth-child(2){border-right:0}.metric:nth-child(1),.metric:nth-child(2){border-bottom:1px solid var(--line)}}
@media (max-width:860px){:root{--header-h:68px}.nav-toggle{display:block}.main-nav{position:fixed;top:var(--header-h);left:16px;right:16px;display:none;flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:20px;padding:18px}.main-nav.is-open{display:flex}.main-nav a{padding:10px}.brand img{width:175px}.hero{min-height:auto;padding:calc(var(--header-h) + 70px) 0 90px}.hero-grid,.split-grid{grid-template-columns:1fr;gap:46px}.hero-panel{min-height:300px}.orbital-card{min-height:500px}.orbit-pill{font-size:.72rem}.left-top,.left-bottom{left:14px}.right-top,.right-bottom{right:14px}.section,.section-soft{padding:74px 0}.capability-grid,.company-grid,.case-grid{grid-template-columns:1fr}.impact-panel{grid-template-columns:1fr}.metric{border-right:0!important;border-bottom:1px solid var(--line)}.metric:last-child{border-bottom:0}.footer-grid{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column;align-items:flex-start}h1{font-size:clamp(2.45rem,12vw,4rem)}.container{width:min(100% - 32px,var(--max))}}
@media (max-width:560px){.hero-actions,.contact-actions{flex-direction:column}.btn{width:100%}.footer-grid{grid-template-columns:1fr}.orbital-card::before,.orbital-card::after{display:none}.orbital-card{display:grid;gap:10px;padding:18px;min-height:auto}.orbital-center,.orbit-pill{position:static;transform:none;justify-self:center}.orbital-center{width:130px;height:130px}.top,.bottom,.left-top,.right-top,.left-bottom,.right-bottom{transform:none}.hero-panel{grid-template-columns:1fr}.hero-panel::before{display:none}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}
.footer-brand img{background:transparent;border-radius:0;padding:0;box-shadow:none;filter:none!important;}
.hero-copy{max-width:850px;}

/* Imagen de fondo responsive para el hero Dosandar */
.hero-bg{
  overflow:hidden;
}

.hero-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("../assets/hero-dosandar.png");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  opacity:.42;
  mix-blend-mode:screen;
  pointer-events:none;
  z-index:0;
}

.hero-bg::before{
  z-index:2;
}

.hero-bg > *{
  position:absolute;
  z-index:3;
}

.hero-grid,
.scroll-cue{
  position:relative;
  z-index:5;
}

@media (max-width:860px){
  .hero-bg::after{
    background-position:58% center;
    opacity:.32;
  }
}

/* Sistema Dosandar: empresas orbitando alrededor del centro */
@media (min-width:1181px){
  .company-system{
    position:relative;
    min-height:680px;
    display:block;
    place-items:unset;
    overflow:visible;
  }

  .company-system::before{
    left:50%;
    top:50%;
    width:min(820px,76vw);
    height:460px;
    transform:translate(-50%,-50%);
    border:1px dashed rgba(16,128,111,.30);
    border-radius:50%;
    animation:none;
    pointer-events:none;
  }

  .system-core{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    z-index:5;
  }

  .system-node{
    position:absolute;
    left:0!important;
    top:0!important;
    right:auto!important;
    bottom:auto!important;
    width:178px!important;
    height:148px!important;
    min-height:148px!important;
    max-height:148px!important;
    z-index:3;
    transform:none!important;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    offset-path:ellipse(390px 220px at 50% 50%);
    offset-anchor:center;
    offset-rotate:0deg;
    animation:orbitCompanies 56s linear infinite;
    animation-fill-mode:both;
  }

  .company-system:hover .system-node{
    animation-play-state:paused;
  }

  .system-node:hover{
    z-index:8;
    box-shadow:var(--shadow);
    border-color:rgba(16,128,111,.42);
  }

  .node-insamar{
    animation-delay:0s;
  }

  .node-logistica{
    animation-delay:-7s;
  }

  .node-sustrend{
    animation-delay:-14s;
  }

  .node-lab{
    animation-delay:-21s;
  }

  .node-efilabs{
    animation-delay:-28s;
  }

  .node-tphite{
    animation-delay:-35s;
  }

  .node-andreaniroute,
  .node-andreaniroute68{
    animation-delay:-42s;
  }

  .node-volltech{
    animation-delay:-49s;
  }

  @keyframes orbitCompanies{
    from{
      offset-distance:0%;
    }
    to{
      offset-distance:100%;
    }
  }
}

@media (max-width:1180px){
  .system-node{
    animation:none;
    offset-path:none;
    offset-distance:0;
  }
}

@media (prefers-reduced-motion:reduce){
  .system-node{
    animation:none!important;
  }
}

/* Carrusel de empresas especializadas: 3 tarjetas visibles en desktop */
.company-carousel{
  position:relative;
  width:100%;
  margin-top:42px;
  overflow:hidden;
}

.company-carousel::before,
.company-carousel::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:70px;
  z-index:2;
  pointer-events:none;
}

.company-carousel::before{
  left:0;
  background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,0) 100%);
}

.company-carousel::after{
  right:0;
  background:linear-gradient(270deg,#fff 0%,rgba(255,255,255,0) 100%);
}

.company-track{
  display:flex!important;
  grid-template-columns:none!important;
  grid-auto-flow:unset!important;
  flex-wrap:nowrap!important;
  gap:30px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-behavior:smooth;
  scroll-snap-type:x proximity;
  scrollbar-width:none;
  -ms-overflow-style:none;
  cursor:grab;
  padding:6px 8px 30px;
  overscroll-behavior-x:contain;
}

.company-track::-webkit-scrollbar{
  display:none;
}

.company-carousel.is-dragging .company-track,
.company-track.is-dragging{
  cursor:grabbing;
  scroll-snap-type:none;
}

.company-track .company-card{
  flex:0 0 calc((100% - 60px) / 3)!important;
  max-width:calc((100% - 60px) / 3)!important;
  min-width:0;
  scroll-snap-align:start;
  border-radius:26px;
}

.company-track .visual{
  height:235px;
  overflow:hidden;
}

.company-track .visual img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
}

.company-track .visual::after{
  pointer-events:none;
}

.company-track .company-card h3{
  padding:24px 24px 6px;
  font-size:1.24rem;
}

.company-track .company-card p{
  padding:0 24px;
  min-height:72px;
  font-size:.96rem;
}

.company-track .company-card a{
  margin:20px 24px 26px;
}

@media (max-width:1024px){
  .company-carousel::before,
  .company-carousel::after{
    width:44px;
  }

  .company-track{
    gap:24px;
  }

  .company-track .company-card{
    flex-basis:calc((100% - 24px) / 2)!important;
    max-width:calc((100% - 24px) / 2)!important;
  }

  .company-track .visual{
    height:215px;
  }
}

@media (max-width:640px){
  .company-carousel{
    margin-top:34px;
  }

  .company-carousel::before,
  .company-carousel::after{
    display:none;
  }

  .company-track{
    gap:18px;
    padding:4px 2px 24px;
    scroll-snap-type:x mandatory;
  }

  .company-track .company-card{
    flex-basis:86%!important;
    max-width:86%!important;
  }

  .company-track .visual{
    height:205px;
  }

  .company-track .company-card h3{
    padding:22px 22px 6px;
  }

  .company-track .company-card p{
    padding:0 22px;
  }

  .company-track .company-card a{
    margin:18px 22px 24px;
  }
}

/* Corrección final carrusel empresas: track transformado sin scroll interno */
.company-carousel{
  overflow:hidden!important;
  cursor:grab;
}

.company-carousel.is-dragging{
  cursor:grabbing;
}

.company-track{
  display:flex!important;
  flex-wrap:nowrap!important;
  gap:30px!important;
  width:max-content!important;
  max-width:none!important;
  overflow:visible!important;
  scroll-behavior:auto!important;
  scroll-snap-type:none!important;
  scrollbar-width:none;
  -ms-overflow-style:none;
  cursor:grab;
  will-change:transform;
  transform:translate3d(0,0,0);
}

.company-track::-webkit-scrollbar{
  display:none;
}

.company-track.is-dragging{
  cursor:grabbing;
}

.company-track .company-card{
  flex:0 0 var(--company-card-width, 360px)!important;
  width:var(--company-card-width, 360px)!important;
  max-width:none!important;
  min-width:0!important;
  scroll-snap-align:none!important;
}

.company-track .visual{
  height:235px;
}

.company-track .visual img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
}

@media (max-width:1024px){
  .company-track{
    gap:24px!important;
  }

  .company-track .visual{
    height:215px;
  }
}

@media (max-width:640px){
  .company-track{
    gap:18px!important;
  }

  .company-track .visual{
    height:205px;
  }
}

/* =========================================================
   PÁGINAS INTERNAS DOSANDAR
   Nosotros + Casos de éxito
   Este bloque se agrega al final para no alterar la home.
   ========================================================= */

.page-body{
  background:var(--soft);
}

.page-main{
  background:var(--soft);
}

.page-hero{
  min-height:620px;
  padding:calc(var(--header-h) + 112px) 0 96px;
  position:relative;
  overflow:hidden;
  color:#fff;
  background:var(--graphite);
}

.page-hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 78% 16%,rgba(16,128,111,.34),transparent 30%),
    linear-gradient(90deg,rgba(4,34,55,.98),rgba(7,60,102,.88) 56%,rgba(16,128,111,.54)),
    url("../assets/hero-dosandar.png");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  opacity:1;
}

.page-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.46),rgba(0,0,0,.10)),
    repeating-linear-gradient(110deg,rgba(255,255,255,.075) 0 1px,transparent 1px 22px);
  opacity:.86;
  pointer-events:none;
}

.page-hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,340px);
  align-items:center;
  gap:54px;
}

.page-hero h1{
  font-size:clamp(2.4rem,5.6vw,5rem);
  max-width:900px;
  color:#fff;
}

.page-hero .lead{
  max-width:760px;
}

.page-hero-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  border-radius:26px;
  padding:30px;
  backdrop-filter:blur(10px);
  box-shadow:0 30px 90px rgba(0,0,0,.18);
}

.page-hero-card strong{
  display:block;
  font-size:clamp(2.8rem,5vw,4.8rem);
  line-height:1;
  color:#fff;
  font-weight:950;
  letter-spacing:-.06em;
}

.page-hero-card span{
  display:block;
  margin-top:8px;
  color:var(--mint);
  font-weight:900;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.14em;
}

.page-hero-card p{
  margin-top:16px;
  color:rgba(255,255,255,.78);
}

.page-section-intro{
  max-width:880px;
  margin:0 auto 44px;
  text-align:center;
}

.page-section-intro p:not(.eyebrow){
  margin:18px auto 0;
  max-width:720px;
}

/* Casos de éxito / blog editable */
.success-tools{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  margin:0 0 30px;
}

.success-tools input{
  flex:1;
  min-height:52px;
  border:1px solid var(--line);
  border-radius:14px;
  padding:0 18px;
  font:inherit;
  color:var(--ink);
  background:#fff;
  box-shadow:var(--shadow-soft);
  outline:none;
}

.success-tools input:focus{
  border-color:rgba(16,128,111,.42);
  box-shadow:0 0 0 4px rgba(16,128,111,.10),var(--shadow-soft);
}

.filter-buttons{
  display:flex;
  gap:9px;
  flex-wrap:wrap;
}

.filter-btn{
  border:1px solid rgba(7,60,102,.18);
  background:#fff;
  color:var(--blue);
  border-radius:999px;
  padding:12px 14px;
  font-weight:850;
  cursor:pointer;
  transition:background .22s ease,color .22s ease,transform .22s ease,border-color .22s ease;
}

.filter-btn:hover{
  transform:translateY(-2px);
}

.filter-btn.is-active,
.filter-btn:hover{
  background:linear-gradient(135deg,var(--blue),var(--teal));
  color:#fff;
  border-color:transparent;
}

.success-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.success-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}

.success-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:rgba(16,128,111,.28);
}

.success-card.is-hidden{
  display:none;
}

.success-image{
  height:230px;
  overflow:hidden;
  background:#0E4A7B;
  position:relative;
}

.success-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg,rgba(7,60,102,.16),rgba(16,128,111,.24)),
    repeating-linear-gradient(115deg,rgba(255,255,255,.08) 0 1px,transparent 1px 18px);
  pointer-events:none;
}

.success-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transition:transform .5s ease;
}

.success-card:hover .success-image img{
  transform:scale(1.05);
}

.success-content{
  padding:22px;
}

.success-content span,
.case-story-copy span{
  display:inline-block;
  color:var(--teal);
  font-weight:900;
  text-transform:uppercase;
  font-size:.68rem;
  letter-spacing:.13em;
  margin-bottom:10px;
}

.success-content h3{
  font-size:1.35rem;
  color:var(--blue);
}

.success-content p{
  margin-top:12px;
  font-size:.94rem;
}

.success-content strong{
  display:block;
  margin-top:18px;
  font-size:.85rem;
  color:rgba(12,23,32,.62);
}

.case-story-list{
  display:grid;
  gap:26px;
}

.case-story{
  display:grid;
  grid-template-columns:420px 1fr;
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}

.case-story-media{
  min-height:320px;
  background:#0E4A7B;
}

.case-story-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}

.case-story-copy{
  padding:34px;
}

.case-story-copy h2{
  font-size:clamp(1.7rem,3vw,2.7rem);
  color:var(--blue);
}

.case-story-copy p{
  margin-top:16px;
}

.case-story-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:22px;
}

.case-story-meta b{
  border:1px solid rgba(7,60,102,.12);
  border-radius:999px;
  padding:9px 12px;
  color:var(--blue);
  font-size:.8rem;
  background:#F7F8F6;
}

/* Página Nosotros */
.about-hero .page-hero-bg{
  background-position:center center;
}

.narrative-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.narrative-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:32px;
  box-shadow:var(--shadow-soft);
}

.narrative-card h2{
  font-size:clamp(1.55rem,2.8vw,2.45rem);
  color:var(--blue);
}

.narrative-card p{
  margin-top:16px;
}

.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}

.timeline div{
  padding:28px;
  border-right:1px solid var(--line);
}

.timeline div:last-child{
  border-right:0;
}

.timeline strong{
  display:block;
  color:var(--teal);
  font-size:1.35rem;
}

.timeline h3{
  color:var(--blue);
  margin-top:10px;
  font-size:1.05rem;
}

.timeline p{
  margin-top:8px;
  font-size:.9rem;
}

.team-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}

.team-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}

.team-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:rgba(16,128,111,.28);
}

.team-photo{
  height:250px;
  background:#0E4A7B;
  overflow:hidden;
}

.team-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}

.team-copy{
  padding:22px;
}

.team-copy h3{
  color:var(--blue);
  font-size:1.15rem;
}

.team-copy p{
  margin-top:8px;
  font-size:.9rem;
  min-height:44px;
}

.team-copy a{
  display:inline-flex;
  margin-top:16px;
  color:var(--teal);
  font-weight:900;
}

.pillar-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.pillar-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}

.pillar-card span{
  display:inline-flex;
  width:44px;
  height:44px;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg,rgba(7,60,102,.08),rgba(16,128,111,.12));
  color:var(--teal);
  font-weight:950;
  margin-bottom:18px;
}

.pillar-card h3{
  color:var(--blue);
  font-size:1.2rem;
}

.pillar-card p{
  margin-top:12px;
}

@media (max-width:1024px){
  .page-hero-grid,
  .case-story{
    grid-template-columns:1fr;
  }

  .success-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .narrative-grid,
  .pillar-grid{
    grid-template-columns:1fr 1fr;
  }

  .timeline,
  .team-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .page-hero-card{
    max-width:420px;
  }

  .case-story-media{
    min-height:260px;
  }
}

@media (max-width:640px){
  .page-hero{
    min-height:auto;
    padding:calc(var(--header-h) + 74px) 0 74px;
  }

  .success-tools{
    align-items:stretch;
    flex-direction:column;
  }

  .success-grid,
  .narrative-grid,
  .pillar-grid,
  .timeline,
  .team-grid{
    grid-template-columns:1fr;
  }

  .timeline div{
    border-right:0;
    border-bottom:1px solid var(--line);
  }

  .timeline div:last-child{
    border-bottom:0;
  }

  .team-photo{
    height:280px;
  }

  .success-image{
    height:210px;
  }

  .case-story-copy{
    padding:26px;
  }
}



/* Ajuste de aire y bloque final para la página Casos de éxito */
.page-main .future{
  background:transparent;
  padding:26px 0 0;
  margin-top:42px;
}

.page-main .future-panel{
  grid-template-columns:1fr;
  gap:22px;
  background:
    radial-gradient(circle at 80% 20%,rgba(16,128,111,.32),transparent 26%),
    linear-gradient(135deg,#061927,#073C66 62%,#0E4A7B);
  border-radius:32px;
  padding:48px 42px;
  box-shadow:var(--shadow);
}

.page-main .future-panel::after{
  display:none;
}

.page-main .future-panel .btn{
  margin-top:10px;
  justify-self:start;
}

@media (max-width:860px){
  .page-main .future{
    margin-top:34px;
    padding-top:18px;
  }

  .page-main .future-panel{
    padding:34px 26px;
    gap:18px;
  }

  .page-main .future-panel .btn{
    width:100%;
    justify-self:stretch;
  }
}

/* Ajuste reforzado: separar y encapsular el CTA final de Casos de éxito */
body .future{
  margin-top:96px;
}

body .future .future-panel{
  max-width:1180px;
  margin:0 auto;
}

body .future .future-panel .btn{
  margin-top:26px;
}

body .future.section-dark{
  padding-top:96px;
  padding-bottom:96px;
}

body .future.section-dark .future-panel{
  padding:56px 42px;
}

/* Variante para páginas internas cuando el CTA final quedó sin fondo oscuro */
body:not(.home) .future{
  padding-top:96px;
  padding-bottom:96px;
}

body:not(.home) .future-panel{
  gap:28px;
}

@media (max-width:860px){
  body .future{
    margin-top:72px;
  }

  body .future.section-dark{
    padding-top:72px;
    padding-bottom:72px;
  }

  body .future .future-panel .btn{
    margin-top:20px;
  }
}

/* CTA final específico de Casos de éxito */
.success-page .next-chapter{
  margin-top:96px;
  padding:56px 48px;
  border-radius:32px;
  background:
    radial-gradient(circle at 82% 18%,rgba(16,128,111,.32),transparent 28%),
    linear-gradient(135deg,#061927,#073C66 62%,#0E4A7B);
  color:#fff;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.success-page .next-chapter::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.10),transparent 48%),
    repeating-linear-gradient(115deg,rgba(255,255,255,.07) 0 1px,transparent 1px 20px);
  pointer-events:none;
}

.success-page .next-chapter h2,
.success-page .next-chapter p,
.success-page .next-chapter a{
  position:relative;
  z-index:1;
}

.success-page .next-chapter h2{
  color:#fff;
  max-width:920px;
  font-size:clamp(2.2rem,4.4vw,4.2rem);
}

.success-page .next-chapter p{
  margin-top:18px;
  max-width:880px;
  color:rgba(255,255,255,.80);
  font-size:1.05rem;
}

.success-page .next-chapter .btn{
  margin-top:34px;
}

.success-page .case-story-list + .next-chapter{
  margin-top:110px;
}

@media (max-width:860px){
  .success-page .next-chapter{
    margin-top:72px;
    padding:38px 28px;
    border-radius:26px;
  }

  .success-page .case-story-list + .next-chapter{
    margin-top:82px;
  }

  .success-page .next-chapter .btn{
    margin-top:26px;
    width:100%;
  }
}

