/* =============================================
   IDT INGENIERÍA — Global Stylesheet (Multi-Page)
   Color Principal: #482800 (Marrón Nogal)
   Tipografía: Outfit (títulos) + Inter (cuerpo)
   ============================================= */

/* ---- CSS Custom Properties ---- */
:root {
  --color-primary: #482800;
  --color-primary-light: #5c3810;
  --color-primary-dark: #3a2000;
  --color-primary-rgb: 72, 40, 0;
  --color-accent: #6b3d0a;
  --color-white: #ffffff;
  --color-bg: #ffffff;
  --color-bg-alt: #f9f9f9;
  --color-bg-dark: #f3f0ec;
  --color-text: #1a1a1a;
  --color-text-light: #555555;
  --color-text-lighter: #888888;
  --color-border: #e5e0da;
  --color-border-light: #f0ede8;

  --font-heading: 'Outfit', sans-serif;
  --font-body: 'Inter', sans-serif;

  --section-padding: 96px 0;
  --container-max: 1200px;
  --container-pad: 0 24px;

  --transition-fast: 0.2s ease;
  --transition-base: 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  --shadow-sm: 0 2px 8px rgba(72,40,0,0.06);
  --shadow-md: 0 4px 20px rgba(72,40,0,0.09);
  --shadow-lg: 0 8px 40px rgba(72,40,0,0.13);
  --shadow-xl: 0 16px 60px rgba(72,40,0,0.16);

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
}

/* ---- Reset ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; scroll-padding-top:80px; }
body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  opacity: 1;
  transition: opacity 0.3s ease;
}
body.page-transition { opacity: 0; }
a { text-decoration:none; color:inherit; transition: color var(--transition-fast); }
ul, ol { list-style:none; }
img { max-width:100%; height:auto; display:block; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ---- Container ---- */
.container { max-width:var(--container-max); margin:0 auto; padding:var(--container-pad); }

/* ---- Section ---- */
.section { padding: var(--section-padding); position:relative; }
.section--alt { background: var(--color-bg-alt); }
.section--dark { background: var(--color-primary); }

.section__header { text-align:center; max-width:720px; margin:0 auto 56px; }
.section__header--left { text-align:left; margin-left:0; }

.section__tag {
  display:inline-block;
  font-family:var(--font-heading);
  font-size:0.78rem; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--color-primary);
  background:rgba(var(--color-primary-rgb),0.08);
  padding:5px 16px; border-radius:50px; margin-bottom:14px;
}
.section__tag--white { color:rgba(255,255,255,0.8); background:rgba(255,255,255,0.1); }

