:root{
  --brand-blue:#3CC1F6;
  --text:#1b1b1b;
  --muted:#707070;
  --brand-blue-2:#2AA7DA;
  --brand-blue-3:#1F8DBD;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Instrument Sans',system-ui,sans-serif;
  background:#fff;
  color:var(--text);
  line-height:1.6;
  font-synthesis-weight:none;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale
}
h1, h2, h3, h4, h5, h6 {
  letter-spacing: -0.02em;
}
/* Topbar modern blur */
.topbar-container{
  position:absolute;top:20px;left:0;right:0;z-index:100;
  width: 100%;
  transition: all 2.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.topbar-container--home{
  top: 40%;
  transform: translateY(-50%) scale(1.15);
}
.topbar-container--home .topbar.modern{
  max-width: 1200px;
  margin: 0 auto;
}

/* Fixed state (when scrolled) */
.topbar-container.fixed{
  position: fixed !important;
  top: 15px !important;
  left: 0;
  right: 0;
  transform: translateY(0) scale(1) !important;
  z-index: 9999 !important;
}
.topbar-container.fixed .topbar.modern{
  max-width: 1200px;
  margin: 0 auto;
  height: 70px;
  background: rgba(0, 0, 0, 0.45); /* Más oscuro pero mantiene transparencia premium */
  backdrop-filter: blur(20px) saturate(180%);
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
}
.topbar-container.fixed .logo{
  height: 32px;
}
.topbar-container.fixed .search{
  background: rgba(255,255,255,0.1) !important;
}
.topbar-container.fixed .search input{
  color: #fff;
}
.topbar-container.fixed .search input::placeholder{
  color: rgba(255,255,255,0.6);
}

.topbar.modern{
  background:rgba(255,255,255,.08);
  backdrop-filter:saturate(180%) blur(14px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:24px;
  height:80px;display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;
  box-shadow:0 15px 35px rgba(0,0,0,0.15);
  width:100%;
  transition: all 0.4s ease;
}
.topbar .logo-wrap{display:flex;align-items:center}
.topbar-right{display:flex;align-items:center;gap:32px}
.menu a{position:relative;padding:8px 0;transition:opacity .2s ease;color:#fff;text-decoration:none}
.menu a:hover{opacity:0.85}
.menu a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--brand-blue);
  transform:scaleX(0);transition:transform .3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.menu a:hover::after{transform:scaleX(1)}
/* Buttons – modern look */
.btn{
  border-radius:999px;border:1px solid transparent;
  height:46px;padding:0 28px;letter-spacing:.03em;
  font-weight:700;display:inline-flex;align-items:center;justify-content:center;
  text-decoration:none;
  transition:transform .2s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-sm{height:36px;padding:0 18px;font-size:13px}
.btn-primary{
  background:linear-gradient(180deg,var(--brand-blue) 0%,var(--brand-blue-2) 60%,var(--brand-blue-3) 100%);
  color:#fff;border-color:rgba(0,0,0,.05);
  box-shadow:0 8px 20px rgba(60,193,246,.28), inset 0 -1px 0 rgba(255,255,255,.25);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(60,193,246,.36)}
.btn-secondary{
  background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);
  box-shadow:0 6px 18px rgba(0,0,0,.1);
}
.btn-secondary:hover{transform:translateY(-3px);background:rgba(255,255,255,.25);box-shadow:0 10px 22px rgba(0,0,0,.15)}
.btn-gray{
  background:#f1f4f8;color:var(--text);border-color:#e1e5ea;
  box-shadow:0 4px 12px rgba(0,0,0,.05)
}
.btn-gray:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.08);background:#fff}
/* Search glass effect */
.search{box-shadow:0 6px 14px rgba(0,0,0,.08);backdrop-filter:blur(10px);background:rgba(255,255,255,.9)!important}
.search input::placeholder{color:#888}
/* Cards – modern look */
.card{
  position:relative;border-radius:20px;border:1px solid #e7eaee;background:#fff;
  box-shadow:0 12px 30px rgba(0,0,0,.06);overflow:hidden;
  transition:transform .3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow .3s ease;
  text-decoration:none;color:inherit;
}
.card:hover{transform:translateY(-8px);box-shadow:0 24px 48px rgba(0,0,0,.12)}
.card img{transition:transform .25s ease;display:block}
.card:hover img{transform:scale(1.02)}
.card-body{padding:18px}
.card-title{font-weight:800;font-size:1rem}
.card-desc{color:var(--muted)}
/* Project overlay soft fade */
.project-card .overlay{transition:opacity .25s ease}
.project-card:hover .overlay{opacity:1}
/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s ease}
.reveal.active{opacity:1;transform:translateY(0)}
.reveal[data-delay="100"]{transition-delay:.1s}
.reveal[data-delay="200"]{transition-delay:.2s}
.reveal[data-delay="300"]{transition-delay:.3s}
/* Subtle section separators */
section{scroll-margin-top:80px}
/* Hero variants */
.hero{background-size:cover;background-position:center;min-height:100vh;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.hero--home{background:none}
.hero-slider{position:absolute;inset:0;z-index:0}
.hero-slider .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.5s ease-in-out}
.hero-slider .slide.active{opacity:1}
.hero .container, .hero .content{position:relative;z-index:5}
.hero--secondary{min-height:420px;justify-content:flex-start}
.hero .content{position:relative;max-width:1200px;margin:0 auto;padding:0 24px;width:100%}
.hero .content-inner{margin-top:180px;max-width:640px;color:#fff}
.hero--secondary .content-inner{margin-top:140px}
.hero .content h1 {
  font-size: clamp(1.5rem, 5vw, 2.2rem);
  font-weight: 900;
  margin-bottom: 20px;
  line-height: 1.1;
  letter-spacing: -0.03em;
  opacity: 1;
  transition: opacity 0.5s ease;
}

.hero--secondary .content h1 {
  font-size: clamp(1.4rem, 4vw, 2rem);
}

.hero .content p.sub {
  font-size: clamp(0.9rem, 1.8vw, 1.15rem);
  font-weight: 400;
  opacity: 0.9;
  margin-bottom: 32px;
  max-width: 600px;
  line-height: 1.6;
  transition: opacity 0.5s ease;
}
.hero .cta{display:flex;gap:16px}
.hero .logo{filter:brightness(9);width:120px;height:40px;object-fit:contain}
.hero .menu{display:flex;gap:24px;text-transform:uppercase;font-weight:700;letter-spacing:.03em}
.hero .menu a{color:#fff;text-decoration:none}
.hero .actions{display:flex;align-items:center;gap:20px}
.hero .search{position:relative;background:rgba(255,255,255,0.9);border:1px solid rgba(255,255,255,0.2);backdrop-filter:blur(10px);border-radius:999px;padding:6px 16px;display:flex;align-items:center}
.hero .search input{border:none;outline:none;width:160px;font-size:14px;background:transparent;color:#000}
.hero .search input::placeholder{color:#666}
.hero .search-results{position:absolute;top:calc(100% + 10px);left:0;width:360px;max-width:70vw;background:rgba(255,255,255,0.98);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.65);border-radius:18px;box-shadow:0 20px 50px rgba(0,0,0,.18);padding:10px;z-index:2000}
.hero .search-results .group{padding:6px 6px 10px}
.hero .search-results .group-title{font-size:11px;letter-spacing:.08em;font-weight:900;color:#64748b;text-transform:uppercase;padding:6px 10px}
.hero .search-results a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;text-decoration:none;color:#0f172a;font-weight:700;font-size:13px}
.hero .search-results a:hover,.hero .search-results a.active{background:rgba(60,193,246,.12);color:var(--brand-blue)}
.hero .search-results .pill{margin-left:auto;font-size:10px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;background:#f1f5f9;color:#475569;padding:4px 10px;border-radius:999px}
.hero .search-results .empty{padding:14px 12px;color:#64748b;font-weight:700}
.menu a.active{font-weight:900}
.menu a.active::after{transform:scaleX(1)}

/* Submenu Styles */
.menu .has-submenu {
    position: relative;
    display: flex;
    align-items: center;
}
.menu .submenu {
    position: absolute;
    top: 100%;
    left: 0;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    min-width: 240px;
    border-radius: 16px;
    padding: 12px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    z-index: 1000;
    margin-top: 10px;
}
.menu .has-submenu:hover .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.menu .submenu a {
    color: #1a1a1a !important;
    padding: 10px 16px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    border-radius: 8px;
    transition: background 0.2s ease;
}
.menu .submenu a:hover {
    background: rgba(60, 193, 246, 0.1);
    color: var(--brand-blue) !important;
}
.menu .submenu a::after {
    display: none;
}
.topbar-container.fixed .menu a.active::after{background:var(--brand-blue)}
.hero .social{display:flex;gap:12px;color:#fff}
.hero .social svg{width:18px;height:18px;opacity:0.8;transition:opacity 0.2s ease}
.hero .social svg:hover{opacity:1}

/* Band (Home Hero bottom) */
.floating-band{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;gap:20px;z-index:10;
  width:max-content;max-width:90%;
}
.floating-band .item{
  flex:none;
  background:rgba(255,255,255,0.12);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:20px;
  padding:24px 32px;
  color:#fff;
  font-weight:700;
  font-size:15px;
  text-transform:uppercase;
  letter-spacing:.05em;
  box-shadow:0 20px 40px rgba(0,0,0,0.15);
  transition:transform .3s ease;
}
.floating-band .item:hover{transform:translateY(-5px)}
.floating-band .item:first-child{border-left:4px solid var(--brand-blue)}
.floating-band .item:nth-child(2){border-left:4px solid #C9D4DA}
.floating-band .item:nth-child(3){border-left:4px solid #A9A9A9}

@media (max-width:900px){
  .floating-band{flex-direction:column;bottom:20px;gap:10px}
  .floating-band .item{padding:12px 20px;font-size:13px}
}

/* Footer */
footer{background:linear-gradient(180deg, var(--brand-blue) 0%, var(--brand-blue-2) 100%);color:#fff;padding:100px 0 40px;position:relative;margin-top:100px}
.footer-band{max-width:1200px;margin:0 auto;padding:0 24px}
.footer-grid{display:grid;grid-template-columns:1.2fr 0.8fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-logo{filter:brightness(0) invert(1);height:45px;object-fit:contain}
.footer-title{font-weight:900;text-transform:uppercase;letter-spacing:.15em;margin-bottom:28px;color:#fff;font-size:15px;position:relative}
.footer-title::after{content:"";position:absolute;bottom:-8px;left:0;width:30px;height:2px;background:rgba(255,255,255,0.4)}
.footer-text{line-height:1.8;color:rgba(255,255,255,0.85);font-size:14px}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-links a{color:rgba(255,255,255,0.85);text-decoration:none;font-size:14px;transition:all 0.3s ease;display:inline-block}
.footer-links a:hover{color:#fff;transform:translateX(5px)}
.footer-social-wrap{display:flex;gap:16px}
.social-icon{
  width:40px;height:40px;background:rgba(255,255,255,0.1);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;transition:all 0.3s ease;border:1px solid rgba(255,255,255,0.1);
}
.social-icon:hover{background:#fff;color:var(--brand-blue);transform:translateY(-5px)}
.social-icon svg{width:20px;height:20px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:32px;font-size:13px;color:rgba(255,255,255,0.7)}
.footer-bottom-flex{display:flex;justify-content:space-between;align-items:center}
.footer-legal{display:flex;gap:24px}
.footer-legal a{color:inherit;text-decoration:none;transition:color 0.2s ease}
.footer-legal a:hover{color:#fff}

@media (max-width:1000px){ .footer-grid{grid-template-columns:1fr 1fr;gap:40px} }
@media (max-width:600px){ 
  .footer-grid{grid-template-columns:1fr} 
  .footer-bottom-flex{flex-direction:column;gap:20px;text-align:center}
}

/* Sections for Nosotros */
.video{margin:48px auto}
.video iframe{width:100%;height:500px;border-radius:16px;border:none;box-shadow:0 20px 50px rgba(0,0,0,.15)}
.cards-info{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:40px}
.card-info{
  background:#fff;padding:40px;border-radius:24px;border:1px solid #f0f3f7;
  box-shadow:0 12px 30px rgba(0,0,0,.04);
  transition:transform .3s ease;
}
.card-info:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,.08)}
.card-info h3{margin-top:0;color:var(--brand-blue);font-weight:900;font-size:1.4rem;margin-bottom:16px}
.dots{display:flex;justify-content:center;gap:12px;margin:60px 0}
.dot{width:10px;height:10px;border-radius:50%;background:#e0e4e9}
.cultura{margin-bottom:56px}
.cultura-title{font-size:32px;font-weight:900;text-align:center;margin-bottom:32px}
.cultura-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.cultura-grid img{width:100%;border-radius:16px;box-shadow:0 15px 35px rgba(0,0,0,.1)}
.cultura-list{list-style:none;padding:0;margin:0}
.cultura-list li{position:relative;padding-left:28px;margin-bottom:18px;line-height:1.6}
.cultura-list li::before{content:"✓";position:absolute;left:0;color:var(--brand-blue);font-weight:900}
.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.project-card{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3}
.project-card img{width:100%;height:100%;object-fit:cover}
.project-card .overlay{position:absolute;inset:0;background:rgba(60,193,246,.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.project-card:hover .overlay{opacity:1}
.btn-overlay{background:#fff;color:var(--brand-blue);padding:10px 20px;border-radius:999px;text-decoration:none;font-weight:800;font-size:14px}

/* Detail page */
.detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:48px;padding-bottom:48px}
.gallery .main-img{width:100%;border-radius:16px;box-shadow:0 15px 40px rgba(0,0,0,.1)}
.thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
.thumbs img{width:100%;border-radius:8px;cursor:pointer;transition:opacity .2s ease}
.thumbs img:hover{opacity:.7}
.info h1{font-size:40px;margin-top:0;margin-bottom:16px}
.info .price{font-size:32px;font-weight:800;color:var(--brand-blue);margin-bottom:24px}
.info .desc{line-height:1.8;color:var(--muted);margin-bottom:32px}
.actions-row{display:flex;gap:16px}
.btn-outline{border:2px solid var(--brand-blue);color:var(--brand-blue);background:transparent}
.btn-outline:hover{background:var(--brand-blue);color:#fff}
.price-sm{font-weight:800;color:var(--brand-blue);margin-top:4px}
.card-name{font-weight:800;margin-top:12px}

@media (max-width:900px){
  .hero h1{font-size:36px}
  .hero .topbar .container{flex-direction:row;justify-content:space-between}
  .hero .menu{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cards-info{grid-template-columns:1fr}
  .cultura-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr 1fr}
  .detail{grid-template-columns:1fr}
}
/* Generic layout helpers */
.container{width:1200px;max-width:100%;margin:0 auto}
.section-title{
  text-align:center;letter-spacing:.15em;color:#1a1a1a;
  font-weight:900;text-transform:uppercase;margin:60px 0 40px;font-size:32px;
  position:relative;
}
.section-title::after{
  content:"";position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);
  width:60px;height:4px;background:var(--brand-blue);border-radius:2px;
}

/* Common sections */
.intro{display:grid;grid-template-columns:1.1fr 0.9fr;gap:80px;padding:100px 24px;align-items:center;position:relative}
.intro::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:100%;
  background:radial-gradient(circle at 10% 20%, rgba(60,193,246,0.03) 0%, transparent 50%);
  pointer-events:none;
}
.intro-content{position:relative;z-index:2}
.intro-content .tag{
  display:inline-block;background:rgba(60,193,246,0.1);color:var(--brand-blue);
  padding:8px 20px;border-radius:999px;font-weight:800;font-size:13px;
  text-transform:uppercase;letter-spacing:0.15em;margin-bottom:32px;
  box-shadow:0 4px 12px rgba(60,193,246,0.1);
}
.intro p{
  font-size:24px;line-height:1.6;margin:0;color:#1a1a1a;font-weight:600;
  letter-spacing:-0.02em;
}
.intro p span{
  color:var(--brand-blue);font-weight:900;
  position:relative;display:inline-block;
}
.intro p span::after{
  content:"";position:absolute;bottom:4px;left:0;width:100%;height:8px;
  background:rgba(60,193,246,0.1);z-index:-1;
}
.form{
  background:#fff;padding:48px;border-radius:40px;
  box-shadow:0 40px 80px rgba(0,0,0,0.1);
  border:1px solid #f0f3f7;
  position:relative;z-index:2;
  transition:all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.form:hover{transform:translateY(-10px);box-shadow:0 50px 100px rgba(0,0,0,0.15)}
.form label{display:block;font-size:14px;margin-bottom:10px;color:#333;font-weight:700}
.form input[type="text"],.form input[type="email"],.form input[type="tel"]{
  width:100%;height:48px;border:1px solid #eef1f5;border-radius:12px;padding:0 16px;margin-bottom:16px;
  background:#f9fafb;transition:all .2s ease;
}
.form input:focus{outline:none;border-color:var(--brand-blue);background:#fff;box-shadow:0 0 0 4px rgba(60,193,246,.1)}
.form .chk{display:flex;align-items:center;gap:10px;font-size:13px;color:#666;margin:12px 0 20px}
.form button{
  height:48px;background:var(--brand-blue);color:#fff;border:none;border-radius:999px;
  font-weight:800;width:100%;cursor:pointer;transition:transform .2s ease, box-shadow .2s ease;
  box-shadow:0 8px 20px rgba(60,193,246,.25);
}
.form button:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(60,193,246,.35)}

/* Dynamic Services Section */
.services-dynamic {
  position: relative;
  padding: 80px 0;
}
.services-dynamic::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 6px;
  background: #f1f4f8;
  transform: translateX(-50%);
  z-index: 1;
  border-radius: 10px;
}
.services-dynamic::after {
  content: "";
  position: absolute;
  top: 100px;
  bottom: 100px;
  left: 50%;
  width: 6px;
  background: linear-gradient(180deg, var(--brand-blue) 0%, var(--brand-blue-2) 100%);
  transform: translateX(-50%);
  z-index: 2;
  border-radius: 10px;
  box-shadow: 0 0 20px rgba(60, 193, 246, 0.3);
}

.service-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 100px;
  padding: 80px 0;
  align-items: center;
  position: relative;
  z-index: 3;
}
.service-block img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: 32px;
  box-shadow: 0 25px 50px rgba(0,0,0,0.12);
  transition: transform .4s ease;
}
.service-block:hover img {
  transform: translateY(-10px);
}
.service-block .content-wrap {
  padding: 20px;
}
.service-block h3 {
  font-size: 32px;
  margin-bottom: 20px;
  color: #1a1a1a;
  font-weight: 900;
  letter-spacing: -0.02em;
}
.service-block p {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 28px;
}
.service-block .benefits-label {
  display: block;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.12em;
  color: var(--brand-blue);
  margin-bottom: 20px;
}
.service-block ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.service-block li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 14px;
  font-size: 16px;
  color: #444;
}
.service-block li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--brand-blue);
  font-weight: 900;
  font-size: 16px;
  line-height: 1.2;
}

/* Alternating layout */
.service-block:nth-child(even) {
  direction: rtl;
}
.service-block:nth-child(even) > * {
  direction: ltr;
}

@media (max-width: 900px) {
  .services-dynamic::before, .services-dynamic::after { 
    left: 24px;
    transform: none;
    display: block;
  }
  .services-dynamic::after {
    top: 50px;
    bottom: 50px;
  }
  .service-block {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 40px 24px 40px 60px;
    direction: ltr!important;
    text-align: left;
  }
  .service-block:nth-child(even) { direction: ltr; }
  .service-block:nth-child(even) > * { direction: ltr; }
  .service-block img { height: 280px; border-radius: 20px; }
  .service-block h3 { font-size: 24px; }
}

.enfoque{
  background:linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
  border-radius:40px;margin:80px auto;padding:60px;
  border:1px solid #eef1f5;text-align:center;max-width:1000px;
  box-shadow:0 30px 60px rgba(0,0,0,0.05);
  position:relative;overflow:hidden;
}
.enfoque::before{
  content:"\"";position:absolute;top:-20px;left:40px;font-size:160px;
  color:rgba(60,193,246,0.08);font-family:serif;font-weight:900;
}
.enfoque strong{font-size:24px;color:var(--brand-blue);display:block;margin-bottom:24px;text-transform:uppercase;letter-spacing:0.1em}
.enfoque p{font-size:18px;line-height:1.8;color:#444;max-width:800px;margin:0 auto 32px}
.enfoque a{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--brand-blue);color:#fff;text-decoration:none;
  font-weight:800;padding:16px 32px;border-radius:999px;
  box-shadow:0 10px 25px rgba(60,193,246,0.3);
  transition:all 0.3s ease;
}
.enfoque a:hover{transform:translateY(-3px);box-shadow:0 15px 35px rgba(60,193,246,0.4);background:var(--brand-blue-2)}

.reasons{padding:80px 48px;background:#f9fafb;border-radius:40px;margin:80px auto;max-width:1200px;box-shadow:0 20px 50px rgba(0,0,0,0.02)}
.grid-reasons{display:grid;grid-template-columns:repeat(3, 1fr);gap:32px}
.reason{
  background:#fff;border:1px solid #f0f3f7;border-radius:24px;padding:32px;
  box-shadow:0 10px 30px rgba(0,0,0,0.03);
  transition:all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  display:flex;flex-direction:column;align-items:flex-start;gap:20px;
  text-align:left;
}
.reason:hover{transform:translateY(-10px);box-shadow:0 25px 50px rgba(0,0,0,0.08);border-color:var(--brand-blue)}
.reason .icon-wrap{
  width:50px;height:50px;background:rgba(60,193,246,0.1);
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  color:var(--brand-blue);font-size:20px;font-weight:900;
}
.reason-text{font-size:16px;line-height:1.6;color:#333;font-weight:600}

@media (max-width:1000px){ .grid-reasons{grid-template-columns:repeat(2, 1fr)} }
@media (max-width:700px){ .grid-reasons{grid-template-columns:1fr} .enfoque{padding:40px 24px} .reasons{padding:40px 24px; border-radius:24px} }

.services-cards{padding:80px 24px}
.cards{display:grid;grid-template-columns:repeat(3, 1fr);gap:40px}

@media (max-width:1100px){ .cards{grid-template-columns:repeat(2, 1fr)} }
@media (max-width:750px){ .cards{grid-template-columns:1fr} }

/* Home specific improvements */
.products-band{background:linear-gradient(180deg, #f4f7f9 0%, #ffffff 100%); padding: 100px 24px}
.product-list{display:grid;grid-template-columns:repeat(5, 1fr);gap:24px;margin-top:50px}
.product{
  width:100%;background:#fff;border-radius:24px;overflow:hidden;
  text-align:center;box-shadow:0 15px 35px rgba(0,0,0,.06);border:1px solid #f0f3f7;
  transition:all .4s cubic-bezier(0.34, 1.56, 0.64, 1);position:relative;
}
.product:hover{transform:translateY(-12px);box-shadow:0 30px 60px rgba(0,0,0,0.12);border-color:var(--brand-blue)}
.product img{width:100%;height:180px;object-fit:cover;transition:transform .6s ease}
.product:hover img{transform:scale(1.1)}
.product-name{padding:20px 15px 8px;font-weight:800;font-size:14px;color:#1a1a1a;letter-spacing:-0.01em;min-height:64px;display:flex;align-items:center;justify-content:center}
.product-price{padding:0 15px 24px;font-weight:900;color:var(--brand-blue);font-size:20px}

.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
.project-card{border-radius:24px;overflow:hidden;box-shadow:0 15px 35px rgba(0,0,0,0.08)}

.projects-cta{
  margin-top:60px;background:linear-gradient(135deg, #2c3e50 0%, #000000 100%);
  color:#fff;border-radius:24px;padding:48px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 25px 55px rgba(0,0,0,0.2);position:relative;overflow:hidden;
}
.projects-cta::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:100%;
  background:url('https://www.transparenttextures.com/patterns/carbon-fibre.png');opacity:0.1;
}
.projects-cta div{font-size:22px;font-weight:700;position:relative;z-index:2;max-width:600px;line-height:1.4}
.projects-cta .btn{position:relative;z-index:2;height:54px;padding:0 40px;font-size:16px}

.company-grid{display:grid;grid-template-columns:1.2fr 0.8fr;gap:60px;align-items:center;margin-bottom:100px}
.company-media iframe{width:100%;height:420px;border:0;border-radius:32px;box-shadow:0 30px 70px rgba(0,0,0,0.15)}
.company-item{
  display:flex;gap:20px;align-items:center;background:#fff;
  border:1px solid #f0f3f7;border-radius:20px;padding:24px;
  transition:all .3s ease;box-shadow:0 10px 25px rgba(0,0,0,0.02);
}
.company-item:hover{transform:translateX(10px);border-color:var(--brand-blue);box-shadow:0 15px 35px rgba(0,0,0,0.06)}
.company-item img{width:90px;height:90px;object-fit:cover;border-radius:16px}
.company-item .title{font-weight:900;font-size:18px;margin-bottom:6px;color:#1a1a1a}
.company-item .desc{color:var(--muted);font-size:14px;line-height:1.5}

.logos-row{display:flex;gap:60px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:32px}
.logos-row img{height:120px;max-width:280px;object-fit:contain;filter:grayscale(100%);opacity:.5;transition:all .4s ease}
.logos-row img:hover{filter:grayscale(0);opacity:1;transform:scale(1.05)}

/* Logo Slider Animation */
.logo-slider {
    overflow: hidden;
    padding: 40px 0;
    position: relative;
    width: 100%;
}
.logo-slider::before, .logo-slider::after {
    content: "";
    height: 100%;
    position: absolute;
    width: 150px;
    z-index: 2;
}
.logo-slider::before {
    background: linear-gradient(to right, white 0%, rgba(255, 255, 255, 0) 100%);
    left: 0;
    top: 0;
}
.logo-slider::after {
    background: linear-gradient(to left, white 0%, rgba(255, 255, 255, 0) 100%);
    right: 0;
    top: 0;
}
.logo-track {
    display: flex;
    width: calc(350px * 20); /* Increased base width for larger logos */
    animation: scroll 80s linear infinite;
    gap: 120px;
    align-items: center;
}
.logo-track:hover {
    animation-play-state: paused;
}
@keyframes scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-350px * 10)); }
}
.logo-track img {
    height: 120px;
    max-width: 280px;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.5;
    transition: all 0.3s ease;
}
.logo-track img:hover {
    filter: grayscale(0);
    opacity: 1;
}

@media (max-width:1100px){
  .product-list{grid-template-columns:repeat(3, 1fr)}
  .projects-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:900px){
  .projects-cta{flex-direction:column;text-align:center;gap:30px;padding:40px 24px}
  .company-grid{grid-template-columns:1fr}
  .product-list{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:600px){
  .product-list{grid-template-columns:1fr}
}
/* Product cards modern */
.prod-card{
  position:relative;display:block;border-radius:24px;border:1px solid #eef1f5;background:#fff;overflow:hidden;
  box-shadow:0 12px 34px rgba(0,0,0,.07);transition:transform .4s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow .4s ease;
  text-decoration:none;color:inherit;
}
.prod-card:hover{transform:translateY(-10px);box-shadow:0 28px 60px rgba(0,0,0,.12);border-color:#e1e5ea}
.prod-card .figure{position:relative;height:210px;overflow:hidden}
.prod-card .figure img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.prod-card:hover .figure img{transform:scale(1.06)}
.prod-card .badge{
  position:absolute;top:16px;right:16px;background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-2) 100%);
  color:#fff;border-radius:999px;padding:6px 14px;font-weight:700;font-size:12px;
  box-shadow:0 8px 16px rgba(60,193,246,0.4);z-index:2;
}
.prod-card .body{padding:20px 24px}
.prod-card .name{font-weight:800;font-size:1.1rem;margin:0 0 8px;letter-spacing:-0.01em;color:#1a1a1a}
.prod-card .stars{color:#ffb400;letter-spacing:.15em;font-size:12px;margin-bottom:12px}
.prod-card .actions{display:flex;justify-content:flex-end;padding:0 24px 24px}
.prod-card .card-desc{font-size:14px;color:var(--muted);line-height:1.5;margin-bottom:16px}
.btn-icon{width:18px;height:18px;margin-right:8px;vertical-align:middle}
