/* ==========================================================================
   EPO224 · Identidad institucional del portal
   ========================================================================== */

:root[data-theme="default"] {
  --organization-name: "EPO224";
  --bg-main: #f8fafc;
  --bg-card: #ffffff;
  --bg-muted: #f1f5f9;
  --bg-elevated: rgba(255, 255, 255, .9);
  --bg-hero: radial-gradient(circle at 8% 8%, rgba(2, 56, 89, .16), transparent 28%), radial-gradient(circle at 88% 12%, rgba(11, 122, 97, .15), transparent 24%), radial-gradient(circle at 76% 72%, rgba(234, 179, 8, .12), transparent 22%), linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  --text-primary: #0f172a;
  --text-secondary: #334155;
  --text-muted: #64748b;
  --text-inverse: #ffffff;
  --text-link: #023859;
  --color-primary: #023859;
  --color-primary-hover: #01243a;
  --color-secondary: #0b7a61;
  --color-secondary-hover: #085c49;
  --color-accent: #eab308;
  --color-accent-hover: #ca8a04;
  --color-accent-muted: #fef3c7;
  --border-default: #e2e8f0;
  --border-strong: #cbd5e1;
  --border-soft: rgba(203, 213, 225, .78);
  --shadow-sm: 0 1px 3px rgba(15, 23, 42, .03), 0 1px 2px rgba(15, 23, 42, .06);
  --shadow-md: 0 10px 28px rgba(15, 23, 42, .09);
  --shadow-brand: 0 28px 80px rgba(2, 56, 89, .17);
  --focus-ring-color: rgba(11, 122, 97, .46);
}

.navbar,
.navbar-brand,
.nav-link,
.dropdown-toggle,
.nav-control,
.language-switcher,
.theme-switcher,
.a11y-switcher,
.site-header .utility-select-button,
.site-header .a11y-toggle {
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
}

.site-header .container-shell {
  max-width: min(1480px, calc(100vw - 32px));
}

.navbar-brand img {
  display: block;
  width: auto;
  max-width: 176px;
  height: auto;
  max-height: 64px;
  object-fit: contain;
}

.navbar-brand .brand-text {
  display: grid;
  line-height: 1.02;
  margin-inline-start: .75rem;
  color: var(--text-primary);
}

.navbar-brand .brand-title {
  font-weight: 900;
  letter-spacing: -.02em;
}

.navbar-brand .brand-subtitle {
  font-size: .78rem;
  color: var(--text-secondary);
  font-weight: 750;
}

@media (max-width: 575.98px) {
  .navbar-brand img { max-width: 64px; max-height: 56px; }
  .navbar-brand .brand-subtitle { display: none; }
}

.site-header .dropdown-menu {
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.site-header .dropdown-item {
  border-radius: .75rem;
  font-weight: 720;
}

.school-hero {
  position: relative;
  padding-block: clamp(7rem, 11vw, 10rem) clamp(4rem, 7vw, 6.5rem);
}

.school-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(120deg, color-mix(in srgb, var(--color-primary), transparent 94%) 0 1px, transparent 1px), linear-gradient(30deg, color-mix(in srgb, var(--color-secondary), transparent 95%) 0 1px, transparent 1px);
  background-size: 58px 58px;
  mask-image: linear-gradient(180deg, #000 0%, transparent 82%);
  opacity: .72;
}

.school-hero > .container-shell {
  position: relative;
}

.hero-title,
.page-title {
  max-inline-size: 13ch;
}

.hero-copy,
.page-copy {
  max-inline-size: 64ch;
}

.logo-orb {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(20rem, 42vw, 34rem);
  border: 1px solid color-mix(in srgb, var(--color-primary), transparent 84%);
  border-radius: clamp(1.5rem, 3vw, 2.25rem);
  background: radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--color-secondary), transparent 84%), transparent 34%), linear-gradient(145deg, color-mix(in srgb, var(--bg-card), transparent 4%), color-mix(in srgb, var(--bg-muted), transparent 6%));
  box-shadow: var(--shadow-brand);
  overflow: hidden;
  isolation: isolate;
}

.logo-orb::before,
.logo-orb::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(34px);
  z-index: -1;
}

.logo-orb::before {
  width: 12rem;
  height: 12rem;
  background: color-mix(in srgb, var(--color-primary), transparent 72%);
  top: -3rem;
  right: -2rem;
}

.logo-orb::after {
  width: 10rem;
  height: 10rem;
  background: color-mix(in srgb, var(--color-accent), transparent 70%);
  bottom: -2rem;
  left: -1rem;
}

.logo-orb img {
  width: min(62%, 19rem);
  filter: drop-shadow(0 24px 34px rgba(15, 23, 42, .22));
}

.portal-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-block-start: 1.25rem;
}

.portal-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border: 1px solid color-mix(in srgb, var(--color-primary), transparent 84%);
  background: var(--bg-elevated);
  border-radius: var(--radius-pill);
  color: var(--text-primary);
  font-weight: 800;
  padding: .55rem .85rem;
  box-shadow: var(--shadow-sm);
}

.school-band {
  border-block: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--color-primary), transparent 96%);
}

.info-card,
.link-card {
  height: 100%;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-xl);
  background: var(--bg-card);
  box-shadow: var(--shadow-sm);
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
}

.info-card h3,
.link-card h3 {
  font-size: clamp(1.1rem, 1.4vw, 1.35rem);
  font-weight: 900;
  margin-block-end: .75rem;
}

.info-card p,
.link-card p {
  color: var(--text-secondary);
  margin-block-end: 0;
}

.link-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-decoration: none;
  color: inherit;
  transition: transform var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard), border-color var(--motion-base) var(--ease-standard);
}

.link-card:hover,
.link-card:focus-visible {
  color: inherit;
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--color-secondary), transparent 60%);
}

.link-card .card-arrow {
  margin-block-start: auto;
  color: var(--color-primary);
  font-weight: 900;
}

.icon-badge.epo {
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  color: var(--text-inverse);
}

.page-hero {
  padding-block: clamp(7rem, 10vw, 9rem) clamp(3rem, 6vw, 5rem);
  background: var(--bg-hero);
  border-block-end: 1px solid var(--border-soft);
}

.breadcrumb-school {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  color: var(--text-muted);
  font-weight: 750;
  margin-block-end: 1rem;
}

.breadcrumb-school a {
  color: var(--color-primary);
  text-decoration: none;
}

.content-flow > * + * {
  margin-block-start: 1rem;
}

.resource-list {
  display: grid;
  gap: .75rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.resource-list li {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  padding: .85rem 1rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-muted), transparent 18%);
  color: var(--text-secondary);
}

.resource-list .mark {
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-secondary), transparent 85%);
  color: var(--color-secondary);
  font-weight: 900;
}

.cta-school {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  color: var(--text-inverse);
  padding: clamp(1.5rem, 4vw, 3rem);
  box-shadow: var(--shadow-brand);
}

.cta-school p {
  color: color-mix(in srgb, var(--text-inverse), transparent 12%);
}

.footer-brand img {
  width: auto;
  max-width: 138px;
  max-height: 96px;
  object-fit: contain;
}

.footer a {
  color: inherit;
}

@media (min-width: 992px) {
  .site-header .navbar-nav {
    flex-wrap: nowrap;
  }
}

@media (max-width: 991.98px) {
  .site-header .navbar-nav {
    align-items: stretch !important;
  }

  .site-header .nav-link,
  .site-header .dropdown-toggle {
    justify-content: flex-start;
  }
}