.section__title {
  font-family:var(--font-heading);
  font-size:clamp(1.8rem,4vw,2.6rem);
  font-weight:700; color:var(--color-text); line-height:1.2; margin-bottom:14px;
}
.section__title--white { color:#fff; }
.section__title--left { text-align:left; }

.section__desc { font-size:1.05rem; color:var(--color-text-light); line-height:1.8; }
.section__desc--white { color:rgba(255,255,255,0.75); }

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-heading); font-size:0.95rem; font-weight:600;
  padding:14px 32px; border-radius:var(--radius-md);
  transition:all var(--transition-base); border:2px solid transparent;
}
.btn--primary { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.btn--primary:hover { background:var(--color-primary-dark); border-color:var(--color-primary-dark); transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.btn--outline { background:transparent; color:var(--color-primary); border-color:var(--color-primary); }
.btn--outline:hover { background:var(--color-primary); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.btn--outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,0.5); }
.btn--outline-white:hover { background:#fff; color:var(--color-primary); border-color:#fff; transform:translateY(-2px); }
.btn--full { width:100%; justify-content:center; }
.btn--sm { padding:10px 22px; font-size:0.88rem; }

/* ---- Badge Pill ---- */
.badge {
  display:inline-block;
  font-family:var(--font-heading); font-size:0.75rem; font-weight:600;
  text-transform:uppercase; letter-spacing:1.5px;
  padding:4px 14px; border-radius:50px;
}
.badge--primary { background:var(--color-primary); color:#fff; }
.badge--light { background:rgba(var(--color-primary-rgb),0.08); color:var(--color-primary); }

/* ---- Divider ---- */
.divider {
  width:48px; height:4px; border-radius:2px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  margin: 0 auto 24px;
}
.divider--left { margin-left:0; }

/* =============================================
   NAVBAR
   ============================================= */
.navbar {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  padding:16px 0; transition:all var(--transition-base);
  background:transparent;
}
.navbar.scrolled, .navbar.solid {
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  box-shadow:var(--shadow-sm); padding:10px 0;
}
.navbar__inner { display:flex; align-items:center; justify-content:space-between; }
.navbar__logo { display:flex; align-items:center; z-index:1001; }
.navbar__logo-img { height:95px; width:auto; transition:var(--transition-base); }
.navbar.scrolled .navbar__logo-img, .navbar.solid .navbar__logo-img { height:70px; }
.navbar__menu { display:flex; align-items:center; gap:4px; }

.navbar__link {
  font-family:var(--font-heading); font-size:0.88rem; font-weight:500;
  color:rgba(255,255,255,0.88); padding:8px 16px; border-radius:var(--radius-sm);
  transition:all var(--transition-fast); position:relative;
}
.navbar.solid .navbar__link, .navbar.scrolled .navbar__link { color:var(--color-text-light); }
.navbar__link::after {
  content:''; position:absolute; bottom:6px; left:50%; transform:translateX(-50%);
  width:0; height:2px; background:#fff; border-radius:2px; transition:width var(--transition-base);
}
.navbar.solid .navbar__link::after, .navbar.scrolled .navbar__link::after { background:var(--color-primary); }
.navbar__link:hover::after, .navbar__link.active::after { width:20px; }
.navbar__link:hover { color:#fff; }
.navbar.solid .navbar__link:hover, .navbar.scrolled .navbar__link:hover { color:var(--color-primary); }
.navbar__link.active { color:#fff; }
.navbar.solid .navbar__link.active, .navbar.scrolled .navbar__link.active { color:var(--color-primary); font-weight:600; }

.navbar__link--cta {
  background:#fff; color:var(--color-primary) !important;
  font-weight:600; padding:10px 24px; border-radius:var(--radius-md); margin-left:8px;
}
.navbar__link--cta::after { display:none; }
.navbar__link--cta:hover { background:var(--color-primary); color:#fff !important; transform:translateY(-1px); box-shadow:var(--shadow-md); }
.navbar.solid .navbar__link--cta, .navbar.scrolled .navbar__link--cta { background:var(--color-primary); color:#fff !important; }
.navbar.solid .navbar__link--cta:hover, .navbar.scrolled .navbar__link--cta:hover { background:var(--color-primary-dark); color:#fff !important; }

/* Hamburger */
.navbar__hamburger { display:none; flex-direction:column; gap:5px; width:32px; height:32px; z-index:1001; justify-content:center; }
.navbar__hamburger-line { display:block; width:100%; height:2px; background:#fff; border-radius:2px; transition:all var(--transition-base); }
.navbar.solid .navbar__hamburger-line, .navbar.scrolled .navbar__hamburger-line { background:var(--color-primary); }
.navbar__hamburger.active .navbar__hamburger-line:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.navbar__hamburger.active .navbar__hamburger-line:nth-child(2) { opacity:0; }
.navbar__hamburger.active .navbar__hamburger-line:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* =============================================
   PAGE HERO (internal pages)
   ============================================= */
.page-hero {
  background:linear-gradient(160deg, #1a0e00 0%, var(--color-primary) 40%, #5c3810 75%, #3a2000 100%);
  padding: 140px 0 80px; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
}
.page-hero__content { position:relative; z-index:2; text-align:center; }
.page-hero__tag {
  display:inline-block; font-family:var(--font-heading);
  font-size:0.78rem; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.65); border:1px solid rgba(255,255,255,0.2);
  padding:7px 22px; border-radius:50px; margin-bottom:20px;
  backdrop-filter:blur(10px); background:rgba(255,255,255,0.04);
}
.page-hero__title {
  font-family:var(--font-heading); font-size:clamp(2rem,5vw,3.2rem);
  font-weight:800; color:#fff; line-height:1.15; margin-bottom:18px;
}
.page-hero__desc {
  font-size:clamp(0.95rem,2vw,1.1rem); color:rgba(255,255,255,0.75);
  max-width:600px; margin:0 auto; line-height:1.8;
}
.page-hero__wave { position:absolute; bottom:-2px; left:0; width:100%; z-index:3; line-height:0; }
.page-hero__wave svg { width:100%; height:60px; }

/* =============================================
   FOOTER
   ============================================= */
.footer { background:var(--color-text); color:rgba(255,255,255,0.65); padding-top:64px; }
.footer__top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.07);
}
.footer__logo-img { height:95px; width:auto; margin-bottom:16px; opacity:0.95; }
.footer__brand-text { font-size:0.88rem; line-height:1.7; max-width:280px; opacity:0.65; }
.footer__socials { display: flex; gap: 10px; margin-top: 20px; }
.footer__social-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.05); color: rgba(255, 255, 255, 0.55);
  transition: all var(--transition-base); text-decoration: none;
}
.footer__social-link:hover {
  background: var(--color-primary); color: #fff;
  transform: translateY(-3px); box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}
.footer__col-title { font-family:var(--font-heading); font-size:0.88rem; font-weight:700; color:#fff; margin-bottom:18px; }
.footer__links ul { display:flex; flex-direction:column; gap:9px; }
.footer__links ul li a { font-size:0.86rem; color:rgba(255,255,255,0.5); transition:all var(--transition-fast); display:inline-block; }
.footer__links ul li a:hover { color:#fff; transform:translateX(4px); }
.footer__bottom { display:flex; align-items:center; justify-content:space-between; padding:22px 0; flex-wrap:wrap; gap:12px; }
.footer__copy { font-size:0.82rem; opacity:0.45; }
.footer__legal { display:flex; gap:20px; }
.footer__legal a { font-size:0.82rem; color:rgba(255,255,255,0.45); transition:color var(--transition-fast); }
.footer__legal a:hover { color:#fff; }

/* =============================================
   SCROLL ANIMATIONS
   ============================================= */
[data-animate] {
  opacity:0; transform:translateY(40px);
  transition: opacity 0.7s cubic-bezier(0.4,0,0.2,1), transform 0.7s cubic-bezier(0.4,0,0.2,1);
}
[data-animate].animate-in { opacity:1; transform:translateY(0); }
[data-animate]:nth-child(2) { transition-delay:0.1s; }
[data-animate]:nth-child(3) { transition-delay:0.2s; }
[data-animate]:nth-child(4) { transition-delay:0.3s; }
[data-animate]:nth-child(5) { transition-delay:0.38s; }
[data-animate]:nth-child(6) { transition-delay:0.46s; }
[data-animate]:nth-child(7) { transition-delay:0.52s; }
[data-animate]:nth-child(8) { transition-delay:0.58s; }

/* =============================================
   SCROLL TO TOP
   ============================================= */
.scroll-top {
  position:fixed; bottom:28px; right:28px; width:46px; height:46px;
  border-radius:50%; background:var(--color-primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-lg); z-index:999;
  opacity:0; visibility:hidden; transform:translateY(20px);
  transition:all var(--transition-base); cursor:pointer; border:none;
}
.scroll-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top:hover { background:var(--color-primary-dark); transform:translateY(-3px); box-shadow:var(--shadow-xl); }

/* =============================================
   INDEX — HERO
   ============================================= */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  background:linear-gradient(160deg, #1a0e00 0%, var(--color-primary) 35%, #5c3810 65%, #3a2000 100%);
}
.hero__video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
  z-index: 0;
  filter: brightness(0.72) contrast(0.85) saturate(1.0);
}
.hero__bg-overlay {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(72,40,0,0.06) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 30%, rgba(107,61,10,0.04) 0%, transparent 60%),
    linear-gradient(to bottom, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.45) 100%);
  z-index:1;
}
.hero__content { position:relative; z-index:2; text-align:center; padding-top:100px; padding-bottom:60px; }
.hero__badge {
  display:inline-block; font-family:var(--font-heading);
  font-size:0.76rem; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.7); border:1px solid rgba(255,255,255,0.2);
  padding:7px 22px; border-radius:50px; margin-bottom:26px;
  backdrop-filter:blur(10px); background:rgba(255,255,255,0.05);
  animation:fadeInDown 1s ease 0.2s both;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
}
.hero__title {
  font-family:var(--font-heading); font-size:clamp(2rem,5.5vw,3.5rem);
  font-weight:800; color:#fff; line-height:1.15; max-width:820px; margin:0 auto 22px;
  animation:fadeInDown 1s ease 0.4s both;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.55);
}
.hero__subtitle {
  font-size:clamp(0.95rem,2vw,1.1rem); color:rgba(255,255,255,0.75);
  max-width:620px; margin:0 auto 36px; line-height:1.8;
  animation:fadeInDown 1s ease 0.6s both;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
}
.hero__ctas { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; animation:fadeInUp 1s ease 0.8s both; }
.hero__stats {
  display:flex; justify-content:center; align-items:center; gap:40px;
  margin-top:60px; padding-top:40px; border-top:1px solid rgba(255,255,255,0.12);
  animation:fadeInUp 1s ease 1s both;
}
.hero__stat { text-align:center; }
.hero__stat-number { display:block; font-family:var(--font-heading); font-size:clamp(2rem,4vw,2.8rem); font-weight:800; color:#fff; }
.hero__stat-suffix { font-family:var(--font-heading); font-size:clamp(1.5rem,3vw,2rem); font-weight:800; color:rgba(255,255,255,0.55); }
.hero__stat-label { display:block; font-size:0.8rem; color:rgba(255,255,255,0.5); font-weight:500; margin-top:4px; letter-spacing:0.5px; }
.hero__stat-divider { width:1px; height:50px; background:rgba(255,255,255,0.14); }
.hero__wave { position:absolute; bottom:-2px; left:0; width:100%; z-index:3; line-height:0; }
.hero__wave svg { width:100%; height:80px; }

/* =============================================
   INDEX — SECTORS PREVIEW
   ============================================= */
.sectores-preview__grid { display:grid; grid-template-columns:repeat(5,1fr); gap:24px; }
.sector-card {
  text-align:center; padding:44px 24px 36px; border-radius:var(--radius-lg);
  background:var(--color-white); border:1px solid var(--color-border-light);
  transition:all var(--transition-base); position:relative; overflow:hidden;
  text-decoration:none; display:block;
}
.sector-card::before {
  content:''; position:absolute; bottom:0; left:0; width:100%; height:3px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transform:scaleX(0); transform-origin:center; transition:transform var(--transition-base);
}
.sector-card:hover { transform:translateY(-7px); box-shadow:var(--shadow-xl); border-color:transparent; }
.sector-card:hover::before { transform:scaleX(1); }
.sector-card__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:80px; height:80px; border-radius:50%;
  background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary);
  margin-bottom:22px; transition:all var(--transition-base);
}
.sector-card:hover .sector-card__icon { background:var(--color-primary); color:#fff; transform:scale(1.1) rotate(5deg); }
.sector-card__title { font-family:var(--font-heading); font-size:1.15rem; font-weight:700; color:var(--color-text); margin-bottom:10px; }
.sector-card__text { font-size:0.88rem; color:var(--color-text-light); line-height:1.7; }

/* =============================================
   INDEX — SERVICES PREVIEW
   ============================================= */
.servicios-preview__grid { display:flex; flex-wrap:wrap; justify-content:center; gap:22px; }
.servicio-card {
  flex: 0 0 calc(25% - 17px);
  background:var(--color-white); border:1px solid var(--color-border-light);
  border-radius:var(--radius-lg); padding:32px 24px; transition:all var(--transition-base);
  position:relative; overflow:hidden;
}
.servicio-card::after {
  content:''; position:absolute; bottom:0; left:0; width:100%; height:3px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transform:scaleX(0); transform-origin:center; transition:transform var(--transition-base);
}
.servicio-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.servicio-card:hover::after { transform:scaleX(1); }
.servicio-card__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:52px; height:52px; border-radius:var(--radius-md);
  background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary);
  margin-bottom:18px; transition:all var(--transition-base);
}
.servicio-card:hover .servicio-card__icon { background:var(--color-primary); color:#fff; }
.servicio-card__icon img,
.servicio-detalle__icon img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  transition: filter var(--transition-fast);
}
.servicio-card:hover .servicio-card__icon img {
  filter: brightness(0) invert(1);
}
.servicio-card__title { font-family:var(--font-heading); font-size:1rem; font-weight:700; color:var(--color-text); margin-bottom:8px; line-height:1.3; }
.servicio-card__text { font-size:0.875rem; color:var(--color-text-light); line-height:1.7; }

/* =============================================
   EMPRESA PAGE
   ============================================= */
.empresa-intro__grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.empresa-intro__visual {
  position:relative; border-radius:var(--radius-xl); overflow:hidden;
  background:linear-gradient(160deg, var(--color-primary), var(--color-accent));
  height:420px; display:flex; align-items:center; justify-content:center;
}
.empresa-intro__visual-inner { text-align:center; color:#fff; padding:40px; }
.empresa-intro__visual-icon { opacity:0.2; margin:0 auto 20px; }
.empresa-intro__visual-text { font-family:var(--font-heading); font-size:1.2rem; font-weight:600; opacity:0.7; }
.empresa-intro__content h2 { font-family:var(--font-heading); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:700; color:var(--color-text); margin-bottom:20px; line-height:1.25; }
.empresa-intro__content p { font-size:1rem; color:var(--color-text-light); line-height:1.8; margin-bottom:16px; }

/* MVV */
.mvv__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.mvv-card {
  background:var(--color-white); border:1px solid var(--color-border-light);
  border-radius:var(--radius-lg); padding:40px 30px; text-align:center;
  transition:all var(--transition-base); position:relative; overflow:hidden;
}
.mvv-card::before {
  content:''; position:absolute; top:0; left:0; width:100%; height:4px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transform:scaleX(0); transform-origin:left; transition:transform var(--transition-base);
}
.mvv-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.mvv-card:hover::before { transform:scaleX(1); }
.mvv-card__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:68px; height:68px; border-radius:50%;
  background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary);
  margin-bottom:22px; transition:all var(--transition-base);
}
.mvv-card:hover .mvv-card__icon { background:var(--color-primary); color:#fff; transform:scale(1.1); }
.mvv-card__title { font-family:var(--font-heading); font-size:1.2rem; font-weight:700; color:var(--color-text); margin-bottom:12px; }
.mvv-card__text { font-size:0.9rem; color:var(--color-text-light); line-height:1.75; }

/* Valores */
.valores__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.valor-item {
  display:flex; gap:18px; align-items:flex-start;
  background:var(--color-white); border:1px solid var(--color-border-light);
  border-radius:var(--radius-md); padding:24px; transition:all var(--transition-base);
}
.valor-item:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:transparent; }
.valor-item__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:48px; height:48px; flex-shrink:0; border-radius:var(--radius-sm);
  background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary);
}
.valor-item__title { font-family:var(--font-heading); font-size:1rem; font-weight:700; color:var(--color-text); margin-bottom:6px; }
.valor-item__text { font-size:0.875rem; color:var(--color-text-light); line-height:1.65; }

