:root{ --bg:#f7f9fb; --card:#ffffff; --muted:#6b7280; --primary: rgb(232,103,2); --secondary: rgb(0,67,110); font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; }
*{box-sizing:border-box}
html,body{height:100%}
body {
  margin: 0;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--bg);
  color: #0b1220;
  line-height: 1.45;
  font-family: Inter, Arial, Helvetica, sans-serif;
}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:16px}
.container.header { position: sticky; z-index: 3; }
.topbar {
  position: sticky;   
  top: 0;
  left: 0;
  right: 0;
  z-index: 120030;
  background: linear-gradient(90deg, rgba(232,103,2,0.12), rgba(0,67,110,0.06));
  border-bottom: 1px solid rgba(255,255,255,0.03);
  padding: 8px 0;
}
.topbar .container {
  max-width: 1100px; 
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.header{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px}

.brand-logo{
  width:225px;
  height:90px;
  object-fit:contain;
  border-radius:8px;
  transition: transform .35s cubic-bezier(.2,.9,.3,1), filter .35s ease, opacity .25s ease;
  will-change: transform, filter, opacity;
  padding-left: 25px;
}

@keyframes logo-pop {
  0% {
    opacity: 0;
    transform: scale(.62) rotate(-8deg) translateY(10px);
    filter: drop-shadow(0 0 0 rgba(0,0,0,0));
  }
  60% {
    opacity: 1;
    transform: scale(1.08) rotate(3deg) translateY(-6px);
    filter: drop-shadow(0 16px 28px rgba(2,6,23,0.12));
  }
  100% {
    opacity: 1;
    transform: scale(1) rotate(0) translateY(0);
    filter: drop-shadow(0 8px 18px rgba(2,6,23,0.08));
  }
}

.brand-logo.logo-animate{
  animation: logo-pop 720ms cubic-bezier(.2,.9,.3,1) both;
}

.brand-logo:hover{
  transform: translateY(-3px) scale(1.03);
}

@media (prefers-reduced-motion: reduce){
  .brand-logo.logo-animate,
  .brand-logo:hover {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}

main#main, main { flex: 1 0 auto; }

.brand h1{font-size:18px;margin:0;color:var(--secondary)}
.subtitle{font-size:13px;color:var(--muted)}
.container.header { position: static; z-index: 50; }

.menu-toggle { display: none; background:transparent; border:0; font-size:22px; z-index:10010; }
.main-nav { display:flex; gap:10px; align-items:center; }

.nav-btn{color:rgb(0,67,110);background-color:transparent;border:0;padding:8px 14px;border-radius:10px;font-weight:600;cursor:pointer;transition:transform .18s ease, box-shadow .18s}
.nav-btn:hover{transform:translateY(-4px);box-shadow:0 8px 18px rgba(11,18,32,0.08)}
.hero{padding:26px 0}

.carousel {
  position: relative;
  width: 100%;
  max-width: 100%;
  border-radius: 14px;
  overflow: hidden;
  background: #e8eef6;
  aspect-ratio: 16 / 9;
  min-height: 260px;
  display: block;
}

.carousel .slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .5s cubic-bezier(.2,.9,.3,1), visibility 0s linear .5s;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.carousel .slide.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 2;
  transition: opacity .5s cubic-bezier(.2,.9,.3,1), visibility 0s linear 0s;
}

.slide-inner img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 12px;
  display: block;
  cursor: zoom-in;
  transition: transform .36s cubic-bezier(.2,.9,.3,1), filter .3s ease;
  box-shadow: 0 8px 30px rgba(2,6,23,0.06);
}

.slide-inner {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  box-sizing: border-box;
}

.carousel-dots {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 10px;
  display:flex;
  gap:8px;
  z-index: 35;
  pointer-events: auto;
}
.carousel-dots button {
  width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,0.6);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.12);
}
.carousel-dots button.active { background: var(--primary); transform: scale(1.12); }

