/* =====================================================
   Alianzared — Estilos principales
   Diseño replicado del sitio original
   ===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@400;500;600;700;800&family=Poppins:wght@300;400;500;600&family=Montserrat:wght@300;400;500;600;700&display=swap');

:root {
  /* Paleta exacta del sitio original (Elementor Global Kit #26154) */
  --primary:     #3E82F7;   /* azul principal */
  --primary-dk:  #0015BD;   /* azul oscuro hover nav */
  --secondary:   #54595F;
  --text-color:  #7A7A7A;
  --dark-navy:   #001c38;
  --dark-blue:   #1F365C;
  --orange:      #F39200;
  --green:       #61CE70;   /* hover CTA */
  --nav-text:    #5B5B5B;
  --bg:          #F8FAFC;
  --bg-card:     #FFFFFF;
  --text:        #1a202c;
  --text-muted:  #7A7A7A;
  --border:      #e2e8f0;
  --radius:      6px;
  --radius-lg:   14px;
  --shadow:      0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:   0 8px 32px rgba(0,0,0,.12);
  --nav-shadow:  0 5px 30px rgba(0,0,0,.1);
  --topbar-h:    36px;
  --nav-h:       70px;
  --header-h:    106px;
  --transition:  .22s ease;

  /* Alias para compatibilidad */
  --blue-dark:   var(--dark-navy);
  --blue:        var(--primary);
  --blue-mid:    var(--primary);
  --blue-light:  #4A8FD9;
  --accent:      var(--orange);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Poppins',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--primary-dk)}
ul,ol{list-style:none}

h1,h2,h3,h4,h5{font-family:'Lexend',sans-serif;font-weight:600}
h1{font-size:clamp(2rem,5vw,3.25rem);line-height:1.15}
h2{font-size:clamp(1.6rem,3vw,2.25rem);line-height:1.25}
h3{font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.3}
h4{font-size:1.1rem}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}