/* Equipo stats */
.equipo__stats { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.equipo-stat {
  text-align:center; padding:36px 20px; border-radius:var(--radius-lg);
  background:linear-gradient(160deg, var(--color-primary), var(--color-accent));
  color:#fff;
}
.equipo-stat__number { font-family:var(--font-heading); font-size:2.4rem; font-weight:800; margin-bottom:8px; }
.equipo-stat__label { font-size:0.88rem; opacity:0.75; }

/* =============================================
   SERVICIOS PAGE
   ============================================= */
.servicios-list { display:flex; flex-direction:column; gap:0; }
.servicio-detalle {
  display:grid; grid-template-columns:72px 1fr; gap:32px;
  padding:56px 0; border-bottom:1px solid var(--color-border-light);
  align-items:start;
}
.servicio-detalle:last-child { border-bottom:none; }
.servicio-detalle__num {
  font-family:var(--font-heading); font-size:3.5rem; font-weight:800;
  color:rgba(var(--color-primary-rgb),0.1); line-height:1; padding-top:8px;
  user-select:none;
}
.servicio-detalle__header { display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.servicio-detalle__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:56px; height:56px; flex-shrink:0; border-radius:var(--radius-md);
  background:rgba(var(--color-primary-rgb),0.08); color:var(--color-primary);
}
.servicio-detalle__title { font-family:var(--font-heading); font-size:1.4rem; font-weight:700; color:var(--color-text); }
.servicio-detalle__desc { font-size:0.98rem; color:var(--color-text-light); line-height:1.8; margin-bottom:20px; }
.servicio-detalle__entregables h4 { font-family:var(--font-heading); font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--color-primary); margin-bottom:14px; }
.servicio-detalle__list { display:grid; grid-template-columns:1fr 1fr; gap:8px 24px; }
.servicio-detalle__list li { display:flex; align-items:center; gap:10px; font-size:0.9rem; color:var(--color-text-light); }
.servicio-detalle__list li svg { color:var(--color-primary); flex-shrink:0; }

