:root{
  --bg:#eef4fb;
  --bg-soft:#e4eef9;
  --surface:rgba(255,255,255,.82);
  --surface-strong:rgba(255,255,255,.92);
  --surface-soft:rgba(234,242,251,.88);
  --text:#10213a;
  --text-soft:#4f6788;
  --line:rgba(16,33,58,.08);
  --brand:#1677d8;
  --brand-2:#0a3e7a;
  --brand-3:#8eb6e8;
  --glow:0 24px 54px rgba(20,63,121,.10);
  --radius-xl:34px;
  --radius-lg:24px;
  --radius-md:18px;
  --max:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:#ffffff;
}
..site-bg{
  position:fixed; inset:0; pointer-events:none; opacity:.12;
  background:
    linear-gradient(transparent 0 97%, rgba(11,41,79,.035) 97% 100%),
    linear-gradient(90deg, transparent 0 97%, rgba(11,41,79,.035) 97% 100%);
  background-size:100% 36px, 36px 100%;
  mask-image:linear-gradient(180deg, transparent, rgba(0,0,0,.35) 14%, rgba(0,0,0,.18) 100%);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(var(--max), calc(100% - 40px));margin:0 auto}
.section-padding{padding:86px 0}
.header{
  position:sticky; top:0; z-index:100;
  background:#ffffff;
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav{min-height:88px; display:flex; align-items:center; justify-content:space-between; gap:24px}
.brand img{height:68px; width:auto; filter:none}
.nav-links{display:flex; align-items:center; gap:26px}
.nav-links a{font-size:14px; color:#27486f; font-weight:700; position:relative}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  transform:scaleX(0); transform-origin:left; transition:.25s ease;
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{display:flex; align-items:center; gap:12px}
.menu-btn{
  display:none; border:1px solid rgba(23,54,95,.12); background:rgba(255,255,255,.82); color:#17365f;
  width:44px; height:44px; border-radius:14px; font-size:20px; cursor:pointer;
}
.lang-switch{display:flex; align-items:center; gap:6px; padding:5px; background:rgba(22,119,216,.08); border:1px solid rgba(22,119,216,.12); border-radius:999px}
.lang-btn{
  border:none; background:transparent; color:#27486f; font-weight:800; font-size:12px;
  padding:8px 11px; border-radius:999px; cursor:pointer;
}
.lang-btn.active{background:#fff; box-shadow:0 8px 18px rgba(20,63,121,.10)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 20px; border-radius:999px; font-size:14px; font-weight:800;
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#fff; background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 18px 34px rgba(22,119,216,.20);
}
.btn-secondary,.btn-ghost{
  color:#17365f; border-color:rgba(23,54,95,.12); background:rgba(255,255,255,.72);
}
.btn-secondary:hover,.btn-ghost:hover{background:#fff}

.hero-inicio{
  min-height:100vh; display:flex; align-items:center; justify-content:center; position:relative;
}
..hero-inicio-container{
  text-align:center; padding:56px 32px; border-radius:40px; width:min(1120px,100%);
  border:1px solid rgba(16,33,58,.05);
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow:0 18px 40px rgba(20,63,121,.06);
}
.hero-logo{width:min(760px, 100%); height:auto; margin:0 auto; filter:none}
.hero-kicker{
  margin:18px 0 10px; font-size:13px; font-weight:800; letter-spacing:.16em;
  text-transform:uppercase; color:#48698f;
}
.hero-inicio h1{
  margin:0 auto 16px; font-size:clamp(34px,5.2vw,68px); line-height:1.02;
  letter-spacing:-.05em; max-width:14ch; color:#10213a;
}
.hero-lead{margin:0; font-size:18px; line-height:1.82; color:#4f6788; max-width:64ch}
.hero-inicio .hero-lead{margin:0 auto}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin-top:28px}
.hero-actions.centered{justify-content:center}

.insight{padding:24px 0 10px}
.hero-grid{display:grid; grid-template-columns:1.08fr .92fr; gap:34px; align-items:center}
.eyebrow,.section-kicker{
  display:inline-flex; align-items:center; gap:10px; padding:9px 14px; border-radius:999px;
  font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
}
.eyebrow{background:rgba(31,95,171,.08); color:#315b8e; border:1px solid rgba(31,95,171,.12)}
.section-kicker{background:rgba(22,119,216,.10); color:#315b8e; border:1px solid rgba(22,119,216,.12)}
.eyebrow::before,.section-kicker::before{content:""; width:8px; height:8px; border-radius:50%; background:var(--brand)}
.hero-copy h2{
  margin:18px 0 16px; font-size:clamp(34px,4.6vw,60px);
  line-height:1; letter-spacing:-.05em; color:#10213a; max-width:12ch;
}
.hero-metrics{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:34px}
.metric-card{
  padding:18px; border-radius:22px; background:rgba(255,255,255,.78);
  border:1px solid rgba(16,33,58,.08); box-shadow:0 18px 38px rgba(16,33,58,.06);
}
.metric-card strong{display:block; font-size:24px; color:#10213a}
.metric-card span{display:block; margin-top:8px; font-size:13px; line-height:1.6; color:#587190}

.hero-visual{position:relative; min-height:640px}
.visual-card{
  border-radius:var(--radius-xl); border:1px solid rgba(16,33,58,.08);
  background:
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.65), transparent 16%),
    radial-gradient(circle at 82% 76%, rgba(199,220,246,.55), transparent 18%),
    linear-gradient(160deg, rgba(20,79,149,.95), rgba(67,128,203,.92) 46%, rgba(193,216,244,.86) 100%);
  box-shadow:0 26px 56px rgba(20,63,121,.14);
  position:relative; overflow:hidden;
}
.visual-main{padding:28px; min-height:640px; display:flex; flex-direction:column; justify-content:space-between}
.visual-main::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(transparent 0 94%, rgba(255,255,255,.08) 94% 100%),
    linear-gradient(90deg, transparent 0 94%, rgba(255,255,255,.08) 94% 100%);
  background-size:100% 40px,40px 100%; opacity:.24; pointer-events:none;
}
.visual-top,.visual-bottom{position:relative; z-index:1}
.visual-top{display:flex; justify-content:space-between; align-items:center; gap:10px; color:#fff}
.visual-top span{font-weight:800; letter-spacing:.04em}
.visual-top small{font-size:12px; text-transform:uppercase; letter-spacing:.12em; opacity:.76}
.architecture{position:relative; z-index:1; display:grid; grid-template-columns:1fr auto 1fr; gap:18px; align-items:center}
.arch-box{
  padding:22px; border-radius:24px; background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18); backdrop-filter:blur(10px);
}
.arch-box h3{margin:0 0 12px; font-size:20px; color:#fff}
.arch-box ul{margin:0; padding-left:18px; color:rgba(255,255,255,.90); font-size:14px; line-height:1.8}
.arch-core{
  width:74px; height:74px; border-radius:24px; display:grid; place-items:center;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.20);
  font-size:28px; color:#fff;
}
..visual-bottom{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  align-items:start;
}
..visual-bottom div{
  padding:16px; border-radius:18px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.16);
  min-height:122px;
}
.visual-bottom strong{display:block; font-size:13px; color:#fff; text-transform:uppercase; letter-spacing:.08em}
.visual-bottom span{display:block; margin-top:8px; font-size:13px; line-height:1.6; color:rgba(255,255,255,.92)}
..floating-note{
  position:absolute; padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.20);
  border:1px solid rgba(255,255,255,.24); backdrop-filter:blur(12px); color:#fff; font-size:12px;
  font-weight:800; letter-spacing:.04em; text-transform:uppercase; box-shadow:0 12px 22px rgba(20,63,121,.10);
  max-width:none; min-width:220px; text-align:center; z-index:2;
}
.note-1{top:18px; right:26px}
.note-2{left:22px; bottom:112px}

.section-head{display:flex; align-items:end; justify-content:space-between; gap:28px; margin-bottom:28px}
.section-head h2{margin:12px 0 0; font-size:clamp(30px,4vw,46px); line-height:1.02; letter-spacing:-.04em; color:#10213a; max-width:12ch}
.section-head p{margin:0; max-width:58ch; color:#56708f; line-height:1.8}
.solution-grid,.cases-grid,.sectors-grid,.method-grid{display:grid; gap:18px}
.solution-grid{grid-template-columns:repeat(2,1fr)}
.cases-grid{grid-template-columns:repeat(3,1fr)}
.sectors-grid,.method-grid{grid-template-columns:repeat(4,1fr)}
.solution-card,.case-card,.sector-card,.method-card,.about-card,.contact-card{
  border:1px solid rgba(16,33,58,.08); background:rgba(255,255,255,.82); box-shadow:var(--glow); border-radius:28px;
}
.solution-card,.case-card,.sector-card,.method-card{padding:28px}
.solution-card h3,.case-card h3,.sector-card h3,.method-card h3,.about-card h2,.contact-card h2{margin:0 0 12px; color:#10213a}
.solution-card p,.case-card p,.sector-card p,.method-card p,.about-card p,.contact-card p{margin:0; color:#56708f; line-height:1.8}
.solution-card ul{margin:16px 0 0; padding-left:18px; color:#40607f; line-height:1.85}
.case-tag{
  display:inline-flex; padding:8px 12px; border-radius:999px; margin-bottom:14px;
  background:rgba(22,119,216,.10); color:#315b8e; border:1px solid rgba(22,119,216,.12); font-weight:800; font-size:12px; text-transform:uppercase; letter-spacing:.08em;
}
.method-card span{
  display:inline-grid; place-items:center; width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; font-weight:800; margin-bottom:16px;
}
.alt-section{background:#fbfdff; border-top:1px solid rgba(16,33,58,.05); border-bottom:1px solid rgba(16,33,58,.05)}
.about-card,.contact-card{padding:34px}
.contact-emails{display:flex; flex-wrap:wrap; gap:16px; margin:20px 0 24px}
.contact-emails a{
  display:inline-flex; padding:12px 16px; border-radius:999px; background:#fff; color:#1a436f;
  border:1px solid rgba(16,33,58,.08); box-shadow:0 12px 24px rgba(20,63,121,.06)
}
.contact-form{margin-top:8px}
.form-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}
.contact-form input,.contact-form textarea{
  width:100%; border:1px solid rgba(16,33,58,.10); background:rgba(255,255,255,.92); color:#10213a;
  border-radius:18px; padding:16px 18px; font:inherit; margin-top:14px;
}
.contact-form textarea{resize:vertical}
.footer{padding:28px 0; border-top:1px solid rgba(16,33,58,.08); background:#ffffff}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:18px}
.footer-inner p{margin:0; color:#56708f}
.footer-links{display:flex; gap:18px; flex-wrap:wrap; color:#315b8e; font-weight:600}

.reveal{opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s ease}
.reveal-delay{transition-delay:.12s}
.reveal.show{opacity:1; transform:none}

@media (max-width: 1120px){
  .hero-grid,.section-head{grid-template-columns:1fr; display:grid}
  .hero-copy h2,.section-head h2{max-width:none}
  .cases-grid{grid-template-columns:1fr}
  .sectors-grid,.method-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 860px){
  .menu-btn{display:inline-grid; place-items:center}
  .nav{position:relative}
  .nav-cta .btn-ghost,.nav-cta .btn-primary{display:none}
  .nav-links{
    display:none; position:absolute; top:78px; left:0; right:0; flex-direction:column; align-items:flex-start;
    padding:18px; border-radius:22px; border:1px solid rgba(16,33,58,.10); background:rgba(255,255,255,.98); box-shadow:0 20px 40px rgba(16,33,58,.12)
  }
  .nav-links.open{display:flex}
  .hero-grid,.solution-grid,.form-grid{grid-template-columns:1fr}
  .hero-metrics,.visual-bottom,.architecture,.sectors-grid,.method-grid{grid-template-columns:1fr}
  .hero-visual,.visual-main{min-height:auto}
  .note-1,.note-2{display:none}
  .section-padding{padding:60px 0}
}
@media (max-width: 560px){
  .container{width:min(var(--max), calc(100% - 24px))}
  .hero-inicio-container{padding:34px 18px}
  .hero-inicio h1{font-size:clamp(32px,10vw,50px)}
  .brand img{height:56px; max-width:220px}
  .solution-card,.case-card,.sector-card,.method-card,.about-card,.contact-card{padding:22px}
  .footer-inner{flex-direction:column; align-items:flex-start}
}


/* FIX overlapping badges (desktop) */
.arch-visual{
  position:relative;
  padding-top:80px;
}

.floating-note{
  white-space:nowrap;
}

.note-1{
  top:20px;
  right:20px;
}

.note-2{
  bottom:20px;
  left:20px;
}

/* ensure text doesn't wrap badly */
.floating-note{
  font-size:11px;
  letter-spacing:0.04em;
}

/* fix outputs label overlap */
.visual-bottom div{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:6px;
}

.visual-bottom div span{
  display:block;
  line-height:1.4;
}


/* === ULTRA PREMIUM MOTION LAYER === */
.hero-visual-interactive{
  perspective: 1200px;
}
.tilt-card{
  transform-style: preserve-3d;
  transition: transform .18s ease, box-shadow .25s ease;
  will-change: transform;
}
.hero-visual-interactive:hover .tilt-card{
  box-shadow: 0 36px 72px rgba(20,63,121,.18);
}
.arch-box,
.arch-core,
.visual-bottom div,
.floating-note{
  transform: translateZ(0);
  transition: transform .25s ease, background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.hero-visual-interactive:hover .arch-box{
  transform: translateY(-4px);
}
.hero-visual-interactive:hover .arch-core{
  transform: translateY(-3px) scale(1.02);
}
.hero-visual-interactive:hover .visual-bottom div{
  transform: translateY(-3px);
}
.hero-visual-interactive:hover .floating-note{
  background: rgba(255,255,255,.26);
}

.floating-note{
  animation: badgeFloat 5.8s ease-in-out infinite;
}
.note-1{ animation-delay: 0s; }
.note-2{ animation-delay: 1.2s; }

@keyframes badgeFloat {
  0%,100% { transform: translateY(0px); }
  50% { transform: translateY(-6px); }
}

.hero-kicker{
  animation: softPulse 4.8s ease-in-out infinite;
}
@keyframes softPulse {
  0%,100% { opacity: .88; letter-spacing: .16em; }
  50% { opacity: 1; letter-spacing: .18em; }
}

.section-kicker,
.eyebrow{
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.section-kicker:hover,
.eyebrow:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(20,63,121,.08);
}

.solution-card,
.case-card,
.sector-card,
.method-card,
.metric-card,
.contact-emails a,
.contact-form input,
.contact-form textarea,
.btn{
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.solution-card:hover,
.case-card:hover,
.sector-card:hover,
.method-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 24px 48px rgba(20,63,121,.11);
  border-color: rgba(22,119,216,.18);
}

.metric-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(16,33,58,.10);
}

.contact-form input:focus,
.contact-form textarea:focus{
  outline: none;
  border-color: rgba(22,119,216,.38);
  box-shadow: 0 0 0 4px rgba(22,119,216,.08);
  background: #fff;
}

.contact-emails a:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(20,63,121,.09);
}

.nav-links a,
.footer-links a{
  transition: color .2s ease, opacity .2s ease;
}
.nav-links a:hover,
.footer-links a:hover{
  color: var(--brand-2);
}

.hero-inicio-container{
  position: relative;
  overflow: hidden;
}
.hero-inicio-container::before{
  content: "";
  position: absolute;
  inset: auto -10% -40% -10%;
  height: 180px;
  background: radial-gradient(circle, rgba(22,119,216,.10), transparent 65%);
  pointer-events: none;
}
.hero-logo{
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: reduce){
  .floating-note,
  .hero-kicker{
    animation: none !important;
  }
  .tilt-card,
  .arch-box,
  .arch-core,
  .visual-bottom div,
  .solution-card,
  .case-card,
  .sector-card,
  .method-card,
  .metric-card,
  .btn{
    transition: none !important;
  }
}

.nav-links a.is-active{
  color: var(--brand-2);
}
.nav-links a.is-active::after{
  transform: scaleX(1);
}


/* ===== User-requested final fixes only ===== */

/* 1) Main logo inscription centered */
.hero-inicio-container{
  text-align:center;
}
.hero-logo{
  margin-left:auto;
  margin-right:auto;
}
.hero-kicker{
  display:block;
  width:100%;
  max-width:980px;
  margin:10px auto 0;
  text-align:center;
  line-height:1.6;
}

/* 2) Improve lower text block inside operating model panel */
.visual-bottom{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  align-items:stretch;
}
.visual-bottom div{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:8px;
  min-height:136px;
  padding:18px;
}
.visual-bottom strong{
  margin:0;
  line-height:1.1;
}
.visual-bottom span{
  margin:0;
  line-height:1.55;
  overflow-wrap:anywhere;
}

/* Hide removed badges in case browser cache keeps old HTML */
.floating-note{
  display:none !important;
}

/* 3) Footer legal text */
.footer-inner p{
  white-space:normal;
}

@media (max-width: 860px){
  .hero-kicker{
    max-width:100%;
    letter-spacing:.12em;
    font-size:12px;
  }
  .visual-bottom{
    grid-template-columns:1fr;
    gap:12px;
  }
  .visual-bottom div{
    min-height:auto;
  }
}

@media (max-width: 560px){
  .hero-kicker{
    font-size:11px;
    letter-spacing:.10em;
  }
}