.controls {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  gap: 10px;
  z-index: 30;
  pointer-events: none;
}

.controls-left { left: 12px; }
.controls-right { right: 12px; }
.controls button {
  pointer-events: auto;
  background: rgba(255,255,255,0.95);
  border: 0;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 18px;
  box-shadow: 0 6px 18px rgba(2,6,23,0.08);
}

.img-modal { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; z-index: 99999; }
.img-modal[aria-hidden="false"] { display: flex; }
.img-modal__backdrop { position:absolute; inset:0; background:rgba(2,6,23,0.6); backdrop-filter: blur(4px); }
.img-modal__content { position:relative; max-width:92vw; max-height:92vh; padding: 12px; box-sizing:border-box; z-index:10; display:flex; flex-direction:column; align-items:center; gap:8px; }
.img-modal__img { max-width:100%; max-height:80vh; border-radius:12px; object-fit:contain; box-shadow:0 18px 50px rgba(2,6,23,0.28); }
.img-modal__close { position:absolute; top:8px; right:8px; background:rgba(255,255,255,0.95); border:0; border-radius:8px; padding:6px 8px; cursor:pointer; }
.img-modal__caption { font-size:14px; color:#fff; opacity:0.95; margin-top:6px; text-align:center; }

.grid {
  grid-template-columns: 2fr 1fr;
  margin-top: 18px;
  align-items: start;
}

@media (max-width: 900px) {
  .grid {
    grid-template-columns: 1fr;
  }
}

.card-row { display:flex; gap:18px; padding:18px; }
.card-row .card-media {
  flex: 0 0 200px;
  max-width: 200px;
}
.card-row .card-media img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}
.card-row .card-body { flex:1; }


@media (max-width: 900px) {
  .card-row .card-media {
    width: 30%;
    max-width: 50%;
    flex: 0 0 auto;
  }
  .card-row .card-media img {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    object-fit: cover;
  }
}

.card#servicios {
  padding: 18px;
  box-sizing: border-box;
  width: 100%;
  order: 0;
}

#servicios {
  grid-column: 1 / -1;
}

.services {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 100%;
}
.card h3{margin:0 0 8px 0;color:var(--secondary)}

.img-modal { position:fixed; inset:0; display:none; align-items:center; justify-content:center; z-index:99999; }
.img-modal[aria-hidden="false"] { display:flex; }
.img-modal__backdrop { position:absolute; inset:0; background:rgba(2,6,23,0.6); backdrop-filter: blur(4px); }
.img-modal__content { position:relative; max-width:92vw; max-height:92vh; padding: 14px; box-sizing:border-box; z-index: 10; display:flex; flex-direction:column; align-items:center; gap:10px; }
.img-modal__img { max-width:100%; max-height:80vh; border-radius:12px; object-fit:contain; box-shadow:0 18px 50px rgba(2,6,23,0.28); }
.img-modal__close { position:absolute; top:8px; right:8px; background:rgba(255,255,255,0.9); border:0;border-radius:8px;padding:8px; cursor:pointer; }

.img-modal__content:focus { outline:none; }

.card { padding: 12px; }

.card-row {
  grid-column: 1 / -1;
  margin-top: 30px; 
}

.muted{color:var(--inherit);font-size:14px}
.services{display:flex;flex-direction:column;gap:12px}
.service-item{display:flex;gap:12px;align-items:flex-start}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:35px}
.gallery-item { overflow:hidden; border-radius:8px; position:relative; cursor: pointer; }
.gallery-item img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition: transform .5s cubic-bezier(.2,.9,.3,1), filter .4s ease;
  display:block;
}
.gallery-item::after {
  content: '';
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.18) 100%);
  opacity:0;
  transition:opacity .35s ease;
}
.gallery-item:hover img { transform: scale(1.06) translateY(-4px); filter: saturate(1.06) contrast(1.03); }
.gallery-item:hover::after { opacity:1; }