/* =============================================
   SECTORES PAGE
   ============================================= */
.sector-detalle {
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
  padding:72px 0; border-bottom:1px solid var(--color-border-light);
}
.sector-detalle:last-child { border-bottom:none; }
.sector-detalle--reverse { direction:rtl; }
.sector-detalle--reverse > * { direction:ltr; }
.sector-detalle__visual {
  border-radius:var(--radius-xl); overflow:hidden; height:380px;
  display:flex; align-items:center; justify-content:center; position:relative;
  background-size: cover; background-position: center;
}
.sector-detalle__visual--industrial { background-image: linear-gradient(135deg, rgba(42, 24, 0, 0.5) 0%, rgba(184, 103, 13, 0.55) 60%, rgba(92, 56, 16, 0.5) 100%), url('assets/sectores-industrial.png'); }
.sector-detalle__visual--agricola { background-image: linear-gradient(135deg, rgba(26, 46, 16, 0.55) 0%, rgba(45, 90, 30, 0.6) 60%, rgba(74, 122, 48, 0.55) 100%), url('assets/sectores-agricola.png'); }
.sector-detalle__visual--ganadero { background-image: linear-gradient(135deg, rgba(30, 26, 10, 0.5) 0%, rgba(74, 60, 16, 0.55) 60%, rgba(110, 90, 24, 0.5) 100%), url('assets/sectores-ganadero.png'); }
.sector-detalle__visual--urbanizacion { background-image: linear-gradient(135deg, rgba(10, 26, 46, 0.5) 0%, rgba(26, 58, 92, 0.55) 60%, rgba(42, 90, 142, 0.5) 100%), url('assets/sectores-urbanizacion.jpg'); }
.sector-detalle__visual--alimentario { background-image: linear-gradient(135deg, rgba(42, 8, 8, 0.5) 0%, rgba(74, 21, 21, 0.55) 60%, rgba(110, 32, 32, 0.5) 100%), url('assets/sectores-alimentario.jpg'); }
.sector-detalle__visual-icon { opacity:0.25; z-index: 2; }
.sector-detalle__visual-label {
  position:absolute; bottom:24px; left:24px;
  font-family:var(--font-heading); font-size:0.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px; color:#fff; opacity:0.85;
  z-index: 2;
}
.sector-detalle__content h2 { font-family:var(--font-heading); font-size:clamp(1.5rem,3vw,2rem); font-weight:700; color:var(--color-text); margin-bottom:16px; }
.sector-detalle__content p { font-size:0.98rem; color:var(--color-text-light); line-height:1.8; margin-bottom:20px; }
.sector-detalle__list { display:flex; flex-direction:column; gap:10px; }
.sector-detalle__list li { display:flex; align-items:center; gap:10px; font-size:0.92rem; color:var(--color-text-light); }
.sector-detalle__list li svg { color:var(--color-primary); flex-shrink:0; }