/* ---- LAYOUT ---- */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section--gray{background:#EEF2F7}

/* =====================================================
   TOPBAR — barra azul superior con contacto y redes
   ===================================================== */
.topbar{
  background:var(--primary);
  height:var(--topbar-h);
  position:fixed;top:0;left:0;right:0;
  z-index:1001;
  display:flex;align-items:center;
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem;
}
.topbar__left,.topbar__right{
  display:flex;align-items:center;gap:1.25rem;
}
.topbar__item{
  display:flex;align-items:center;gap:.4rem;
  color:#fff;font-family:'Montserrat',sans-serif;
  font-size:.78rem;font-weight:300;white-space:nowrap;
}
.topbar__item svg{width:13px;height:13px;flex-shrink:0;fill:#fff}
.topbar__item a{color:#fff}
.topbar__item a:hover{color:rgba(255,255,255,.75)}
.topbar__social{display:flex;align-items:center;gap:.65rem}
.topbar__social a{
  width:24px;height:24px;border-radius:50%;
  background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition);
}
.topbar__social a:hover{background:rgba(255,255,255,.35)}
.topbar__social svg{width:12px;height:12px;fill:#fff}

/* =====================================================
   NAVBAR — barra blanca principal con logo y menú
   ===================================================== */
.navbar{
  position:fixed;
  top:var(--topbar-h);
  left:0;right:0;
  height:var(--nav-h);
  background:#fff;
  z-index:1000;
  box-shadow:var(--nav-shadow);
  transition:box-shadow var(--transition);
}
.navbar.scrolled{box-shadow:0 5px 30px rgba(0,0,0,.18)}
.navbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem;
}
/* Logo — imagen real sobre fondo blanco (sin filtro) */
.navbar__logo{display:flex;align-items:center}
.navbar__logo-img{
  height:46px;width:auto;display:block;
  /* Sin filter — logo azul se ve perfecto sobre blanco */
}
/* Links */
.navbar__links{display:flex;align-items:center;gap:.15rem}
.navbar__links a{
  color:var(--nav-text);
  padding:.5rem .85rem;
  border-radius:var(--radius);
  font-family:'Montserrat',sans-serif;
  font-size:.9rem;font-weight:600;
  text-transform:capitalize;
  transition:color var(--transition);
}
.navbar__links a:hover,.navbar__links a.active{
  color:var(--primary);
}
/* CTA button en nav */
.navbar__cta{
  background:var(--primary)!important;
  color:#fff!important;
  padding:.5rem 1.2rem!important;
  border-radius:4px!important;
  box-shadow:0 0 10px rgba(0,0,0,.2);
  font-family:'Montserrat',sans-serif!important;
  font-size:.85rem!important;
}
.navbar__cta:hover{
  background:var(--green)!important;
  color:#fff!important;
}
.navbar__toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem}
.navbar__toggle span{display:block;width:24px;height:2px;background:var(--nav-text);border-radius:2px;transition:all var(--transition)}

/* ---- DROPDOWN NAV ---- */
.nav-item{position:relative}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown{
  position:absolute;top:calc(100% + 15px);left:0;
  background:#fff;border-radius:var(--radius);
  box-shadow:0 15px 20px rgba(0,0,0,.1);
  min-width:240px;padding:.4rem 0;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all var(--transition);z-index:200;
  border:1px solid var(--border);
}
.dropdown a{
  display:block;padding:.75rem 2rem;
  color:var(--secondary)!important;
  font-family:'Montserrat',sans-serif!important;
  font-size:.875rem;font-weight:400;
  background:transparent!important;border-radius:0;
  transition:color var(--transition);
}
.dropdown a:hover{color:var(--primary)!important}
.nav-arrow{display:inline-block;margin-left:.3rem;font-size:.7rem;transition:transform var(--transition)}
.nav-item:hover .nav-arrow{transform:rotate(180deg)}

/* =====================================================
   HERO
   ===================================================== */
.hero{
  background:var(--dark-navy);color:#fff;
  padding-top:var(--header-h);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 60%,rgba(62,130,247,.2) 0%,transparent 60%),
             radial-gradient(ellipse at 80% 20%,rgba(21,72,190,.25) 0%,transparent 50%);
}
.hero__top{padding:4.5rem 0 3rem;position:relative;z-index:1}
.hero__badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(62,130,247,.18);border:1px solid rgba(62,130,247,.4);
  color:#7fb3fb;padding:.35rem .9rem;border-radius:100px;
  font-size:.8rem;font-weight:600;font-family:'Montserrat',sans-serif;
  margin-bottom:1.5rem;letter-spacing:.05em;text-transform:uppercase;
}
.hero__title{margin-bottom:1.25rem;letter-spacing:-.03em;max-width:700px}
.hero__title span{color:#7fb3fb}
.hero__subtitle{color:rgba(255,255,255,.72);font-size:1.1rem;margin-bottom:2.25rem;max-width:560px}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}
.hero__visual{position:relative}
.hero__img{border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(0,0,0,.45);width:100%}
.hero__float{
  position:absolute;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:.75rem 1.1rem;
  display:flex;align-items:center;gap:.6rem;
  font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;
  font-family:'Montserrat',sans-serif;
}
.hero__float--1{bottom:2rem;left:-1.5rem}
.hero__float--2{top:2rem;right:-1rem}
.hero__float .dot{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0}