.contact-msg{margin:18px 0;padding:12px;border-radius:10px}
.contact-msg.success{background:rgba(34,197,94,0.12);color:#064e3b}
.contact-msg.error{background:rgba(239,68,68,0.1);color:#7f1d1d}
.contact-form label{display:block;margin-bottom:10px}
.contact-form input[type=text], .contact-form input[type=email], .contact-form textarea{width:100%;padding:10px;border-radius:8px;border:1px solid #e6e8eb}
.form-actions{display:flex;gap:8px;align-items:center}
.btn{background:var(--primary);color:#fff;padding:20px 24px;border-radius:8px;border:0;cursor:pointer}
.btn-secondary{background:transparent;border:1px solid rgba(0,0,0,0.06);padding:8px 12px;border-radius:8px}
@media (max-width:900px){.carousel img{height:260px}}

.menu-toggle { display: none; background:transparent; border:0; font-size:22px; z-index:10060; }

.main-nav { display:flex; gap:10px; align-items:center; }

@media (max-width: 640px) {
  .menu-toggle { display: block; z-index: 120000; } 

  #mainNav {
    position: fixed !important;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(92vw, 360px);
    max-width: 360px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: calc(1rem + 56px) 16px 24px;
    background: linear-gradient(180deg,#ffffff,#fbfdff);
    box-shadow: -18px 8px 48px rgba(2,6,23,0.22);
    transform: translateX(100%);
    transition: transform .36s cubic-bezier(.2,.9,.3,1);
    z-index: 120050; 
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    pointer-events: auto; 
    border-left: 1px solid rgba(2,6,23,0.04);
    -webkit-tap-highlight-color: transparent;
    will-change: transform;
  }

  #mainNav.open { transform: translateX(0); }

  .nav-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2,6,23,0.45);
    z-index: 120040; 
    opacity: 0;
    pointer-events: none; 
    transition: opacity .28s ease;
  }
  .nav-backdrop.show {
    opacity: 1;
    pointer-events: auto; 
  }

  .topbar { z-index: 120030; position: relative; }

  #mainNav .nav-btn {
    display: block;
    width: 100%;
    text-align: left;
    padding: 12px 14px;
    border-radius: 10px;
    font-weight: 700;
    color: var(--secondary);
    background: transparent;
  }
  #mainNav .nav-btn:hover, #mainNav .nav-btn:focus { background: rgba(2,6,23,0.04); outline: none; }

  body.nav-open { overflow: hidden; }
}

#servicios .service-item { align-items: center; }
#servicios .service-item > div:last-child { flex: 1 1 auto; min-width: 0; }
#servicios .service-item .icon { flex-shrink: 0; }

#mainNav, #mainNav * { pointer-events: auto !important; }@media (max-width:640px) {
  .menu-toggle { display: block; }

  html { overflow-y: scroll;}

#mainNav {
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(92vw, 360px);
    max-width: 360px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: calc(1rem + 56px) 16px 24px;
    background: linear-gradient(180deg,#ffffff,#fbfdff);
    box-shadow: -18px 8px 48px rgba(2,6,23,0.22);
    transform: translateX(100%);
    transition: transform .36s cubic-bezier(.2,.9,.3,1);
    z-index: 10080; 
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    pointer-events: auto;
    border-left: 1px solid rgba(2,6,23,0.04);
  }

  #mainNav.open { transform: translateX(0); }

  .nav-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2,6,23,0.45);
    z-index: 10070;
    opacity: 0;
    pointer-events: none;
    transition: opacity .28s ease;
  }
  .nav-backdrop.show {
    opacity: 1;
    pointer-events: auto;
  }

  body.nav-open { overflow: hidden; padding-right: 0;}
  .topbar { z-index: 10060; }

  #mainNav .nav-btn {
    display: block;
    width: 100%;
    text-align: left;
    padding: 12px 14px;
    border-radius: 10px;
    font-weight: 700;
    color: var(--secondary);
    background: transparent;
  }

  #mainNav .nav-btn:hover, #mainNav .nav-btn:focus {
    background: rgba(2,6,23,0.04);
    outline: none;
  }

}