/* =============================================
   PROYECTOS PAGE
   ============================================= */
.proyectos__filters { display:flex; justify-content:center; flex-wrap:wrap; gap:8px; margin-bottom:40px; }
.proyectos__filter {
  font-family:var(--font-heading); font-size:0.88rem; font-weight:500;
  padding:10px 24px; border-radius:50px; color:var(--color-text-light);
  background:transparent; border:1px solid var(--color-border); transition:all var(--transition-base);
}
.proyectos__filter:hover { color:var(--color-primary); border-color:var(--color-primary); }
.proyectos__filter.active { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.proyectos__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.proyecto-card { border-radius:var(--radius-lg); overflow:hidden; background:var(--color-white); border:1px solid var(--color-border-light); transition:all var(--transition-base); }
.proyecto-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-xl); border-color:transparent; }
.proyecto-card.hidden { display:none; }
.proyecto-card__img { position:relative; height:200px; overflow:hidden; }
.proyecto-card__overlay { position:absolute; inset:0; display:flex; align-items:flex-start; justify-content:flex-end; padding:14px; background:linear-gradient(180deg,rgba(0,0,0,0.12) 0%,transparent 100%); }
.proyecto-card__cat {
  font-family:var(--font-heading); font-size:0.72rem; font-weight:600;
  text-transform:uppercase; letter-spacing:1px; color:#fff;
  background:rgba(255,255,255,0.18); padding:5px 12px; border-radius:50px;
  backdrop-filter:blur(8px);
}
.proyecto-card__body { padding:22px; }
.proyecto-card__title { font-family:var(--font-heading); font-size:1.05rem; font-weight:700; color:var(--color-text); margin-bottom:8px; }
.proyecto-card__desc { font-size:0.85rem; color:var(--color-text-light); line-height:1.65; margin-bottom:12px; }
.proyecto-card__meta { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.proyecto-card__loc { display:flex; align-items:center; gap:5px; font-size:0.82rem; color:var(--color-text-lighter); }
.proyecto-card__loc svg { color:var(--color-primary); flex-shrink:0; }
.proyecto-card__area { font-family:var(--font-heading); font-size:0.8rem; font-weight:600; color:var(--color-primary); background:rgba(var(--color-primary-rgb),0.07); padding:3px 10px; border-radius:50px; }

/* =============================================
   INNOVACION PAGE
   ============================================= */
.innovacion-hero { background:linear-gradient(160deg, #1a0e00 0%, var(--color-primary) 45%, #5c3810 80%, #3a2000 100%); }
.subvenciones__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.subvencion-card {
  background:var(--color-white); border:1px solid var(--color-border-light);
  border-radius:var(--radius-lg); padding:36px 28px;
  transition:all var(--transition-base); position:relative; overflow:hidden;
}
.subvencion-card::before {
  content:''; position:absolute; top:0; left:0; width:100%; height:4px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
}
.subvencion-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.subvencion-card__logo {
  display:inline-flex; align-items:center; justify-content:center;
  width:60px; height:60px; border-radius:var(--radius-md);
  background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary); margin-bottom:20px;
}
.subvencion-card__title { font-family:var(--font-heading); font-size:1.15rem; font-weight:700; color:var(--color-text); margin-bottom:10px; }
.subvencion-card__text { font-size:0.9rem; color:var(--color-text-light); line-height:1.75; }
.subvencionables__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.subvencionable-item {
  display:flex; gap:16px; align-items:flex-start;
  background:var(--color-white); border:1px solid var(--color-border-light);
  border-radius:var(--radius-md); padding:22px;
  transition:all var(--transition-base);
}
.subvencionable-item:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:transparent; }
.subvencionable-item__icon { display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; flex-shrink:0; border-radius:var(--radius-sm); background:rgba(var(--color-primary-rgb),0.07); color:var(--color-primary); }
.subvencionable-item__title { font-family:var(--font-heading); font-size:0.98rem; font-weight:700; color:var(--color-text); margin-bottom:5px; }
.subvencionable-item__text { font-size:0.85rem; color:var(--color-text-light); line-height:1.6; }
.innovacion-cta {
  background:linear-gradient(160deg, var(--color-primary), var(--color-accent));
  border-radius:var(--radius-xl); padding:64px 48px; text-align:center; color:#fff;
  position:relative; overflow:hidden;
}
.innovacion-cta::before { content:''; position:absolute; top:-40%; right:-20%; width:60%; height:180%; background:radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%); }