/* 3 service cards at bottom of hero */
.hero__cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.1);margin-top:3rem;
}
.hero__card{
  padding:2rem 1.75rem;border-right:1px solid rgba(255,255,255,.1);
  cursor:pointer;transition:background var(--transition);
}
.hero__card:last-child{border-right:none}
.hero__card:hover{background:rgba(255,255,255,.06)}
.hero__card--active{background:rgba(62,130,247,.15);border-bottom:3px solid var(--primary)}
.hero__card__icon{
  width:46px;height:46px;background:rgba(62,130,247,.2);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;margin-bottom:1rem;
}
.hero__card__icon svg{width:22px;height:22px;color:#7fb3fb}
.hero__card__title{font-size:1rem;font-weight:700;margin-bottom:.4rem;color:#fff;font-family:'Lexend',sans-serif}
.hero__card__desc{font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.55}
.hero__card__link{
  display:inline-flex;align-items:center;gap:.3rem;margin-top:.75rem;
  font-size:.8rem;font-weight:600;color:#7fb3fb;font-family:'Montserrat',sans-serif;
}
.hero__card__link:hover{color:#fff}

/* ---- BUTTONS ---- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.75rem;border-radius:4px;
  font-weight:600;font-size:.95rem;font-family:'Montserrat',sans-serif;
  cursor:pointer;border:2px solid transparent;
  transition:all var(--transition);line-height:1;
}
.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn--primary:hover{background:var(--green);color:#fff;border-color:var(--green);transform:translateY(-1px);box-shadow:0 6px 20px rgba(62,130,247,.35)}
.btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--outline:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff}
.btn--accent{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn--accent:hover{filter:brightness(1.1);color:#fff;transform:translateY(-1px)}
.btn--sm{padding:.5rem 1.1rem;font-size:.85rem}
.btn--lg{padding:1rem 2.2rem;font-size:1.05rem}
.btn--full{width:100%;justify-content:center}

/* ---- SECTION TITLE ---- */
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header__tag{
  display:inline-block;background:rgba(62,130,247,.1);
  color:var(--primary);padding:.3rem .9rem;border-radius:100px;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;margin-bottom:.75rem;
  font-family:'Montserrat',sans-serif;
}
.section-header__title{margin-bottom:.75rem;color:var(--dark-blue)}
.section-header__desc{color:var(--text-muted);max-width:560px;margin:0 auto;font-size:1.05rem}

/* ---- SERVICES ---- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.service-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;
  transition:all var(--transition);position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),#7fb3fb);
  transform:scaleX(0);transform-origin:left;transition:transform var(--transition);
}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--primary)}
.service-card:hover::before{transform:scaleX(1)}
.service-card__icon{
  width:56px;height:56px;background:rgba(62,130,247,.1);
  border-radius:var(--radius);display:flex;align-items:center;
  justify-content:center;margin-bottom:1.25rem;
}
.service-card__icon svg{width:28px;height:28px;color:var(--primary)}
.service-card__title{margin-bottom:.6rem;font-size:1.1rem;color:var(--dark-blue)}
.service-card__desc{color:var(--text-muted);font-size:.9rem;margin:0}

/* ---- STATS ---- */
.stats-section{background:var(--dark-navy);color:#fff;padding:4rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;text-align:center}
.stat__number{font-size:2.75rem;font-weight:800;color:var(--primary);line-height:1;font-family:'Lexend',sans-serif}
.stat__label{font-size:.9rem;color:rgba(255,255,255,.7);margin-top:.4rem;font-family:'Poppins',sans-serif}

/* ---- BLOG CARDS ---- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.blog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.blog-card__img{height:200px;object-fit:cover;width:100%;background:#dde3ed}
.blog-card__body{padding:1.5rem}
.blog-card__category{font-size:.75rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-family:'Montserrat',sans-serif}
.blog-card__title{font-size:1.05rem;font-weight:700;margin-bottom:.5rem;color:var(--dark-blue)}
.blog-card__title a{color:inherit}
.blog-card__title a:hover{color:var(--primary)}
.blog-card__excerpt{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card__meta{display:flex;align-items:center;gap:.75rem;font-size:.78rem;color:var(--text-muted)}
.blog-card__meta svg{width:14px;height:14px}

/* ---- PAGINATION ---- */
.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:3rem}
.pagination button{
  width:40px;height:40px;border-radius:var(--radius);
  border:1px solid var(--border);background:#fff;
  cursor:pointer;font-size:.9rem;font-weight:600;
  color:var(--text);transition:all var(--transition);
}
.pagination button:hover,.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination button:disabled{opacity:.4;cursor:default}

/* ---- ARTICLE ---- */
.article-hero{background:var(--dark-navy);color:#fff;padding:calc(var(--header-h) + 3rem) 0 3rem}
.article-hero__category{color:#7fb3fb;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem;font-family:'Montserrat',sans-serif}
.article-hero__title{margin-bottom:1rem}
.article-hero__meta{display:flex;gap:1.5rem;flex-wrap:wrap;color:rgba(255,255,255,.65);font-size:.875rem}
.article-featured{width:100%;max-height:480px;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:2.5rem;box-shadow:var(--shadow)}
.article-content{max-width:780px;margin:0 auto}
.article-content h2{font-size:1.6rem;margin:2rem 0 .75rem;color:var(--dark-blue)}
.article-content h3{font-size:1.25rem;margin:1.5rem 0 .5rem;color:var(--dark-blue)}
.article-content p{font-size:1.0625rem;line-height:1.75;margin-bottom:1.25rem}
.article-content ul,.article-content ol{padding-left:1.5rem;margin-bottom:1.25rem}
.article-content ul{list-style:disc}
.article-content ol{list-style:decimal}
.article-content li{margin-bottom:.4rem}
.article-content img{border-radius:var(--radius);margin:1.5rem 0;width:100%}
.article-content blockquote{border-left:4px solid var(--primary);padding:1rem 1.5rem;margin:1.5rem 0;background:rgba(62,130,247,.06);border-radius:0 var(--radius) var(--radius) 0;font-style:italic}
.article-content code{background:#f1f5f9;padding:.15em .4em;border-radius:4px;font-size:.875em;font-family:'Consolas','Fira Code',monospace}
.article-content pre{background:#1e293b;color:#e2e8f0;padding:1.5rem;border-radius:var(--radius);overflow-x:auto;margin-bottom:1.25rem}
.article-content pre code{background:none;padding:0;color:inherit}

/* ---- CONTACT ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}
.contact-info__item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.75rem}
.contact-info__icon{width:44px;height:44px;background:rgba(62,130,247,.1);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-info__icon svg{width:20px;height:20px;color:var(--primary)}
.contact-info__label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;font-family:'Montserrat',sans-serif}
.contact-info__value{font-weight:500}

/* ---- FORMS ---- */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.4rem;color:var(--text)}
.form-control{
  width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);
  border-radius:var(--radius);font-size:.95rem;background:#fff;
  color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);
  font-family:'Poppins',sans-serif;
}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(62,130,247,.12)}
textarea.form-control{resize:vertical;min-height:140px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-msg{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;margin-top:1rem;display:none}
.form-msg.success{background:#dcfce7;color:#166534;display:block}
.form-msg.error{background:#fee2e2;color:#991b1b;display:block}

/* ---- TESTIMONIOS ---- */
.testimonials-section{background:var(--dark-navy);color:#fff;padding:5rem 0}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}
.testimonial-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:2rem;transition:background var(--transition)}
.testimonial-card:hover{background:rgba(255,255,255,.11)}
.testimonial-stars{color:#FBBF24;font-size:1rem;margin-bottom:1rem;letter-spacing:2px}
.testimonial-text{font-size:.9rem;line-height:1.75;color:rgba(255,255,255,.82);margin-bottom:1.5rem;font-style:italic}
.testimonial-text::before{content:'"';font-size:2rem;color:#7fb3fb;line-height:0;vertical-align:-.5em;margin-right:.2rem}
.testimonial-author{display:flex;align-items:center;gap:.85rem}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7fb3fb);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}
.testimonial-name{font-weight:700;font-size:.9rem;font-family:'Lexend',sans-serif}
.testimonial-role{font-size:.78rem;color:rgba(255,255,255,.55)}

/* ---- AGENCIA / ABOUT ---- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-features{display:flex;flex-direction:column;gap:1.25rem;margin:1.75rem 0}
.about-feature{display:flex;gap:1rem;align-items:flex-start}
.about-feature__icon{width:40px;height:40px;background:rgba(62,130,247,.1);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.about-feature__icon svg{width:18px;height:18px;color:var(--primary)}
.about-feature__title{font-weight:700;font-size:.9rem;margin-bottom:.2rem;font-family:'Montserrat',sans-serif}
.about-feature__desc{font-size:.82rem;color:var(--text-muted)}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.team-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center}
.team-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--dark-navy),var(--primary));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;margin:0 auto .75rem;text-transform:uppercase;font-family:'Lexend',sans-serif}
.team-name{font-weight:700;margin-bottom:.2rem;font-family:'Lexend',sans-serif}
.team-role{font-size:.8rem;color:var(--text-muted);font-family:'Poppins',sans-serif}

/* ---- BENEFICIOS ---- */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}
.benefit-item{display:flex;gap:.85rem;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}
.benefit-num{width:32px;height:32px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:800;color:#fff;flex-shrink:0;font-family:'Montserrat',sans-serif}
.benefit-text{font-size:.875rem;font-weight:600}

/* ---- WA FLOAT BUTTON ---- */
.wa-btn{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45);transition:transform var(--transition),box-shadow var(--transition)}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.6)}
.wa-btn svg{width:28px;height:28px}

/* ---- FOOTER ---- */
.footer{background:var(--dark-navy);color:rgba(255,255,255,.75);padding:4rem 0 2rem}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:3rem}
.footer__brand{color:#fff;font-size:1.2rem;font-weight:800;margin-bottom:.75rem;display:flex;align-items:center;gap:.6rem;font-family:'Lexend',sans-serif}
.footer__logo-img{height:38px;width:auto;filter:brightness(0) invert(1);display:block}
.footer__desc{font-size:.875rem;line-height:1.7;max-width:280px}
.footer__title{color:#fff;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:1.25rem;font-family:'Montserrat',sans-serif}
.footer__links{display:flex;flex-direction:column;gap:.5rem}
.footer__links a{color:rgba(255,255,255,.65);font-size:.875rem;transition:color var(--transition)}
.footer__links a:hover{color:#fff}
.footer__social{display:flex;gap:.75rem;margin-top:1rem}
.footer__social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background var(--transition)}
.footer__social a:hover{background:var(--primary)}
.footer__social svg{width:16px;height:16px;color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem}
.footer__bottom a{color:rgba(255,255,255,.5)}
.footer__bottom a:hover{color:#fff}

/* ---- BREADCRUMB ---- */
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:rgba(255,255,255,.55);margin-bottom:1rem}
.breadcrumb a{color:rgba(255,255,255,.65)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.4)}

/* ---- UTILS ---- */
.text-center{text-align:center}
.text-blue{color:var(--primary)}
.text-muted{color:var(--text-muted)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.gap-1{gap:.5rem}.gap-2{gap:1rem}
.flex{display:flex}.flex-center{align-items:center}.flex-wrap{flex-wrap:wrap}
.d-none{display:none}
.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f8fafc 50%,#e2e8f0 75%);background-size:200% 100%;animation:skeleton 1.5s infinite;border-radius:var(--radius)}
@keyframes skeleton{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---- PAGE HERO (páginas internas) ---- */
.page-hero{background:var(--dark-navy);color:#fff;padding:calc(var(--header-h) + 3rem) 0 3.5rem;text-align:center}
.page-hero__subtitle{color:rgba(255,255,255,.7);font-size:1.05rem;max-width:600px;margin:.75rem auto 0}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__subtitle{margin-inline:auto}
  .hero__actions{justify-content:center}
  .hero__visual{display:none}
  .contact-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .topbar__item:nth-child(3){display:none}
}
@media(max-width:768px){
  :root{--topbar-h:0px;--header-h:var(--nav-h)}
  .topbar{display:none}
  .navbar{top:0}
  .navbar__links{
    display:none;position:fixed;
    top:var(--nav-h);left:0;right:0;
    background:#fff;flex-direction:column;
    padding:1rem 1.5rem 1.5rem;gap:.25rem;
    box-shadow:0 8px 30px rgba(0,0,0,.15);
    border-top:1px solid var(--border);
  }
  .navbar__links.open{display:flex}
  .navbar__links a{color:var(--nav-text)!important}
  .navbar__toggle{display:flex}
  .navbar__toggle span{background:var(--nav-text)}
  .dropdown{position:static;visibility:visible;opacity:1;transform:none;box-shadow:none;background:rgba(62,130,247,.05);border:none;border-radius:var(--radius);margin:.25rem 0;padding:.25rem 0}
  .dropdown a{color:var(--nav-text)!important;font-size:.82rem;padding:.5rem 1.5rem}
  .dropdown a:hover{color:var(--primary)!important}
  .hero__cards{grid-template-columns:1fr}
  .hero__card{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .hero__card:last-child{border-bottom:none}
  .section{padding:3.5rem 0}
  .form-row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer__bottom{flex-direction:column;text-align:center}
  .team-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  h1{font-size:1.85rem}
  .btn--lg{padding:.875rem 1.5rem}
  .services-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:1fr}
}
