﻿@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --ink:#111827;
  --bg:#f7f8fb;
  --bg-soft:#eef1f7;
  --surface:#ffffff;
  --blue:#3b6fd6;
  --blue-dark:#2c54a8;
  --blue-soft:#e8f0fd;
  --amber:#f0a93b;
  --amber-soft:#fdf1de;
  --slate:#6b7585;
  --line:#e6e9f0;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 2px 10px rgba(17,24,39,0.05);
  --shadow-lg:0 16px 40px rgba(17,24,39,0.12);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
}
h1,h2,h3,h4{
  font-family:'Poppins',sans-serif;
  font-weight:700;
  margin:0;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.mono{
  font-family:'Inter',sans-serif;
  font-weight:600;
  letter-spacing:0.02em;
  text-transform:uppercase;
  font-size:0.74rem;
  color:var(--blue);
}
a{color:inherit; text-decoration:none;}
.wrap{max-width:1140px; margin:0 auto; padding:0 24px;}
.hairline{border-top:1px solid var(--line);}

/* ---------- NAV ---------- */
header.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
nav.site-nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:1140px; margin:0 auto;
}
.logo{padding:4px 0;}
.logo img{height:30px; display:block;}
.logo-img{
  height:44px !important;
  filter:drop-shadow(0 2px 6px rgba(17,24,39,0.18));
  transition:transform .18s ease, filter .18s ease;
}
.logo:hover .logo-img{transform:scale(1.04); filter:drop-shadow(0 4px 10px rgba(59,111,214,0.35));}
.navlinks{display:flex; gap:6px; align-items:center; flex-wrap:wrap;}
.navlinks a{
  font-family:'Inter',sans-serif; font-size:0.92rem; font-weight:600;
  color:var(--ink);
  padding:8px 14px; border-radius:999px;
  transition:background .15s ease, color .15s ease;
}
.navlinks a:hover, .navlinks a.active{background:var(--blue-soft); color:var(--blue-dark);}
.navlinks a:focus-visible, button:focus-visible, .btn:focus-visible{
  outline:2px solid var(--blue); outline-offset:3px;
}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--blue); color:#fff;
  font-family:'Inter',sans-serif; font-size:0.92rem; font-weight:600;
  padding:13px 24px; border-radius:999px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  border:1px solid var(--blue);
  cursor:pointer;
  box-shadow:var(--shadow);
}
.btn:hover{background:var(--blue-dark); border-color:var(--blue-dark); transform:translateY(-1px); box-shadow:var(--shadow-lg);}
.btn-ghost{background:var(--surface); color:var(--ink); border:1px solid var(--line);}
.btn-ghost:hover{background:var(--bg-soft); border-color:var(--line); color:var(--ink);}
.navcta{margin-left:8px; padding:10px 20px; font-size:0.85rem;}
.navcta{display:none;}
@media(min-width:900px){.navcta{display:inline-flex;}}