/* =============================================
   CONTACTAR PAGE
   ============================================= */
.contactar__inner { display:grid; grid-template-columns:1.2fr 0.8fr; gap:40px; align-items:start; }
.contacto__global { display:flex; justify-content:center; gap:40px; margin-bottom:48px; flex-wrap:wrap; }
.contacto__global-item { display:flex; align-items:center; gap:10px; font-family:var(--font-heading); font-size:1.08rem; font-weight:600; color:var(--color-primary); transition:all var(--transition-fast); }
.contacto__global-item:hover { color:var(--color-accent); transform:translateY(-1px); }
.contacto__form { background:var(--color-white); border:1px solid var(--color-border-light); border-radius:var(--radius-xl); padding:40px; box-shadow:var(--shadow-sm); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-group { margin-bottom:18px; }
.form-group:last-child { margin-bottom:0; }
.form-label { display:block; font-family:var(--font-heading); font-size:0.84rem; font-weight:600; color:var(--color-text); margin-bottom:7px; }
.form-input {
  width:100%; padding:13px 16px; font-family:var(--font-body); font-size:0.92rem;
  color:var(--color-text); background:var(--color-bg-alt); border:1px solid var(--color-border);
  border-radius:var(--radius-md); transition:all var(--transition-fast); outline:none;
  appearance:none; -webkit-appearance:none;
}
.form-input:focus { border-color:var(--color-primary); background:#fff; box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),0.1); }
.form-input::placeholder { color:var(--color-text-lighter); }
.form-select { cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }
.form-textarea { resize:vertical; min-height:120px; }
.form-check { display:flex; align-items:flex-start; gap:10px; }
.form-checkbox { width:18px; height:18px; margin-top:2px; accent-color:var(--color-primary); cursor:pointer; flex-shrink:0; }
.form-check-label { font-size:0.82rem; color:var(--color-text-light); line-height:1.5; cursor:pointer; }
.form-link { color:var(--color-primary); text-decoration:underline; font-weight:500; }
.form-link:hover { color:var(--color-primary-dark); }
.contacto__sedes { display:flex; flex-direction:column; gap:24px; }
.sede-card { background:var(--color-white); border:1px solid var(--color-border-light); border-radius:var(--radius-lg); padding:28px; transition:all var(--transition-base); }
.sede-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:transparent; }
.sede-card__badge { display:inline-block; font-family:var(--font-heading); font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:#fff; background:var(--color-primary); padding:4px 13px; border-radius:50px; margin-bottom:14px; }
.sede-card__title { display:flex; align-items:center; gap:9px; font-family:var(--font-heading); font-size:1.15rem; font-weight:700; color:var(--color-text); margin-bottom:14px; }
.sede-card__title svg { color:var(--color-primary); flex-shrink:0; }
.sede-card__info { display:flex; flex-direction:column; gap:9px; }
.sede-card__info li { display:flex; align-items:center; gap:9px; font-size:0.88rem; color:var(--color-text-light); }
.sede-card__info li svg { color:var(--color-primary); flex-shrink:0; }
.sede-card__info li a { color:var(--color-text-light); transition:color var(--transition-fast); }
.sede-card__info li a:hover { color:var(--color-primary); }
.sede-card__map { margin-top:16px; border-radius:var(--radius-md); overflow:hidden; }

/* Success state */
.form-success { display:none; text-align:center; padding:48px 24px; }
.form-success.show { display:block; }
.form-success__icon { display:inline-flex; align-items:center; justify-content:center; width:68px; height:68px; border-radius:50%; background:rgba(var(--color-primary-rgb),0.08); color:var(--color-primary); margin-bottom:18px; }
.form-success__title { font-family:var(--font-heading); font-size:1.25rem; font-weight:700; color:var(--color-text); margin-bottom:8px; }
.form-success__text { font-size:0.92rem; color:var(--color-text-light); }

/* =============================================
   EQUIPO — Team Members
   ============================================= */
.team__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
}
.team-card {
  text-align: center;
  background: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: all var(--transition-base);
  position: relative;
}
.team-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
  border-color: transparent;
}
.team-card__photo-wrap {
  position: relative;
  overflow: hidden;
  height: 280px;
  background: linear-gradient(160deg, var(--color-bg-alt), var(--color-border-light));
}
.team-card__photo-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  display: block;
}
.team-card:hover .team-card__photo-wrap img {
  transform: scale(1.06);
}
.team-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(72,40,0,0.55) 100%);
  opacity: 0;
  transition: opacity var(--transition-base);
}
.team-card:hover .team-card__overlay { opacity: 1; }