.site-toast {
    position: fixed;
    top: 18px;
    right: 18px;
    width: min(420px, calc(100% - 36px));
    z-index: 9999;
    pointer-events: none;
}
.site-toast[hidden] { display:none; }

@media (max-width:640px) {
    .site-toast {
        top: auto;
        bottom: 18px;
        left: 50%;
        right: auto;
        transform: translateX(-50%);
        width: calc(100% - 36px);
    }
    .site-toast__inner {
        border-left-width: 4px;
    }
}

.site-toast__icon {
    width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;
    background: linear-gradient(180deg, var(--primary), rgba(232,103,2,0.9));
    color:white;font-weight:700;font-size:18px;
    flex:0 0 40px;
}

.site-toast__title{ font-weight:700; margin-bottom:2px; font-size:15px }
.site-toast__message{ font-size:13px; color:#374151; }

.site-toast__close{ margin-left:8px;background:transparent;border:0;font-size:16px;cursor:pointer;color:#6b7280;padding:6px;border-radius:8px; }

.site-toast--success .site-toast__icon{ background: linear-gradient(180deg,#16a34a,#059669); }
.site-toast--error .site-toast__icon{ background: linear-gradient(180deg,#ef4444,#dc2626); }

@keyframes toast-in {
    0% { transform: translateY(-10px) scale(.98); opacity: 0; }
    60% { transform: translateY(6px) scale(1.02); opacity: 1; }
    100% { transform: translateY(0) scale(1); opacity: 1; }
}
@keyframes toast-out {
    0% { opacity:1; transform: translateY(0); }
    100% { opacity:0; transform: translateY(-8px) scale(.98); }
}

.site-toast__inner.toast-show {
    animation: toast-in 540ms cubic-bezier(.2,.9,.3,1) both;
}
.site-toast__inner.toast-hide {
    animation: toast-out 340ms ease-in both;
}

@media (prefers-reduced-motion: reduce) {
    .site-toast__inner, .site-toast__inner.toast-show, .site-toast__inner.toast-hide { animation: none !important; transition: none !important; }
}

.topbar { position: relative; overflow: visible; }
.topbar-decor {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
    display: block;
}
.header { position: sticky; z-index: 3; }

.topbar-decor__svg {
    width: 120%;
    height: 120%;
    display: block;
    transform-origin: 0% 50%;
}

.topbar-decor__svg .blobs {
    animation: blobs-slide 28s linear infinite;
    transform-box: fill-box;
}
.topbar-decor__svg .blobs2 {
    animation: blobs-slide 42s linear infinite;
    opacity: 0.9;
    transform-box: fill-box;
}

.topbar-decor__svg .lines {
    animation: topbar-lines-slide linear infinite;
    animation-duration: 20s;
    transform-box: fill-box;
    transform-origin: 0 50%;
}

@keyframes topbar-lines-slide {
    0%   { transform: translateX(0); opacity: 0.95; }
    50%  { opacity: 1; }
    100% { transform: translateX(-50%); opacity: 0.95; }
}

@media (max-width: 640px) {
    .topbar-decor { height: 48px; opacity: 0.85; }
    .topbar-decor__svg { width: 260%; }
    @keyframes topbar-lines-slide { 0% { transform: translateX(0);} 100% { transform: translateX(-60%);} }
}

@media (prefers-reduced-motion: reduce) {
    .topbar-decor__svg .lines { animation: none; transform: translateX(-8%); }
}

.footer{margin-top:26px;background:linear-gradient(90deg,#021728 0%,#07293d 100%);color:#fff;padding:28px 0;border-top-left-radius:20px;border-top-right-radius:20px}
.footer-flex{display:flex;align-items:flex-start;gap:24px}
.footer .col{flex:1}
.footer .small{font-size:13px;color:rgba(255,255,255,0.85);margin-left: 10px;}
.footer-logo{width:220px;height:84px;object-fit:contain;border-radius:8px;margin-bottom:8px;margin-left: 8px;}
.footer-links{list-style:none;padding:0;margin:0}

footer.container.footer {
  background: linear-gradient(90deg,#021728 0%,#07293d 100%);
  color: #fff;
  padding: 36px 16px;
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
}

.footer-flex {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  align-items: start;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

.footer .col { padding: 6px 0; }
.footer .col h4 { margin: 0 0 8px 0; color: var(--primary); font-size: 16px; }
.footer .contact-line { display:flex; gap:8px; align-items:center; font-size:14px; color:rgba(255,255,255,0.9); }
.footer .contact-line svg { width:18px; height:18px; flex-shrink:0; fill: #fff; opacity:0.95; }

.footer-links li { margin-bottom:8px; }
.footer-links a { color: rgba(255,255,255,0.92); text-decoration:none; transition: opacity .18s; }
.footer-links a:hover { opacity: 0.86; transform: translateX(4px); }

.footer .social { display:flex; gap:8px; margin-top:6px; }
.footer .social a { display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:10px; background: rgba(255,255,255,0.04); color:#fff; text-decoration:none; font-weight:600; }

.footer .copyright { margin-top:18px; text-align:center; color: rgba(255,255,255,0.7); font-size:13px; grid-column: 1 / -1; }

@media (max-width:900px){
  .footer-flex { grid-template-columns: 1fr 1fr; }
}
@media (max-width:640px){
  .footer-flex { grid-template-columns: 1fr; text-align:center; gap: 14px; }
  .footer .contact-line { justify-content:center; }
  .footer .social { justify-content:center; }
}

.contacto{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

.telefono-btn {
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:8px 12px;
  border-radius:10px;
  color: #0b1220;
  background: rgba(255,255,255,0.06);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  transition: background .18s ease, transform .12s ease;
  box-shadow: 0 6px 18px rgba(2,6,23,0.06);
}

.telefono-btn:hover {
  transform: translateY(-3px);
}

.social { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

.social-btn {
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:8px 12px;
  border-radius:10px;
  color: #0b1220;
  background: rgba(255,255,255,0.06);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  transition: background .18s ease, transform .12s ease;
  box-shadow: 0 6px 18px rgba(2,6,23,0.06);
}


.social-btn svg { display:block; flex:0 0 18px; width:18px; height:18px; }

.social-btn:hover {
  transform: translateY(-3px);
}

.social-btn.facebook { background: var(--primary); color: #0284c7; }
.social-btn.facebook:hover { filter:brightness(.95); transform:none; }

@media (max-width:640px){
  .social-btn { padding:6px 10px; font-size:13px; gap:8px; }
  .social-btn svg { width:16px; height:16px; }
  .telefono-btn { padding:6px 10px; font-size:13px; gap:8px; }
}

.service-item { display:flex; gap:14px; align-items:flex-start; }
.service-item .icon {
  width:56px; height:56px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex:0 0 56px;
  background: linear-gradient(180deg, rgba(2,6,23,0.06), rgba(255,255,255,0.02));
  box-shadow: 0 6px 16px rgba(2,6,23,0.06);
  transition: transform .22s cubic-bezier(.2,.9,.3,1), box-shadow .22s ease;
}

#servicios .service-item {
  display:flex;
  gap:14px;
  align-items:center;
}

#servicios .service-item:hover .icon {
  transform: translateY(-6px) scale(1.03);
  box-shadow: 0 20px 48px rgba(2,6,23,0.14);
}

#servicios .service-item .icon {
  display:flex;
  align-items:center;
  justify-content:center;
  width:72px;
  height:72px;
  border-radius:14px;
  box-shadow: 0 12px 30px rgba(2,6,23,0.10);
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .18s ease;
  color: #ffffff;
  background: linear-gradient(180deg, var(--primary), rgba(232,103,2,0.9));
  flex: 0 0 72px;
}

@media (max-width: 640px) {
  .card-row { flex-direction: column; gap: 12px; }
  .card-row .card-media { flex: 0 0 auto; width: 100%; max-width: none; text-align:center; }
  .card-row .card-media img { width: 90px; height: 90px; margin: 0 auto; }
}

#servicios .icon-asistencia    { background: linear-gradient(180deg, var(--primary), rgba(232,103,2,0.9)); }
#servicios .icon-eventos       { background: linear-gradient(180deg, #06b6d4, #0284c7); }
#servicios .icon-capacitacion  { background: linear-gradient(180deg, #7c3aed, #6d28d9); }
#servicios .icon-revista       { background: linear-gradient(180deg, #f97316, #ef4444); }

#servicios .service-item:hover .icon {
  transform: translateY(-6px) scale(1.03);
  box-shadow: 0 20px 48px rgba(2,6,23,0.14);
}

#servicios .service-item .icon svg {
  width:36px;
  height:36px;
  display:block;
  color: #fff;
  fill: currentColor;
}

.icon-asistencia { background: linear-gradient(180deg, var(--primary), rgba(232,103,2,0.9)); }
.icon-eventos    { background: linear-gradient(180deg, #06b6d4, #0284c7); }
.icon-capacitacion{ background: linear-gradient(180deg, #7c3aed, #6d28d9); }
.icon-revista    { background: linear-gradient(180deg, #f97316, #ef4444); }

#servicios .service-item strong { display:block; margin-bottom:6px; color:var(--secondary); font-size:15px; }
#servicios .service-item .muted { font-size:14px; }

@media (max-width: 640px) {
  #servicios .service-item { gap:10px; align-items:center; }
  #servicios .service-item .icon {
    box-shadow: none;
    border: 2px solid rgba(232,103,2,0.12);
    color: var(--primary);
    width: 56px;
    height: 56px;
    border-radius: 10px;
  }
  #servicios .service-item .icon svg,
  #servicios .service-item .icon svg * {
    width: 24px;
    height: 24px;
    fill: rgb(232,103,2);
  }
}

#servicios .service-item .icon svg,
#servicios .service-item .icon svg path,
#servicios .service-item .icon svg circle,
#servicios .service-item .icon svg * {
  width: 36px;
  height: 36px;
  display: block;
  fill: rgb(255, 255, 255);
  stroke: none;
  vertical-align: middle;
}

@keyframes blobs-slide {
  0%   { transform: translateX(0%); }
  100% { transform: translateX(-40%); }
}

@media (max-width: 900px) {
  .topbar-decor__svg { width: 200%; height: 140%; }
  @keyframes blobs-slide { 0% { transform: translateX(0%);} 100% { transform: translateX(-48%);} }
}
@media (max-width: 480px) {
  .topbar-decor__svg { width: 200%; height: 160%; }
  .topbar-decor { height: 64px; }
  .topbar { background: linear-gradient(90deg, rgba(232,103,2,0.08), rgba(0,67,110,0.06)); }
}

@media (prefers-reduced-motion: reduce) {
  .topbar-decor__svg .blobs,
  .topbar-decor__svg .blobs2 { animation: none; transform: translateX(-10%); }
}

.full-width-sep {
  grid-column: 1 / -1;
  height: 14px;
  border-radius: 8px;
  margin: 8px 0 0 0;
  background: linear-gradient(90deg, rgba(232,103,2,0.12), rgba(0,67,110,0.08));
  box-shadow: 0 6px 18px rgba(2,6,23,0.06), inset 0 -2px 6px rgba(255,255,255,0.02);
}
@media (max-width: 640px){
  .full-width-sep { height: 10px; margin-top:12px; }
}