/* ---------- HERO ---------- */
.hero, .page-hero{
  background:linear-gradient(120deg, #0f1729 0%, #1d2740 28%, #2c54a8 62%, #3b6fd6 100%);
  border-radius:var(--radius);
  padding:56px 40px 64px;
  margin-top:20px;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.hero::before, .page-hero::before{
  content:""; position:absolute; top:-40%; right:-10%; width:60%; height:180%;
  background:radial-gradient(circle, rgba(240,169,59,0.22), transparent 70%);
  pointer-events:none;
}
@media(min-width:760px){.hero, .page-hero{padding:72px 56px 80px;}}
.spec-row{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom:32px; position:relative; z-index:1;
}
.spec-row div{
  font-family:'Inter',sans-serif; font-size:0.8rem; color:#d7def0;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.18); border-radius:999px;
  padding:7px 14px;
}
.spec-row b{color:#fff; font-weight:600;}
.hero h1, .page-hero h1{
  font-size:clamp(2.3rem, 5vw, 3.6rem);
  line-height:1.12;
  max-width:820px;
  color:#fff;
  position:relative; z-index:1;
}
.hero h1 em, .page-hero h1 em{
  font-style:normal; color:#ffd28a;
  background:none;
  padding:0;
}
.hero-sub, .page-hero .lead{
  margin-top:20px; max-width:560px;
  color:#cdd5e6; font-size:1.08rem; line-height:1.6;
  position:relative; z-index:1;
}
.hero-actions{display:flex; gap:14px; margin-top:28px; flex-wrap:wrap; position:relative; z-index:1;}
.hero .btn-ghost, .page-hero .btn-ghost{background:rgba(255,255,255,0.08); color:#fff; border-color:rgba(255,255,255,0.35);}
.hero .btn-ghost:hover, .page-hero .btn-ghost:hover{background:rgba(255,255,255,0.18); border-color:#fff;}

/* signature ticket */
.ticket{
  margin-top:48px;
  border:1px solid var(--line);
  background:var(--surface); color:var(--ink);
  border-radius:var(--radius);
  overflow:hidden;
  display:grid;
  grid-template-columns: 1fr;
  box-shadow:var(--shadow-lg);
}
@media(min-width:760px){.ticket{grid-template-columns: 1.1fr 1fr;}}
.ticket-left{padding:28px 30px; border-bottom:1px solid var(--line); position:relative;}
.ticket-left::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:5px;
  background:linear-gradient(180deg, var(--blue), var(--amber));
}
@media(min-width:760px){.ticket-left{border-bottom:none; border-right:1px solid var(--line);}}
.ticket-id{color:var(--amber); background:var(--amber-soft); display:inline-block; padding:4px 10px; border-radius:999px;}
.ticket-left h3{color:var(--ink); font-size:1.25rem; margin-top:12px;}
.ticket-meta{margin-top:16px; display:flex; gap:22px; flex-wrap:wrap;}
.ticket-meta div{font-family:'Inter',sans-serif; font-size:0.72rem; color:var(--slate); text-transform:uppercase; font-weight:600;}
.ticket-meta div b{display:block; color:var(--ink); font-size:0.95rem; margin-top:4px; font-weight:700; text-transform:none;}
.ticket-right{padding:28px 30px; display:flex; flex-direction:column; justify-content:center; gap:10px; background:var(--bg-soft);}
.progress-bar{height:8px; background:#dfe4ee; border-radius:999px; overflow:hidden;}
.progress-fill{height:100%; width:72%; background:linear-gradient(90deg, var(--blue), var(--amber)); border-radius:999px; animation:fillgrow 1.2s ease-out;}
@keyframes fillgrow{from{width:0%} to{width:72%}}
.ticket-right p{font-family:'Inter',sans-serif; font-size:0.78rem; color:var(--slate); font-weight:600;}

/* ---------- SECTION TITLES ---------- */
.section{padding:72px 0;}
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end; gap:24px;
  margin-bottom:40px; flex-wrap:wrap;
}
.section-tag{
  background:var(--blue-soft); color:var(--blue-dark); display:inline-block;
  padding:5px 12px; border-radius:999px; margin-bottom:10px;
}
.section h2{font-size:clamp(1.7rem,3vw,2.3rem);}
.section-note{max-width:340px; color:var(--slate); font-size:0.95rem; line-height:1.55;}

/* ---------- OFFER CARDS (productos + servicio en home) ---------- */
.offers{display:grid; grid-template-columns:1fr; gap:20px;}
@media(min-width:760px){.offers{grid-template-columns:repeat(3,1fr);}}
.offer{
  background:var(--surface); padding:28px 26px; display:flex; flex-direction:column; min-height:280px;
  border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow);
  transition:transform .18s ease, box-shadow .18s ease;
}
.offer:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg);}
.offer .icon{
  width:46px; height:46px; border-radius:14px; background:var(--blue-soft);
  display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:14px;
}
.offer h3{font-size:1.3rem; margin-top:4px;}
.offer p{color:#4a5263; line-height:1.55; margin-top:10px; flex:1; font-size:0.93rem;}
.offer .pillrow{display:flex; gap:6px; flex-wrap:wrap; margin-top:14px;}
.offer .pillrow span{
  font-family:'Inter',sans-serif; font-size:0.7rem; font-weight:600;
  background:var(--bg-soft); padding:5px 10px; border-radius:999px; color:var(--slate);
}
.offer .more{
  margin-top:20px; font-family:'Inter',sans-serif; font-size:0.88rem; font-weight:700;
  color:var(--blue); display:inline-flex; width:fit-content; align-items:center; gap:4px;
}
.offer .more:hover{color:var(--blue-dark); gap:8px;}

/* ---------- MODULE / SERVICE LIST ---------- */
.modules{display:grid; grid-template-columns:1fr; gap:14px;}
.module{
  display:grid; grid-template-columns: 56px 1fr; gap:20px; align-items:flex-start;
  padding:22px 22px; border-radius:var(--radius-sm); background:var(--surface);
  border:1px solid var(--line); box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .15s ease;
}
.module:hover{transform:translateY(-2px); box-shadow:var(--shadow-lg);}
.module .num{
  width:40px; height:40px; border-radius:12px;
  background:linear-gradient(135deg, var(--blue), var(--blue-dark)); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:700; font-size:0.95rem;
  display:flex; align-items:center; justify-content:center;
}
.module h3{font-size:1.12rem; margin-bottom:6px;}
.module p{margin:0; color:#4a5263; line-height:1.55; max-width:560px; font-size:0.94rem;}

/* ---------- PROCESO ---------- */
.process{background:var(--bg-soft); border-radius:var(--radius); margin:0 0;}
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:16px;}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.steps{grid-template-columns:1fr;}}
.step{
  background:var(--surface); padding:24px 20px; border-radius:var(--radius-sm);
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.step .mono{
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; border-radius:999px; background:var(--amber-soft); color:#a06a0e;
  font-size:0.72rem; margin-bottom:10px;
}
.step h4{font-family:'Poppins',sans-serif; font-size:1.05rem; margin:6px 0 8px;}
.step p{margin:0; font-size:0.88rem; color:var(--slate); line-height:1.55;}

/* ---------- PORTFOLIO ---------- */
.cases{display:grid; grid-template-columns:1fr; gap:18px;}
@media(min-width:760px){.cases{grid-template-columns:1fr 1fr;}}
.case{
  background:var(--surface); padding:28px; display:flex; flex-direction:column; min-height:220px;
  border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow);
}
.case .tag-row{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px;}
.case .tag-row .mono{color:var(--slate); background:var(--bg-soft); padding:4px 10px; border-radius:999px;}
.case h3{margin-top:14px; font-size:1.3rem;}
.case p{color:#4a5263; line-height:1.55; margin-top:10px; flex:1; font-size:0.93rem;}
.case .result{
  margin-top:16px; padding-top:16px; border-top:1px solid var(--line);
  display:flex; gap:28px; font-family:'Inter',sans-serif; font-size:0.74rem; color:var(--slate); font-weight:600; text-transform:uppercase;
}
.case .result b{display:block; color:var(--blue-dark); font-size:1.2rem; font-family:'Poppins',sans-serif; text-transform:none; margin-top:2px;}

/* ---------- BLOG ---------- */
.posts{display:grid; grid-template-columns:1fr; gap:16px;}
@media(min-width:760px){.posts{grid-template-columns:repeat(3,1fr);}}
.post{
  padding:24px; border-radius:var(--radius-sm); background:var(--surface);
  border:1px solid var(--line); box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .15s ease;
}
.post:hover{transform:translateY(-3px); box-shadow:var(--shadow-lg);}
.post .mono{background:var(--blue-soft); color:var(--blue-dark); padding:4px 10px; border-radius:999px; display:inline-block;}
.post h4{font-family:'Poppins',sans-serif; font-size:1.08rem; margin:12px 0 8px; line-height:1.35;}
.post p{margin:0; color:var(--slate); font-size:0.88rem; line-height:1.55;}

/* ---------- CONTACT ---------- */
.contact{
  background:linear-gradient(135deg, var(--ink), #1d2740); color:#fff; border-radius:var(--radius);
  padding:48px 32px; display:grid; gap:36px; grid-template-columns:1fr;
  box-shadow:var(--shadow-lg);
}
@media(min-width:760px){.contact{grid-template-columns:1.1fr 1fr; padding:56px 50px;}}
.contact h2{color:#fff; font-size:clamp(1.7rem,3.2vw,2.3rem);}
.contact .mono{background:var(--amber-soft); color:#a06a0e;}
.contact p.lead{color:#c7ccd6; margin-top:14px; line-height:1.6; max-width:420px;}
.field{margin-bottom:16px;}
.field label{display:block; font-family:'Inter',sans-serif; font-size:0.78rem; font-weight:600; color:#aab2c5; margin-bottom:6px;}
.field input, .field textarea, .field select{
  width:100%; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.16); color:#fff;
  padding:12px 14px; font-family:'Inter',sans-serif; font-size:0.94rem; border-radius:var(--radius-sm);
}
.field textarea{resize:vertical; min-height:80px;}
.field input:focus, .field textarea:focus, .field select:focus{outline:2px solid var(--amber); outline-offset:1px;}
.contact-form .btn{width:100%; justify-content:center; background:var(--amber); border-color:var(--amber); color:var(--ink); margin-top:6px;}
.contact-form .btn:hover{background:#e2992a;}
.field-error{color:#ffb454; font-size:0.78rem; font-family:'Inter',sans-serif; display:block; margin-top:4px;}
.success-msg{
  margin-top:14px; padding:13px 16px; background:rgba(240,169,59,0.15); color:var(--amber);
  font-family:'Inter',sans-serif; font-size:0.88rem; border-radius:var(--radius-sm); border:1px solid rgba(240,169,59,0.3);
}

/* ---------- CTA strip (paginas de producto/servicio) ---------- */
.cta-strip{
  border-radius:var(--radius); padding:38px 36px;
  display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
  background-image:linear-gradient(120deg, #0f1729, #1d2740 45%, #2c54a8 100%);
  box-shadow:var(--shadow);
}
.cta-strip h3{font-size:1.35rem; max-width:480px; font-weight:700; color:#fff;}
.cta-strip .btn{background:var(--amber); border-color:var(--amber); color:var(--ink);}
.cta-strip .btn:hover{background:#e2992a; border-color:#e2992a;}

/* ---------- FOOTER ---------- */
footer.site-footer{padding:32px 0; border-top:1px solid var(--line); margin-top:24px;}
.foot-row{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; max-width:1140px; margin:0 auto; padding:0 24px;}
.foot-row .mono{color:var(--slate); background:none; padding:0;}
.foot-links{display:flex; gap:18px;}
.foot-links a{font-family:'Inter',sans-serif; font-size:0.84rem; font-weight:600; color:var(--slate);}
.foot-links a:hover{color:var(--blue);}

/* ---------- WHATSAPP FLOTANTE ---------- */
.whatsapp-float{
  position:fixed; bottom:24px; right:24px; z-index:60;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 18px rgba(37,211,102,0.45);
  transition:transform .18s ease, box-shadow .18s ease;
}
.whatsapp-float:hover{transform:translateY(-2px) scale(1.05); box-shadow:0 10px 24px rgba(37,211,102,0.55);}
.whatsapp-float:focus-visible{outline:2px solid #128C7E; outline-offset:3px;}

/* ---------- WHATSAPP INLINE (sección de contacto) ---------- */
.whatsapp-inline{
  display:inline-flex; align-items:center; gap:8px; margin-top:18px;
  color:#fff; background:rgba(37,211,102,0.18); border:1px solid rgba(37,211,102,0.4);
  padding:9px 16px; border-radius:999px; font-weight:600; font-size:0.92rem;
  transition:background .15s ease;
}
.whatsapp-inline:hover{background:rgba(37,211,102,0.3);}

/* ---------- ANCHOR TABS (estilo Azure: pestañas pegajosas bajo el hero) ---------- */
.anchor-tabs-wrap{
  position:sticky; top:65px; z-index:40;
  background:rgba(255,255,255,0.95); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line); border-top:1px solid var(--line);
}
.anchor-tabs{
  display:flex; gap:4px; overflow-x:auto; padding:10px 0;
  max-width:1140px; margin:0 auto; padding-left:24px; padding-right:24px;
  -ms-overflow-style:none; scrollbar-width:none;
}
.anchor-tabs::-webkit-scrollbar{display:none;}
.anchor-tabs a{
  flex:0 0 auto; font-size:0.86rem; font-weight:600; color:var(--slate);
  padding:8px 14px; border-radius:999px; white-space:nowrap;
  transition:background .15s ease, color .15s ease;
}
.anchor-tabs a:hover{background:var(--blue-soft); color:var(--blue-dark);}

/* ---------- STATS (estilo Azure: panel con degradado y números grandes) ---------- */
.stats{
  display:grid; grid-template-columns:1fr; gap:1px;
  background:rgba(255,255,255,0.12);
  border-radius:var(--radius); overflow:hidden;
  background-image:linear-gradient(120deg, #0f1729, #1d2740 40%, #2c54a8 100%);
}
@media(min-width:760px){.stats{grid-template-columns:repeat(3,1fr);}}
.stat{background:rgba(255,255,255,0.03); padding:36px 32px;}
.stat .stat-num{
  font-family:'Poppins',sans-serif; font-weight:800; font-size:2.8rem; line-height:1;
  color:#ffd28a; display:block;
}
.stat .stat-label{margin-top:10px; color:#cdd5e6; font-size:0.92rem; line-height:1.5; max-width:280px;}

/* ---------- FAQ (acordeón nativo) ---------- */
.faq{display:flex; flex-direction:column; gap:10px;}
.faq details{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:0; overflow:hidden;
}
.faq summary{
  list-style:none; cursor:pointer; padding:18px 22px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  font-family:'Poppins',sans-serif; font-weight:600; font-size:1rem; color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{
  content:"+"; font-size:1.4rem; color:var(--blue); flex-shrink:0;
  transition:transform .2s ease;
}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .faq-body{padding:0 22px 20px; color:#4a5263; font-size:0.94rem; line-height:1.6;}

/* ---------- BANNER DE LOGO (ancho completo de la página) ---------- */
.logo-banner{
  width:100%;
  background:linear-gradient(120deg, #0f1729 0%, #1d2740 35%, #2c54a8 75%, #3b6fd6 100%);
  display:flex; align-items:center; justify-content:center;
  padding:28px 24px;
  position:relative; overflow:hidden;
}
.logo-banner::before{
  content:""; position:absolute; top:-60%; left:10%; width:40%; height:220%;
  background:radial-gradient(circle, rgba(240,169,59,0.18), transparent 70%);
  pointer-events:none;
}
.banner-logo{
  height:48px; display:block;
}
@media(min-width:760px){.banner-logo{height:58px;}}
.logo-banner-card{
  background:#fff; border-radius:16px; padding:16px 28px;
  position:relative; z-index:1; box-shadow:0 8px 24px rgba(0,0,0,0.25);
}