.team-card__body {
  padding: 20px 16px 24px;
}
.team-card__name {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 6px;
}
.team-card__role {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 0.76rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--color-primary);
  background: rgba(var(--color-primary-rgb), 0.08);
  padding: 4px 13px;
  border-radius: 50px;
}

@media (max-width: 1024px) {
  .team__grid { grid-template-columns: repeat(3, 1fr); }
  .team-card__photo-wrap { height: 240px; }
}
@media (max-width: 768px) {
  .team__grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .team-card__photo-wrap { height: 220px; }
}
@media (max-width: 480px) {
  .team__grid { grid-template-columns: 1fr; }
}

/* =============================================
   SUBVENCIONES PAGE
   ============================================= */
.subvencion-item {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 48px;
  align-items: flex-start;
  padding: 64px 0;
  border-bottom: 1px solid var(--color-border-light);
}
.subvencion-item:last-child {
  border-bottom: none;
}
.subvencion-item--reverse {
  direction: rtl;
}
.subvencion-item--reverse > * {
  direction: ltr;
}
.subvencion-item__content h3 {
  font-family: var(--font-heading);
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 16px;
  line-height: 1.35;
}
.subvencion-item__meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 24px;
  background: var(--color-bg-alt);
  padding: 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-light);
}
.subvencion-item__meta-item {
  font-size: 0.88rem;
  color: var(--color-text-light);
}
.subvencion-item__meta-item strong {
  display: block;
  font-family: var(--font-heading);
  color: var(--color-text);
  font-size: 0.92rem;
  margin-bottom: 2px;
}
.subvencion-item__text {
  font-size: 0.95rem;
  color: var(--color-text-light);
  line-height: 1.75;
  margin-bottom: 20px;
}
.subvencion-item__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
}
.subvencion-item__list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.9rem;
  color: var(--color-text-light);
  line-height: 1.5;
}
.subvencion-item__list li svg {
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 3px;
}
.subvencion-item__poster-container {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.subvencion-item__poster {
  width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-light);
  cursor: pointer;
  transition: transform var(--transition-fast);
}
.subvencion-item__poster:hover {
  transform: scale(1.02);
}
.subvencion-item__thumbs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

