:root {
      --carbon: #202727;
      --carbon-2: #2a3941;
      --deep: #063d76;
      --blue: #0e6099;
      --electric: #3075f3;
      --sky: #55bcea;
      --sky-2: #6ec6eb;
      --fuchsia: #e3097e;
      --hot: #fc2583;
      --rose: #fb6fa0;
      --paper: #f2f1f1;
      --white: #ffffff;
      --muted: #64737b;
      --line: rgba(32, 39, 39, 0.12);
      --shadow: 0 22px 58px rgba(6, 61, 118, 0.17);
      --radius: 28px;
      --radius-soft: 42px;
      --radius-organic: 44px 24px 54px 28px;
    }

    * { box-sizing: border-box; }

    html { scroll-behavior: smooth; }

    body {
      margin: 0;
      color: var(--carbon);
      background: #fff;
      font-family: Inter, "Segoe UI", Arial, Helvetica, sans-serif;
      letter-spacing: 0;
    }

    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    .topbar {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 30;
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 78px;
      padding: 0 34px;
      color: #fff;
      background: linear-gradient(180deg, rgba(13, 26, 40, 0.78), rgba(13, 26, 40, 0.32));
      border-bottom: 1px solid rgba(255,255,255,0.16);
      backdrop-filter: blur(18px);
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      min-width: clamp(260px, 25vw, 410px);
      font-weight: 900;
    }

    .brand-logo { display: block; width: clamp(260px, 24vw, 390px); height: auto; filter: drop-shadow(0 14px 24px rgba(0,0,0,0.18)); }

    .nav {
      display: flex;
      align-items: center;
      gap: 22px;
      font-size: 14px;
      font-weight: 800;
      color: rgba(255,255,255,0.88);
      white-space: nowrap;
    }

    .nav a { transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease; }
    .nav a:hover { color: #fff; }

    .nav .nav-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      padding: 0 15px;
      border: 1px solid rgba(255,255,255,0.32);
      border-radius: 999px;
      color: #fff;
      background: rgba(255,255,255,0.15);
      box-shadow: 0 10px 24px rgba(0,0,0,0.16);
    }

    .nav .nav-button-campus {
      border-color: transparent;
      background: linear-gradient(135deg, var(--electric), var(--hot));
      box-shadow: 0 14px 30px rgba(252,37,131,0.28);
    }

    .nav .nav-button:hover {
      transform: translateY(-2px);
      border-color: rgba(255,255,255,0.48);
      background: rgba(255,255,255,0.22);
      box-shadow: 0 16px 34px rgba(0,0,0,0.2);
    }

    .nav .nav-button-campus:hover {
      background: linear-gradient(135deg, var(--sky), var(--electric) 42%, var(--hot));
      box-shadow: 0 18px 38px rgba(252,37,131,0.34);
    }

    .top-actions {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .header-spacer {
      flex: 0 0 188px;
      width: 188px;
      height: 1px;
    }

    .municipio-shield {
      position: absolute;
      right: 34px;
      top: 14px;
      z-index: 32;
      flex: 0 0 auto;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 96px;
      height: 112px;
      margin-left: 0;
      padding: 13px;
      border: 1px solid rgba(255,255,255,0.22);
      border-radius: 30px 16px 36px 20px;
      background: rgba(255,255,255,0.12);
      box-shadow: 0 22px 44px rgba(0,0,0,0.22);
      backdrop-filter: blur(16px);
      transform: none;
    }

    .municipio-shield img {
      width: 100%;
      height: 100%;
      max-width: none;
      object-fit: contain;
      filter: drop-shadow(0 12px 20px rgba(0,0,0,0.2));
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 44px;
      padding: 0 17px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: #fff;
      color: var(--carbon);
      font-size: 14px;
      font-weight: 900;
      box-shadow: 0 10px 28px rgba(32,39,39,0.06);
    }

    .btn.primary {
      color: #fff;
      border: 0;
      background: linear-gradient(135deg, var(--electric), var(--hot));
      box-shadow: 0 18px 40px rgba(252, 37, 131, 0.27);
    }

    .btn.dark {
      color: #fff;
      border-color: rgba(255,255,255,0.2);
      background: rgba(255,255,255,0.13);
      box-shadow: none;
    }

    .hero {
      position: relative;
      min-height: 84vh;
      display: grid;
      align-items: end;
      overflow: hidden;
      color: #fff;
      background: var(--carbon);
      border-radius: 0 0 54px 54px;
    }

    .hero-media {
      position: absolute;
      inset: 0;
      overflow: hidden;
    }

    .hero-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: saturate(1.05) contrast(1.02);
      transform: scale(1.02);
    }

    .hero-media img[data-fixed-hero] {
      object-position: center;
    }

    .hero-media::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(8, 15, 24, 0.94) 0%, rgba(6, 61, 118, 0.78) 43%, rgba(252, 37, 131, 0.28) 100%),
        linear-gradient(180deg, rgba(0,0,0,0.36) 0%, rgba(0,0,0,0.08) 40%, rgba(0,0,0,0.72) 100%);
    }

    .hero-glass {
      position: absolute;
      right: -120px;
      top: 110px;
      width: 48vw;
      height: 48vw;
      max-width: 620px;
      max-height: 620px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(85,188,234,0.35), rgba(252,37,131,0.22) 46%, transparent 70%);
      filter: blur(4px);
      animation: unsavGlow 13s ease-in-out infinite alternate;
    }

    .hero-shapes {
      position: absolute;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      overflow: hidden;
    }

    .shape {
      position: absolute;
      display: block;
      border: 1px solid rgba(255,255,255,0.18);
      background: rgba(255,255,255,0.08);
      box-shadow: 0 24px 60px rgba(0,0,0,0.18);
      backdrop-filter: blur(3px);
      animation: unsavFloat 12s ease-in-out infinite;
    }

    .shape.one {
      width: 128px;
      height: 128px;
      right: 14%;
      top: 22%;
      border-radius: 42% 58% 62% 38% / 50% 42% 58% 50%;
      background: linear-gradient(135deg, rgba(85,188,234,0.24), rgba(252,37,131,0.12));
    }

    .shape.two {
      width: 94px;
      height: 94px;
      left: 47%;
      top: 17%;
      border-radius: 28px 18px 36px 20px;
      transform: rotate(18deg);
      animation-delay: -4s;
      background: linear-gradient(135deg, rgba(48,117,243,0.24), rgba(255,255,255,0.1));
    }

    .shape.three {
      width: 180px;
      height: 180px;
      right: 5%;
      bottom: 22%;
      border-radius: 50%;
      animation-delay: -7s;
      background: radial-gradient(circle, rgba(252,37,131,0.22), rgba(85,188,234,0.08) 62%, transparent);
    }

    .shape.four {
      width: 74px;
      height: 74px;
      left: 7%;
      bottom: 28%;
      border-radius: 18px 30px 20px 34px;
      transform: rotate(-12deg);
      animation-delay: -2s;
    }

    @keyframes unsavFloat {
      0%, 100% { translate: 0 0; rotate: 0deg; }
      45% { translate: 20px -28px; rotate: 8deg; }
      70% { translate: -14px 12px; rotate: -5deg; }
    }

    @keyframes unsavGlow {
      0% { transform: translate3d(0, 0, 0) scale(1); opacity: 0.75; }
      100% { transform: translate3d(-44px, 30px, 0) scale(1.08); opacity: 0.95; }
    }

    .hero-content {
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 1280px;
      margin: 0 auto;
      padding: 112px 34px 86px;
    }

    .hero-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.78fr);
      gap: 34px;
      align-items: center;
      transform: translateY(-28px);
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      width: max-content;
      min-height: 30px;
      padding: 0 11px;
      border: 1px solid rgba(255,255,255,0.18);
      border-radius: var(--radius);
      color: #fff;
      background: rgba(255,255,255,0.12);
      font-size: 12px;
      font-weight: 950;
      text-transform: uppercase;
    }

    .dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: var(--hot);
      box-shadow: 0 0 0 5px rgba(252,37,131,0.16);
    }

    h1 {
      max-width: 880px;
      margin: 18px 0 18px;
      font-size: clamp(40px, 5.8vw, 72px);
      line-height: 0.96;
      letter-spacing: 0;
    }

    .hero-lede {
      max-width: 700px;
      margin: 0 0 22px;
      color: rgba(255,255,255,0.8);
      font-size: 20px;
      line-height: 1.5;
    }

    .hero-actions {
      display: none;
    }

    .hero-slider {
      position: relative;
      min-height: 430px;
    }

    .hero-slide {
      position: absolute;
      inset: 0 0 74px 0;
      opacity: 0;
      transform: translateY(18px);
      visibility: hidden;
      pointer-events: none;
      transition: opacity 0.55s ease, transform 0.55s ease;
    }

    .hero-slide.is-active {
      opacity: 1;
      transform: translateY(0);
      visibility: visible;
      pointer-events: auto;
    }

    .slide-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 18px;
      color: rgba(255,255,255,0.7);
      font-size: 13px;
      font-weight: 850;
    }

    .slide-meta span {
      padding: 8px 10px;
      border: 1px solid rgba(255,255,255,0.16);
      border-radius: 999px;
      background: rgba(255,255,255,0.1);
    }

    .hero-dots {
      position: absolute;
      left: 0;
      bottom: 0;
      z-index: 5;
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .hero-dots button {
      width: 44px;
      height: 10px;
      padding: 0;
      border: 0;
      border-radius: 999px;
      cursor: pointer;
      background: rgba(255,255,255,0.25);
      transition: width 0.25s ease, background 0.25s ease;
    }

    .hero-dots button.is-active {
      width: 72px;
      background: linear-gradient(135deg, var(--sky), var(--hot));
    }

    .hero-panel {
      padding: 18px;
      border: 1px solid rgba(255,255,255,0.18);
      border-radius: 34px 20px 42px 24px;
      background: rgba(255,255,255,0.12);
      backdrop-filter: blur(18px);
      box-shadow: 0 18px 42px rgba(0,0,0,0.24);
    }

    .hero-story-card {
      position: relative;
      min-height: 370px;
    }

    .hero-story-image {
      position: absolute;
      right: 18px;
      top: 8px;
      width: min(330px, 66%);
      aspect-ratio: 1.22;
      overflow: hidden;
      border: 1px solid rgba(255,255,255,0.24);
      border-radius: 36px 18px 42px 24px;
      background:
        linear-gradient(135deg, rgba(6,61,118,0.12), rgba(252,37,131,0.08)),
        var(--story-image) center/cover no-repeat;
      background-size: cover;
      background-position: center;
      box-shadow: 0 26px 54px rgba(0,0,0,0.26);
      animation: softFloat 8s ease-in-out infinite 0.8s;
    }

    .hero-story-image img {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      max-width: none;
      object-fit: cover;
      object-position: center;
      display: block;
    }

    .hero-story-image::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 2;
      background: linear-gradient(135deg, rgba(6,61,118,0.08), rgba(252,37,131,0.06));
      pointer-events: none;
    }

    .hero-story-logo {
      position: absolute;
      right: 34px;
      top: 28px;
      z-index: 4;
      display: none;
      width: min(250px, 50%);
      padding: 0;
      pointer-events: none;
    }

    .hero-story-logo.is-visible {
      display: block;
    }

    .hero-story-logo img {
      width: 100%;
      height: auto;
      display: block;
      filter: drop-shadow(0 14px 24px rgba(0,0,0,0.18));
    }

    .hero-story-body {
      position: absolute;
      left: 0;
      top: 116px;
      z-index: 2;
      width: min(292px, 70%);
      padding: 18px;
      border: 1px solid rgba(255,255,255,0.2);
      border-radius: 30px 18px 38px 20px;
      background: rgba(255,255,255,0.14);
      backdrop-filter: blur(18px);
      box-shadow: 0 18px 42px rgba(0,0,0,0.24);
      animation: softFloat 9s ease-in-out infinite 1.1s;
    }

    .hero-story-body strong {
      display: block;
      color: #fff;
      font-size: 20px;
      line-height: 1.1;
      margin: 8px 0;
    }

    .hero-story-body p {
      margin: 0;
      color: rgba(255,255,255,0.72);
      line-height: 1.42;
      font-size: 14px;
    }

    .hero-mini-card {
      position: absolute;
      right: 0;
      bottom: 64px;
      z-index: 3;
      width: 190px;
      min-height: 96px;
      padding: 14px;
      border: 1px solid rgba(255,255,255,0.18);
      border-radius: 26px 16px 32px 18px;
      color: #fff;
      background: linear-gradient(135deg, rgba(48,117,243,0.62), rgba(252,37,131,0.72));
      box-shadow: 0 22px 44px rgba(0,0,0,0.22);
      animation: softFloat 7s ease-in-out infinite 1.4s;
    }

    .hero-mini-card b,
    .hero-campus-card b {
      display: block;
      margin-bottom: 5px;
      font-size: 15px;
      line-height: 1.1;
    }

    .hero-mini-card span,
    .hero-campus-card span {
      display: block;
      color: rgba(255,255,255,0.76);
      font-size: 12px;
      font-weight: 800;
      line-height: 1.3;
    }

    .hero-campus-card {
      position: absolute;
      left: 42px;
      bottom: 10px;
      z-index: 1;
      width: 230px;
      padding: 15px;
      border: 1px solid rgba(255,255,255,0.16);
      border-radius: 24px 34px 18px 30px;
      color: #fff;
      background: rgba(6,61,118,0.28);
      backdrop-filter: blur(16px);
      box-shadow: 0 18px 38px rgba(0,0,0,0.18);
      animation: softFloat 10s ease-in-out infinite 1.7s;
    }

    .hero-story-card.is-entering .hero-story-image {
      animation: cardEnterImage 0.72s cubic-bezier(.2,.8,.2,1) both, softFloat 8s ease-in-out infinite 0.8s;
    }

    .hero-story-card.is-entering .hero-story-logo {
      animation: cardEnterImage 0.72s cubic-bezier(.2,.8,.2,1) 0.04s both;
    }

    .hero-story-card.is-entering .hero-story-body {
      animation: cardEnterText 0.72s cubic-bezier(.2,.8,.2,1) 0.08s both, softFloat 9s ease-in-out infinite 1.1s;
    }

    .hero-story-card.is-entering .hero-mini-card {
      animation: cardEnterMini 0.72s cubic-bezier(.2,.8,.2,1) 0.16s both, softFloat 7s ease-in-out infinite 1.4s;
    }

    .hero-story-card.is-entering .hero-campus-card {
      animation: cardEnterCampus 0.72s cubic-bezier(.2,.8,.2,1) 0.24s both, softFloat 10s ease-in-out infinite 1.7s;
    }

    @keyframes cardEnterImage {
      from { opacity: 0; transform: translate3d(34px, 24px, 0) rotate(3deg) scale(0.94); }
      to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
    }

    @keyframes cardEnterText {
      from { opacity: 0; transform: translate3d(-22px, 28px, 0) rotate(-2deg) scale(0.96); }
      to { opacity: 1; transform: translate3d(0, 0, 0) rotate(0) scale(1); }
    }

    @keyframes cardEnterMini {
      from { opacity: 0; transform: translate3d(28px, 30px, 0) rotate(2deg) scale(0.94); }
      to { opacity: 1; transform: translate3d(0, 0, 0) rotate(0) scale(1); }
    }

    @keyframes cardEnterCampus {
      from { opacity: 0; transform: translate3d(-18px, 26px, 0) rotate(-2deg) scale(0.96); }
      to { opacity: 1; transform: translate3d(0, 0, 0) rotate(0) scale(1); }
    }

    @keyframes softFloat {
      0%, 100% { translate: 0 0; }
      50% { translate: 0 -10px; }
    }

    .panel-title {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 14px;
    }

    .panel-title strong { font-size: 18px; }

    .panel-title span {
      color: var(--sky-2);
      font-size: 12px;
      font-weight: 900;
      text-transform: uppercase;
    }

    .open-card {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 14px;
      align-items: center;
      min-height: 78px;
      padding: 14px;
      border-radius: 30px 18px 38px 22px;
      background: rgba(255,255,255,0.11);
      border: 1px solid rgba(255,255,255,0.16);
    }

    .open-card + .open-card { margin-top: 10px; }

    .open-card b {
      display: block;
      margin-bottom: 4px;
      font-size: 15px;
    }

    .open-card small {
      color: rgba(255,255,255,0.68);
      font-weight: 700;
    }

    .arrow {
      display: grid;
      place-items: center;
      width: 34px;
      height: 34px;
      border-radius: 50%;
      color: #fff;
      background: linear-gradient(135deg, var(--electric), var(--hot));
    }

    .quick-strip {
      position: relative;
      z-index: 4;
      max-width: 1280px;
      margin: -68px auto 0;
      padding: 0 34px;
    }

    .quick-grid {
      display: grid;
      grid-template-columns: repeat(6, 1fr);
      gap: 10px;
    }

    .quick {
      min-height: 116px;
      padding: 16px;
      border-radius: 32px 18px 38px 20px;
      background: #fff;
      border: 1px solid var(--line);
      box-shadow: var(--shadow);
      transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease;
    }

    .quick span {
      display: grid;
      place-items: center;
      width: 34px;
      height: 34px;
      margin-bottom: 13px;
      border-radius: 42% 58% 48% 52% / 50% 44% 56% 50%;
      color: #fff;
      background: linear-gradient(135deg, var(--deep), var(--electric));
      font-weight: 900;
      transition: transform 0.24s ease, box-shadow 0.24s ease;
    }

    .quick:nth-child(2n) span {
      background: linear-gradient(135deg, var(--blue), var(--sky));
    }

    .quick:nth-child(3n) span {
      background: linear-gradient(135deg, var(--electric), var(--hot));
    }

    .quick strong {
      display: block;
      font-size: 14px;
      line-height: 1.2;
    }

    .quick:hover {
      transform: translateY(-6px);
      border-color: rgba(252,37,131,0.24);
      box-shadow: 0 24px 52px rgba(6,61,118,0.16);
      background: linear-gradient(180deg, #fff, rgba(85,188,234,0.08));
    }

    .quick:hover span {
      transform: scale(1.08);
      box-shadow: 0 16px 30px rgba(252,37,131,0.24);
    }

    .section {
      padding: 72px 34px;
    }

    .section.alt {
      background:
        linear-gradient(180deg, #fff, var(--paper));
    }

    .section.dark {
      color: #fff;
      background:
        radial-gradient(circle at 80% 16%, rgba(252,37,131,0.22), transparent 30%),
        radial-gradient(circle at 18% 24%, rgba(85,188,234,0.2), transparent 26%),
        linear-gradient(135deg, var(--carbon), var(--deep));
    }

    .inner {
      max-width: 1280px;
      margin: 0 auto;
    }

    .section-head {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 28px;
      margin-bottom: 24px;
    }

    .kicker {
      color: var(--fuchsia);
      font-size: 12px;
      font-weight: 950;
      text-transform: uppercase;
    }

    .section.dark .kicker { color: var(--sky-2); }

    h2 {
      max-width: 720px;
      margin: 8px 0 0;
      font-size: clamp(32px, 4vw, 54px);
      line-height: 0.98;
      letter-spacing: 0;
    }

    .section-head p {
      max-width: 500px;
      margin: 0;
      color: var(--muted);
      line-height: 1.5;
      font-size: 16px;
    }

    .section.dark .section-head p { color: rgba(255,255,255,0.7); }

    .paths {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
    }

    .path {
      position: relative;
      overflow: hidden;
      min-height: 420px;
      padding: 28px;
      border-radius: var(--radius-organic);
      color: #fff;
      background: linear-gradient(135deg, var(--deep), var(--electric));
      box-shadow: var(--shadow);
    }

    .path::after {
      content: "";
      position: absolute;
      inset: auto -90px -130px auto;
      width: 310px;
      height: 310px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(255,255,255,0.3), transparent 68%);
    }

    .path.student {
      background: linear-gradient(135deg, var(--carbon), var(--deep) 48%, var(--hot));
    }

    .path h3 {
      position: relative;
      z-index: 1;
      max-width: 540px;
      margin: 16px 0 12px;
      font-size: 38px;
      line-height: 1;
      letter-spacing: 0;
    }

    .path p {
      position: relative;
      z-index: 1;
      max-width: 540px;
      color: rgba(255,255,255,0.76);
      line-height: 1.55;
    }

    .path-links {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      margin-top: 26px;
    }

    .path-links a {
      min-height: 58px;
      display: flex;
      align-items: center;
      padding: 0 13px;
      border-radius: 28px 18px 34px 20px;
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.18);
      font-weight: 850;
      font-size: 14px;
    }

    .offer-layout {
      display: grid;
      grid-template-columns: 300px minmax(0, 1fr);
      gap: 18px;
    }

    .filters,
    .offer,
    .news,
    .service {
      border-radius: 34px 20px 42px 24px;
      background: #fff;
      border: 1px solid var(--line);
      box-shadow: 0 14px 34px rgba(32,39,39,0.07);
    }

    .filters {
      padding: 20px;
      background:
        linear-gradient(180deg, #fff, rgba(85,188,234,0.08));
    }

    .filters strong {
      display: block;
      margin-bottom: 14px;
      font-size: 18px;
    }

    .filter-pill {
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 44px;
      margin-top: 10px;
      padding: 0 12px;
      border-radius: 999px;
      background: var(--paper);
      color: var(--carbon-2);
      font-size: 13px;
      font-weight: 850;
    }

    .offers {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
    }

    .offer {
      min-height: 250px;
      padding: 20px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .offer-media {
      min-height: 124px;
      margin: -4px -4px 16px;
      border-radius: 28px 16px 34px 18px;
      background:
        linear-gradient(135deg, rgba(6,61,118,0.18), rgba(252,37,131,0.12)),
        var(--offer-image) center/cover no-repeat;
      background-size: cover;
      background-position: center;
      box-shadow: inset 0 0 0 1px rgba(255,255,255,0.34);
      position: relative;
      overflow: hidden;
    }

    .offer-media img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      max-width: none;
      object-fit: cover;
      object-position: center;
      display: block;
    }

    .tag {
      display: inline-flex;
      align-items: center;
      width: max-content;
      min-height: 27px;
      padding: 0 10px;
      border-radius: 999px;
      color: var(--deep);
      background: rgba(85,188,234,0.18);
      font-size: 11px;
      font-weight: 950;
      text-transform: uppercase;
    }

    .tag.hot {
      color: #fff;
      background: linear-gradient(135deg, var(--electric), var(--hot));
    }

    .offer h3,
    .news h3,
    .service h3 {
      margin: 14px 0 10px;
      font-size: 22px;
      line-height: 1.08;
      letter-spacing: 0;
    }

    .offer p,
    .news p,
    .service p {
      margin: 0;
      color: var(--muted);
      line-height: 1.48;
      font-size: 14px;
    }

    .meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 18px;
      color: var(--muted);
      font-size: 12px;
      font-weight: 850;
    }

    .meta span {
      padding: 7px 9px;
      border-radius: var(--radius);
      background: var(--paper);
    }

    .territory {
      display: grid;
      grid-template-columns: 0.95fr 1.05fr;
      gap: 22px;
      align-items: stretch;
    }

    .territory-copy {
      padding: 28px;
      border-radius: 46px 24px 54px 26px;
      background:
        linear-gradient(135deg, rgba(255,255,255,0.13), rgba(255,255,255,0.07));
      border: 1px solid rgba(255,255,255,0.16);
    }

    .territory-copy p {
      color: rgba(255,255,255,0.72);
      line-height: 1.55;
    }

    .territory-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .territory-card {
      min-height: 170px;
      padding: 18px;
      border-radius: 30px 18px 38px 20px;
      border: 1px solid rgba(255,255,255,0.16);
      background: rgba(255,255,255,0.1);
    }

    .territory-card b {
      display: block;
      margin-bottom: 8px;
      font-size: 18px;
    }

    .territory-card span {
      color: rgba(255,255,255,0.68);
      line-height: 1.4;
    }

    .news-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
    }

    .news.feature {
      grid-column: span 2;
    }

    .news {
      overflow: hidden;
      border-radius: 34px 20px 42px 24px;
      animation: newsEnter 0.68s cubic-bezier(.2,.8,.2,1) both;
      transition: transform 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
    }

    .news:hover {
      transform: translateY(-8px);
      border-color: rgba(252,37,131,0.24);
      box-shadow: 0 24px 56px rgba(42,57,65,0.14);
    }

    .news:nth-child(2) { animation-delay: 0.08s; }
    .news:nth-child(3) { animation-delay: 0.14s; }
    .news:nth-child(4) { animation-delay: 0.2s; }
    .news:nth-child(5) { animation-delay: 0.26s; }
    .news:nth-child(6) { animation-delay: 0.32s; }

    .news-img {
      min-height: 170px;
      background:
        linear-gradient(135deg, rgba(6,61,118,0.14), rgba(252,37,131,0.08)),
        var(--news-image, url("../universidad-sv.jpg")) center/cover no-repeat;
      background-color: var(--deep);
      background-size: cover;
      background-position: center;
      position: relative;
      overflow: hidden;
      transition: transform 0.42s ease, filter 0.42s ease;
    }

    .news-img img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      max-width: none;
      object-fit: cover;
      object-position: center;
      display: block;
    }

    .news-img::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(6,61,118,0.08), rgba(252,37,131,0.05));
      pointer-events: none;
    }

    .news:hover .news-img {
      transform: scale(1.035);
      filter: saturate(1.08) contrast(1.03);
    }

    .news.feature .news-img { min-height: 260px; }

    .news-body { padding: 18px; }

    .news-more {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      margin-top: 16px;
      padding: 0 14px;
      border-radius: 999px;
      color: #fff;
      background: linear-gradient(135deg, var(--deep), var(--electric) 58%, var(--hot));
      font-size: 13px;
      font-weight: 900;
      box-shadow: 0 12px 26px rgba(48,117,243,0.18);
    }

    @keyframes newsEnter {
      from { opacity: 0; transform: translate3d(0, 22px, 0) scale(0.98); }
      to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
    }

    .services {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
    }

    .service {
      min-height: 190px;
      padding: 20px;
      border-radius: 34px 20px 42px 24px;
    }

    .service-icon {
      display: grid;
      place-items: center;
      width: 42px;
      height: 42px;
      border-radius: 42% 58% 48% 52% / 50% 44% 56% 50%;
      color: #fff;
      background: linear-gradient(135deg, var(--deep), var(--electric) 56%, var(--hot));
      font-weight: 900;
    }

    .footer {
      color: rgba(255,255,255,0.74);
      background: var(--carbon);
      padding: 34px;
    }

    .footer-inner {
      max-width: 1280px;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      gap: 24px;
    }

    .footer strong {
      display: block;
      color: #fff;
      margin-bottom: 8px;
    }

    @media (max-width: 1120px) {
      .nav { display: none; }
      .hero-grid,
      .offer-layout,
      .territory { grid-template-columns: 1fr; }
      .quick-grid { grid-template-columns: repeat(3, 1fr); }
      .offers,
      .services { grid-template-columns: repeat(2, 1fr); }
      .news-grid { grid-template-columns: 1fr 1fr; }
      .news.feature { grid-column: span 2; }
    }

    @media (max-width: 740px) {
      .topbar { padding: 0 16px; }
      .brand { min-width: 0; }
      .brand-logo { width: 190px; }
      .municipio-shield {
        width: 70px;
        height: 84px;
        right: 16px;
        top: 10px;
        margin-left: 0;
        padding: 10px;
        border-radius: 22px 12px 26px 14px;
        transform: none;
      }
      .top-actions .btn.dark { display: none; }
      .hero-content { padding: 104px 16px 72px; }
      h1 { font-size: 38px; }
      .hero-lede { font-size: 17px; }
      .hero-slider { min-height: 400px; }
      .hero-slide { inset: 0 0 76px 0; }
      .hero-grid { transform: translateY(-18px); }
      .hero-story-card { min-height: 330px; }
      .hero-story-image {
        right: 0;
        top: 10px;
        width: 68%;
        min-height: 0;
      }
      .hero-story-logo {
        right: 10px;
        top: 24px;
        width: 58%;
      }
      .hero-story-body {
        top: 102px;
        width: 72%;
        padding: 15px;
      }
      .hero-mini-card {
        right: 6px;
        bottom: 38px;
        width: 164px;
      }
      .hero-campus-card {
        left: 4px;
        bottom: 0;
        width: 196px;
      }
      .quick-strip,
      .section,
      .footer { padding-left: 16px; padding-right: 16px; }
      .quick-grid,
      .paths,
      .path-links,
      .offers,
      .territory-grid,
      .news-grid,
      .services {
        grid-template-columns: 1fr;
      }
      .news.feature { grid-column: span 1; }
      .section-head { display: block; }
      .path { min-height: auto; }
      .footer-inner { display: block; }
    }