@media (max-width: 1024px) {
  .subvencion-item {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 48px 0;
  }
  .subvencion-item--reverse {
    direction: ltr;
  }
}

/* =============================================
   KIT DIGITAL CO-FINANCING FOOTER INTEGRATION
   ============================================= */
.footer__co-financing {
  text-align: center;
  padding: 24px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  margin-bottom: 16px;
}
.footer__co-financing-card {
  display: inline-block;
  background-color: var(--color-white);
  padding: 10px 24px;
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.footer__co-financing-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
}
.footer__co-financing-img {
  max-width: 100%;
  height: auto;
  max-height: 55px;
  display: block;
}
.footer__co-financing-text {
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.6);
  max-width: 750px;
  margin: 16px auto 0;
  line-height: 1.6;
  text-align: center;
}
.footer__co-financing-text strong {
  color: #fff;
  font-weight: 600;
}

/* =============================================
   KEYFRAMES
   ============================================= */
@keyframes fadeInDown { from { opacity:0; transform:translateY(-28px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeInUp   { from { opacity:0; transform:translateY(28px);  } to { opacity:1; transform:translateY(0); } }
@keyframes spin       { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }

/* =============================================
   RESPONSIVE — Tablet (≤1024px)
   ============================================= */
@media (max-width:1024px) {
  .sectores-preview__grid { grid-template-columns:repeat(2,1fr); }
  .servicio-card { flex: 0 0 calc(50% - 11px); }
  .mvv__grid { grid-template-columns:repeat(3,1fr); }
  .equipo__stats { grid-template-columns:repeat(2,1fr); }
  .empresa-intro__grid { grid-template-columns:1fr; gap:40px; }
  .empresa-intro__visual { height:300px; order:-1; }
  .sector-detalle { grid-template-columns:1fr; gap:36px; }
  .sector-detalle--reverse { direction:ltr; }
  .sector-detalle__visual { height:280px; }
  .proyectos__grid { grid-template-columns:repeat(2,1fr); }
  .subvenciones__grid { grid-template-columns:repeat(2,1fr); }
  .contactar__inner { grid-template-columns:1fr; }
  .footer__top { grid-template-columns:1fr 1fr; gap:30px; }
}

/* =============================================
   RESPONSIVE — Mobile (≤768px)
   ============================================= */
@media (max-width:768px) {
  :root { --section-padding:68px 0; }
  .navbar__hamburger { display:flex; }
  .navbar__menu {
    position:fixed; top:0; right:-100%; width:80%; max-width:340px; height:100vh;
    background:#fff; flex-direction:column; align-items:flex-start; justify-content:center;
    gap:6px; padding:80px 36px 40px; transition:right var(--transition-base);
    box-shadow:-8px 0 40px rgba(0,0,0,0.1);
  }
  .navbar__menu.open { right:0; }
  .navbar__link { color:var(--color-text) !important; font-size:1rem; padding:12px 0; width:100%; }
  .navbar__link::after { bottom:8px; left:0; transform:none; background:var(--color-primary) !important; }
  .navbar__link--cta { margin-left:0; margin-top:12px; text-align:center; justify-content:center; display:flex; background:var(--color-primary) !important; color:#fff !important; width:100%; }
  .hero__stats { flex-direction:column; gap:22px; }
  .hero__stat-divider { width:48px; height:1px; }
  .hero__ctas, .page-hero .hero__ctas { flex-direction:column; align-items:center; }
  .hero__ctas .btn { width:100%; max-width:300px; justify-content:center; }
  .sectores-preview__grid { grid-template-columns:1fr; gap:16px; }
  .servicio-card { flex: 0 0 100%; }
  .mvv__grid { grid-template-columns:1fr; gap:16px; }
  .valores__grid { grid-template-columns:1fr; }
  .equipo__stats { grid-template-columns:repeat(2,1fr); }
  .servicio-detalle { grid-template-columns:1fr; gap:16px; }
  .servicio-detalle__num { font-size:2rem; }
  .servicio-detalle__list { grid-template-columns:1fr; }
  .proyectos__grid { grid-template-columns:1fr; }
  .subvenciones__grid { grid-template-columns:1fr; }
  .subvencionables__grid { grid-template-columns:1fr; }
  .contacto__form { padding:26px 18px; }
  .form-row { grid-template-columns:1fr; }
  .contacto__global { flex-direction:column; align-items:center; gap:14px; }
  .footer__top { grid-template-columns:1fr; gap:26px; }
  .footer__bottom { flex-direction:column; text-align:center; }
  .footer__legal { flex-wrap:wrap; justify-content:center; }
  .section__header { margin-bottom:36px; }
  .innovacion-cta { padding:44px 28px; }
}

@media (max-width:480px) {
  .hero__title { font-size:1.8rem; }
  .page-hero__title { font-size:1.8rem; }
  .equipo__stats { grid-template-columns:1fr; }
}

