/*
  zero2hero unified foundation (phase 1)
  - Shared visual system for public, user and admin views.
  - Keeps functional JS/HTML contracts intact.
*/

:root {
  --u-bg: #f3f6fb;
  --u-surface: #ffffff;
  --u-surface-soft: #f8fafc;
  --u-text: #0f172a;
  --u-muted: #64748b;
  --u-border: #dbe5f1;
  --u-border-strong: #c8d7ea;
  --u-primary: #2563eb;
  --u-primary-strong: #1d4ed8;
  --u-primary-soft: #eaf2ff;
  --u-success-soft: #e8f8ee;
  --u-danger-soft: #feeceb;
  --u-radius-sm: 10px;
  --u-radius-md: 14px;
  --u-radius-lg: 18px;
  --u-shadow-sm: 0 8px 20px rgba(15, 23, 42, 0.04);
  --u-shadow-md: 0 18px 34px rgba(15, 23, 42, 0.08);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body.z2h-body {
  margin: 0;
  background: radial-gradient(1200px 460px at 8% -12%, rgba(37, 99, 235, 0.08), transparent 60%),
    radial-gradient(1000px 420px at 92% -8%, rgba(14, 165, 233, 0.07), transparent 58%),
    var(--u-bg);
  color: var(--u-text);
  font-family: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  line-height: 1.55;
  min-height: 100vh;
}

#main {
  padding-top: 2rem !important;
  padding-bottom: 3.25rem !important;
}

.container {
  max-width: 1140px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--u-text);
  letter-spacing: -0.01em;
}

p,
small,
label,
li,
dt,
dd {
  color: inherit;
}

a {
  color: var(--u-primary);
  text-decoration: none;
}

a:hover {
  color: var(--u-primary-strong);
}

.text-muted {
  color: var(--u-muted) !important;
}

.text-uppercase.small,
.small.text-uppercase {
  letter-spacing: 0.08em;
}

/* Base controls */
.btn {
  border-radius: var(--u-radius-sm);
  font-weight: 700;
  letter-spacing: 0.01em;
  min-height: 40px;
  border-width: 1px;
}

.btn-primary,
.btn-cta,
.z2h-nav-pill--primary {
  background: linear-gradient(135deg, var(--u-primary), var(--u-primary-strong));
  border-color: var(--u-primary);
  color: #fff !important;
}

.btn-primary:hover,
.btn-cta:hover,
.z2h-nav-pill--primary:hover {
  background: linear-gradient(135deg, #3b82f6, var(--u-primary-strong));
  border-color: var(--u-primary-strong);
  color: #fff !important;
}

.btn-outline-secondary,
.btn-ghost,
.btn-owa-outline,
.z2h-nav-pill--ghost {
  background: var(--u-surface);
  color: var(--u-text) !important;
  border-color: var(--u-border-strong);
}

.btn-outline-secondary:hover,
.btn-ghost:hover,
.btn-owa-outline:hover,
.z2h-nav-pill--ghost:hover {
  background: #f1f5fb;
  border-color: #b7cae2;
  color: var(--u-text) !important;
}

.btn-link {
  color: var(--u-primary);
  font-weight: 700;
}

.form-control,
.form-select,
.input-group-text {
  border-color: var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fff;
  color: var(--u-text);
}

.input-group > .form-control:not(:first-child),
.input-group > .form-select:not(:first-child) {
  border-top-left-radius: var(--u-radius-sm);
  border-bottom-left-radius: var(--u-radius-sm);
}

.form-control:focus,
.form-select:focus,
.btn:focus-visible,
.form-check-input:focus {
  border-color: #93c5fd;
  box-shadow: 0 0 0 0.24rem rgba(37, 99, 235, 0.14);
}

.card,
.admin-card,
.student-panel,
.student-card,
.z2h-contact-card,
.sem-panel {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  box-shadow: var(--u-shadow-sm);
  background: var(--u-surface);
}

.card .card-header {
  background: transparent;
  border-bottom: 1px solid var(--u-border);
}

.badge {
  border-radius: 999px;
  font-weight: 700;
}

.admin-pill {
  background: var(--u-primary-soft) !important;
  color: #1e40af !important;
  border-color: #c5d9f6 !important;
}

.list-group-item {
  border-color: var(--u-border);
  background: #fff;
}

.table {
  --bs-table-bg: transparent;
}

.table > :not(caption) > * > * {
  border-bottom-color: var(--u-border);
}

.alert {
  border-radius: var(--u-radius-sm);
  border: 1px solid var(--u-border);
}

.alert-info {
  background: #eef7ff;
}

.alert-danger {
  background: #fff1f2;
}

/* Navbar */
.z2h-nav {
  position: sticky;
  top: 0;
  z-index: 1040;
  background: rgba(255, 255, 255, 0.94) !important;
  border-bottom: 1px solid var(--u-border);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
  backdrop-filter: blur(10px);
}

.z2h-nav::after {
  display: none !important;
}

.z2h-nav .z2h-nav-shell {
  align-items: center;
  gap: 1rem;
  padding-top: 0.58rem;
  padding-bottom: 0.58rem;
}

.z2h-brand--pro {
  display: inline-flex;
  align-items: center;
  gap: 0.66rem;
  text-decoration: none;
}

.z2h-brand__glyph {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  border: 0;
  color: #1e3a8a;
  background: transparent;
  font-weight: 800;
}

.z2h-brand__glyph .fa-rocket {
  font-size: 1.18rem;
  transform: translateY(-0.5px) rotate(-8deg);
}

.z2h-brand__copy {
  display: flex;
  flex-direction: column;
  line-height: 1.08;
}

.z2h-brand__name {
  color: var(--u-text);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: -0.01em;
}

.z2h-brand__meta {
  color: var(--u-muted);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.z2h-nav .z2h-nav-main {
  align-items: center;
  gap: 0.2rem;
}

.z2h-nav .z2h-nav-main .nav-link {
  color: var(--u-muted);
  border: 1px solid transparent;
  border-radius: 9px;
  font-weight: 700;
  font-size: 0.92rem;
  padding: 0.48rem 0.78rem;
  transform: none !important;
}

.z2h-nav .z2h-nav-main .nav-link:hover {
  color: var(--u-text);
  background: #eff6ff;
  border-color: #d7e5f8;
}

.z2h-nav .z2h-nav-main .nav-link.is-current {
  color: #1e40af;
  background: #eaf2ff;
  border-color: #c8daf6;
}

.z2h-nav .z2h-nav-main .nav-link[aria-current="page"] {
  color: #1e40af;
  background: #eaf2ff;
  border-color: #c8daf6;
}

.z2h-nav .nav-link:not(.dropdown-toggle)::after {
  display: none !important;
}

.z2h-nav .z2h-nav-main .dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.z2h-nav .z2h-nav-main .dropdown-toggle::after {
  display: inline-block !important;
  margin-left: 0.1rem;
  vertical-align: 0.12em;
  transition: transform 0.22s ease;
}

.z2h-nav .z2h-nav-main .dropdown.show > .dropdown-toggle::after {
  transform: rotate(180deg);
}

.z2h-nav .z2h-nav-main .dropdown-menu {
  margin-top: 0.4rem;
  border: 1px solid var(--u-border);
  border-radius: 12px;
  padding: 0.35rem;
  min-width: 220px;
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.12);
}

.z2h-nav .z2h-nav-main .dropdown-item {
  border-radius: 9px;
  padding: 0.48rem 0.65rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--u-text);
}

.z2h-nav .z2h-nav-main .dropdown-item:hover,
.z2h-nav .z2h-nav-main .dropdown-item:focus-visible {
  color: var(--u-text);
  background: #eff6ff;
}

.z2h-nav .z2h-nav-main .dropdown-item.is-current,
.z2h-nav .z2h-nav-main .dropdown-item[aria-current="page"] {
  color: #1e40af;
  background: #eaf2ff;
}

.z2h-nav .z2h-nav-actions {
  display: flex;
  align-items: center;
  gap: 0.48rem;
  margin-left: 0.85rem;
}

.z2h-nav .z2h-nav-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-height: 38px;
  padding: 0.45rem 0.95rem;
  font-size: 0.88rem;
}

.z2h-nav-toggler {
  border: 0;
  border-radius: 10px;
  background: transparent;
  box-shadow: none;
}

.z2h-nav .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 16 16'%3E%3Cpath stroke='%230f172a' stroke-width='1.7' stroke-linecap='round' d='M2 4h12M2 8h12M2 12h12'/%3E%3C/svg%3E");
}

.z2h-nav-mobile-meta {
  display: none;
}

/* Shared surface wrappers */
.z2h-hero-slim,
.z2h-home-hero,
.student-hero,
.z2h-contact-hero,
.z2h-devs-showcase,
.z2h-semillero-stars,
.sem-roadmap,
.z2h-pillar,
.z2h-team-card,
.sem-star-card,
.program-card,
.z2h-tile,
.z2h-case {
  background: var(--u-surface) !important;
  border: 1px solid var(--u-border) !important;
  border-radius: var(--u-radius-lg) !important;
  box-shadow: var(--u-shadow-sm) !important;
  color: var(--u-text) !important;
}

.z2h-hero-slim::before,
.student-hero::after,
.z2h-home-hero::before,
.z2h-home-hero__bg,
.z2h-pillar__bg,
.sem-hero__bg,
.student-hero__bg {
  display: none !important;
}

.z2h-home .z2h-home-hero.z2h-hero-full {
  margin-top: 0 !important;
  padding: 1.75rem 1rem !important;
  min-height: auto !important;
}

.z2h-home .z2h-home-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr);
  gap: 1rem;
  align-items: stretch;
}

.z2h-home .z2h-home-hero__title {
  font-size: clamp(1.75rem, 4.4vw, 2.8rem);
  line-height: 1.08;
  max-width: 18ch;
}

.z2h-home .z2h-home-hero__line,
.z2h-home .z2h-home-hero__line--scroll {
  color: var(--u-text) !important;
  background: none !important;
  -webkit-text-fill-color: currentcolor !important;
}

.z2h-home .z2h-home-hero__lead {
  color: var(--u-muted) !important;
  max-width: 62ch;
}

.z2h-home .z2h-home-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.z2h-link-underline {
  font-weight: 700;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.z2h-home .z2h-home-hero__panel {
  display: grid;
  gap: 0.65rem;
}

.z2h-home .z2h-home-hero__mini-card {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  padding: 0.9rem;
  background: var(--u-surface-soft);
}

.z2h-home .z2h-home-hero__tags span,
.z2h-hero-chip,
.z2h-chip,
.z2h-pill,
.chip,
.chip-soft,
.chip-ghost,
.pill,
.meta-pill,
.student-mail,
.student-hero__tag,
.z2h-case__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border-radius: 999px;
  border: 1px solid #d4e1f2;
  background: #f4f8ff;
  color: #1e3a8a;
  padding: 0.28rem 0.66rem;
  font-size: 0.76rem;
  font-weight: 700;
}

.z2h-subtle {
  color: var(--u-muted);
}

.letter-spaced {
  letter-spacing: 0.08em;
}

.z2h-home .z2h-home-hero__eyebrow,
.z2h-hero-slim__eyebrow,
.student-eyebrow,
.z2h-eyebrow,
.sem-section-eyebrow,
.sem-roadmap__eyebrow {
  color: #1e3a8a !important;
  font-size: 0.74rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  margin-bottom: 0.42rem !important;
}

.z2h-pillar {
  padding: 1rem;
}

.z2h-pillar__title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--u-text);
}

.z2h-pillar__sub {
  margin: 0.35rem 0 0.55rem;
  color: var(--u-muted);
}

.z2h-pillar__meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.z2h-pillar__meta > div {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #f8fbff;
  padding: 0.45rem 0.5rem;
}

.z2h-meta__big {
  font-size: 1.05rem;
  font-weight: 800;
  color: #1e3a8a;
  line-height: 1.2;
}

.z2h-meta__label {
  font-size: 0.76rem;
  color: var(--u-muted);
}

.z2h-pillar__actions {
  margin-top: 0.75rem;
}

.z2h-case-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.z2h-devs-showcase {
  padding: 1rem;
}

.z2h-case__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
}

.z2h-case__client {
  color: var(--u-muted);
  font-size: 0.82rem;
}

.z2h-case__title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 800;
}

.z2h-case__desc {
  margin: 0.4rem 0 0.55rem;
  color: var(--u-muted);
  font-size: 0.9rem;
}

.z2h-case__footer {
  padding-top: 0.25rem;
  border-top: 1px solid var(--u-border);
}

.z2h-communities {
  padding: 1rem;
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-lg);
  background: var(--u-surface);
  box-shadow: var(--u-shadow-sm);
}

.z2h-comm-rail {
  display: grid;
  gap: 0.55rem;
}

.z2h-comm-item {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fff;
  overflow: hidden;
}

.z2h-comm-toggle {
  width: 100%;
  border: 0;
  background: #f8fbff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
  padding: 0.8rem 0.9rem;
}

.z2h-comm-name {
  font-weight: 700;
  color: var(--u-text);
}

.z2h-comm-plus {
  width: 16px;
  height: 16px;
  position: relative;
  flex: 0 0 auto;
}

.z2h-comm-plus::before,
.z2h-comm-plus::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 11px;
  height: 1px;
  background: #334155;
  transform: translate(-50%, -50%);
}

.z2h-comm-plus::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.z2h-comm-item.is-open .z2h-comm-plus::after {
  display: none;
}

.z2h-comm-panel {
  display: none;
  padding: 0.85rem 0.9rem;
  border-top: 1px solid var(--u-border);
}

.z2h-comm-item.is-open .z2h-comm-panel {
  display: block;
}

.z2h-comm-text {
  margin: 0 0 0.55rem;
  color: var(--u-muted);
}

.z2h-comm-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.45rem;
}

.z2h-comm-badge {
  display: inline-flex;
  border: 1px solid var(--u-border);
  border-radius: 999px;
  background: #f8fbff;
  color: #1e3a8a;
  padding: 0.2rem 0.6rem;
  font-size: 0.73rem;
  font-weight: 700;
}

.z2h-comm-badge--accent {
  background: #e9f7ef;
  border-color: #bde4cb;
  color: #166534;
}

.z2h-featured {
  padding: 1rem;
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-lg);
  background: var(--u-surface);
  box-shadow: var(--u-shadow-sm);
}

.z2h-filters {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-lg);
}

.z2h-searchgroup .input-group-text {
  border-right: 0;
  background: #f8fbff;
}

.z2h-searchgroup .form-control {
  border-left: 0;
}

.z2h-searchgroup .btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.z2h-clearlink {
  font-size: 0.9rem;
}

.z2h-tile {
  display: block;
  overflow: hidden;
}

.z2h-tile__media {
  position: relative;
  min-height: 190px;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
}

.z2h-tile__media-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.08), rgba(15, 23, 42, 0.28));
}

.z2h-tile__top {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  padding: 0.75rem 0.75rem 0;
}

.z2h-tile__content {
  padding: 0.9rem;
}

.z2h-tile__title {
  margin: 0;
  font-size: 1.03rem;
  font-weight: 800;
  color: var(--u-text);
}

.z2h-tile__desc {
  margin: 0.45rem 0 0.62rem;
  color: var(--u-muted);
  font-size: 0.9rem;
}

.z2h-tile__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.55rem;
}

.z2h-meta-pill {
  display: inline-flex;
  border: 1px solid var(--u-border);
  border-radius: 999px;
  padding: 0.2rem 0.56rem;
  font-size: 0.72rem;
  color: #1e3a8a;
  background: #f8fbff;
  font-weight: 700;
}

.z2h-tile__shine {
  display: none;
}

.z2h-consult {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-lg);
  background: var(--u-surface);
  box-shadow: var(--u-shadow-sm);
  padding: 1rem;
}

.z2h-consult__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.95fr);
  gap: 1rem;
}

.z2h-consult__title {
  margin: 0;
  font-size: 1.4rem;
}

.z2h-consult__desc,
.z2h-consult__note {
  color: var(--u-muted);
}

.z2h-consult__list {
  margin: 0.4rem 0 0.7rem;
  padding-left: 1rem;
}

.z2h-consult__list li {
  margin: 0.3rem 0;
}

.z2h-gradient-tile {
  background: var(--u-surface) !important;
  border: 1px solid var(--u-border) !important;
  border-radius: var(--u-radius-lg) !important;
  box-shadow: var(--u-shadow-sm) !important;
}

.z2h-gradient-tile .card {
  border: 1px solid var(--u-border);
  box-shadow: none;
}

.z2h-contact__title {
  margin: 0;
}

.z2h-contact__sub {
  margin: 0.45rem 0 0;
  color: var(--u-muted);
}

.z2h-team-name {
  margin: 0.65rem 0 0.25rem;
  font-size: 1rem;
  font-weight: 800;
}

.z2h-team-role {
  margin: 0;
  color: var(--u-muted);
}

.z2h-social-ico {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: #cbdcf1;
}

.z2h-social-ico.i--linkedin {
  background: #0a66c2;
}

.z2h-social-ico.i--twitter {
  background: #0f172a;
}

.z2h-social-ico.i--youtube {
  background: #dc2626;
}

.z2h-social-ico.i--instagram {
  background: #db2777;
}

.z2h-social-ico.i--whatsapp {
  background: #16a34a;
}

.z2h-instructors-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.z2h-instructors-grid--single {
  grid-template-columns: minmax(0, 420px);
}

.z2h-instructor-card {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: #fff;
  box-shadow: var(--u-shadow-sm);
  overflow: hidden;
}

.z2h-instructor-media img {
  width: 100%;
  height: 190px;
  object-fit: cover;
  border-bottom: 1px solid var(--u-border);
}

.z2h-instructor-placeholder {
  width: 100%;
  height: 190px;
  display: grid;
  place-items: center;
  background: #f1f5fb;
  border-bottom: 1px solid var(--u-border);
}

.z2h-instructor-body {
  padding: 0.8rem;
}

.z2h-instructor-name {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
}

.z2h-instructor-bio {
  margin: 0.35rem 0 0;
  color: var(--u-muted);
}

.z2h-enroll-card {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-lg);
  box-shadow: var(--u-shadow-sm);
}

.z2h-steps li {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  margin-bottom: 0.7rem;
}

.z2h-step-index {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--u-primary-soft);
  color: #1d4ed8;
  font-size: 0.78rem;
  font-weight: 800;
  flex: 0 0 auto;
}

.z2h-step-content h3 {
  margin: 0;
  font-size: 1rem;
}

.z2h-step-content p {
  margin: 0.3rem 0 0;
  color: var(--u-muted);
}

.z2h-note {
  border-top: 1px dashed var(--u-border-strong);
  padding-top: 0.65rem;
  color: var(--u-muted);
}

.sem-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
  margin-bottom: 1rem;
}

.sem-list li {
  margin: 0.25rem 0;
}

.sem-roadmap__head {
  margin-bottom: 0.75rem;
}

.sem-roadmap__title {
  margin: 0;
  font-size: 1.2rem;
}

.sem-roadmap__stack {
  display: grid;
  gap: 0.55rem;
}

.sem-roadmap__month {
  font-size: 0.78rem;
  color: #1e40af;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.sem-roadmap__block-title {
  display: block;
  margin-top: 0.12rem;
  font-weight: 700;
}

.sem-roadmap__label {
  font-size: 0.78rem;
  color: var(--u-muted);
  margin-bottom: 0.3rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sem-roadmap__list {
  margin: 0;
  padding-left: 1rem;
}

.sem-roadmap__list li {
  margin: 0.2rem 0;
}

.sem-roadmap__project-title {
  font-weight: 700;
}

.sem-roadmap__project-desc {
  margin: 0.3rem 0 0;
  color: var(--u-muted);
}

.student-hero__content,
.z2h-hero-slim__body,
.z2h-contact-hero__body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem 1.35rem;
}

.student-hero__actions,
.z2h-hero-slim__actions,
.z2h-contact__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.student-panel__header,
.student-panel__body {
  padding: 1rem 1.1rem;
}

.student-panel__header {
  border-bottom: 1px solid var(--u-border);
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: flex-start;
}

.student-panel__header--tight {
  align-items: center;
}

.student-step {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  margin-bottom: 0.45rem;
}

.student-step__index {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--u-primary-soft);
  color: #1e40af;
  font-size: 0.75rem;
  font-weight: 800;
  flex: 0 0 auto;
}

.content-kind-card.active {
  border-color: #9cc0fa !important;
  background: #eff6ff !important;
}

.content-kind-count--full {
  background: #dbeafe;
  color: #1e3a8a;
}

.content-kind-count--empty {
  background: #e2e8f0;
  color: #334155;
}

.student-video {
  margin-top: 0.6rem;
}

.student-embed iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
}

.admin-kpi {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: var(--u-surface);
  padding: 0.95rem 1rem;
  box-shadow: var(--u-shadow-sm);
}

.admin-kpi--muted {
  background: var(--u-surface-soft);
}

.admin-kpi__label {
  font-size: 0.75rem;
  color: var(--u-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.admin-kpi__value {
  font-size: 1.55rem;
  font-weight: 800;
  color: var(--u-text);
  margin-top: 0.15rem;
}

.admin-kpi__hint {
  color: var(--u-muted);
  font-size: 0.85rem;
  margin-top: 0.15rem;
}

.admin-tile {
  display: block;
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: var(--u-surface);
  box-shadow: var(--u-shadow-sm);
  padding: 1rem;
  height: 100%;
  color: inherit;
}

.admin-tile:hover {
  transform: translateY(-1px);
  box-shadow: var(--u-shadow-md);
}

.admin-tile-body {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.admin-tile-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  flex: 0 0 auto;
}

.admin-tile-title {
  font-weight: 800;
}

.admin-course-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.8rem 1.2rem;
  margin-bottom: 0.9rem;
}

.admin-course-item.is-active {
  border-color: #b8cff0;
  box-shadow: inset 3px 0 0 #2563eb;
}

.admin-subpanel,
.admin-manage-pane,
.admin-detail-tile {
  background: #fafcff !important;
  border-color: var(--u-border) !important;
}

.program-card {
  padding: 1rem;
}

.program-card__head,
.program-card__footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.program-card__title {
  margin: 0.6rem 0 0.35rem;
  font-size: 1.08rem;
  font-weight: 800;
}

.program-card__desc {
  color: var(--u-muted);
  margin-bottom: 0.55rem;
}

.z2h-team-grid,
.sem-star-grid,
.sem-highlights__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.z2h-team-card,
.sem-star-card {
  padding: 1rem;
}

.sem-star-card__top,
.sem-star-card__footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.45rem;
}

.sem-star-card__title {
  margin: 0.55rem 0 0.28rem;
  font-size: 1.08rem;
  font-weight: 800;
}

.sem-star-card__tagline,
.sem-star-card__note {
  color: var(--u-muted);
  margin: 0;
}

.sem-star-card__meta,
.sem-star-card__preview {
  margin-top: 0.55rem;
}

.sem-star-card__list {
  margin: 0.35rem 0 0;
  padding-left: 1rem;
}

.sem-star-card__list li {
  margin: 0.2rem 0;
}

.z2h-team-media img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: var(--u-radius-sm);
  border: 1px solid var(--u-border);
}

.z2h-team-placeholder {
  width: 100%;
  height: 220px;
  border-radius: var(--u-radius-sm);
  display: grid;
  place-items: center;
  background: #f1f5fb;
  border: 1px dashed var(--u-border-strong);
}

.z2h-contact-form .form-control {
  min-height: 42px;
}

.z2h-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.z2h-social-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.75rem;
  border-radius: 999px;
  border: 1px solid var(--u-border);
  background: #fff;
  color: var(--u-text);
  font-weight: 700;
}

.z2h-case-viewport {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 0.2rem;
}

.z2h-case-viewport:focus-visible {
  outline: 2px solid #93c5fd;
  outline-offset: 2px;
  border-radius: var(--u-radius-sm);
}

.z2h-case-track {
  display: flex;
  gap: 0.9rem;
  min-width: max-content;
}

.z2h-case {
  flex: 0 0 min(340px, 86vw);
  scroll-snap-align: start;
  padding: 0.95rem;
}

.z2h-case__preview img {
  width: 100%;
  height: 170px;
  object-fit: cover;
  border-radius: var(--u-radius-sm);
  border: 1px solid var(--u-border);
}

.z2h-case__preview--reef {
  min-height: 170px;
  border-radius: var(--u-radius-sm);
  border: 1px solid var(--u-border);
  background: linear-gradient(135deg, #e8f1ff, #f3f8ff);
}

.sem-detail-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.7rem;
  margin-bottom: 1rem;
}

.sem-metric {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fff;
  padding: 0.7rem;
  text-align: center;
}

.sem-metric__value {
  display: block;
  font-size: 1.25rem;
  font-weight: 800;
}

.sem-metric__label {
  font-size: 0.83rem;
  color: var(--u-muted);
}

.sem-roadmap-item {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fff;
  overflow: hidden;
}

.sem-star-card__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

.sem-stat {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fafcff;
  padding: 0.45rem;
  text-align: center;
}

.sem-stat__value {
  display: block;
  font-weight: 800;
}

.sem-stat__label {
  display: block;
  color: var(--u-muted);
  font-size: 0.75rem;
}

.z2h-pillar__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.z2h-pillar__list li {
  position: relative;
  padding-left: 1.1rem;
  margin: 0.35rem 0;
}

.z2h-pillar__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #3b82f6;
}

.sem-roadmap-toggle {
  width: 100%;
  border: 0;
  background: #f8fbff;
  padding: 0.85rem 0.95rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
}

.sem-roadmap-toggle__icon {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid var(--u-border-strong);
  position: relative;
}

.sem-roadmap-toggle__icon::before,
.sem-roadmap-toggle__icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 9px;
  height: 1px;
  background: #334155;
  transform: translate(-50%, -50%);
}

.sem-roadmap-toggle__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.sem-roadmap-item.is-open .sem-roadmap-toggle__icon::after {
  display: none;
}

.sem-roadmap-panel {
  overflow: hidden;
  transition: max-height 0.25s ease, opacity 0.2s ease;
}

.sem-roadmap-panel__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  padding: 0.9rem;
}

.course-item,
.admin-project-item {
  border-color: var(--u-border);
}

.admin-project-item {
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: 0.8rem;
  align-items: center;
}

.admin-project-thumb img {
  width: 92px;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--u-border);
}

.z2h-footer {
  background: #0f172a;
  color: #d7e1ee;
  margin-top: 2.5rem;
  border-top: 1px solid #1e293b;
}

.z2h-footer__reveal {
  padding: 2.1rem 0 1.35rem;
}

.z2h-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
  gap: 1.1rem 1.6rem;
}

.z2h-footer-title,
.z2h-footer-logo {
  color: #f8fafc;
}

.z2h-footer-tag,
.z2h-footer-list a,
.z2h-footer-bottom {
  color: #c3d2e4;
}

.z2h-footer-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.38rem;
}

.z2h-footer-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.z2h-footer-bottom {
  margin-top: 1.2rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(148, 163, 184, 0.3);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  font-size: 0.86rem;
}

.z2h-footer-right {
  display: inline-flex;
  gap: 0.45rem;
  align-items: center;
}

/* Phase 3: auth/admin/student coverage (no legacy styles dependency) */
.z2h-nav--pro {
  isolation: isolate;
}

.z2h-nav-collapse {
  width: 100%;
}

#admin-login .admin-card,
#signup-page .admin-card,
#password-recovery .admin-card,
#password-reset .admin-card {
  border-radius: var(--u-radius-lg);
  box-shadow: var(--u-shadow-md);
}

#admin-login .card-body,
#signup-page .card-body,
#password-recovery .card-body,
#password-reset .card-body {
  padding: 1.25rem;
}

.admin-page-head {
  border-bottom: 1px solid var(--u-border);
  padding-bottom: 0.25rem;
}

.admin-kpis {
  align-items: stretch;
}

.admin-view-toggle,
.admin-manage-tabs {
  align-items: center;
}

.admin-view-toggle .btn.active,
.admin-manage-tabs .btn.active {
  background: #eaf2ff;
  border-color: #c2d6f4;
  color: #1e40af;
}

.admin-course-search {
  flex: 1 1 320px;
  min-width: 260px;
}

.admin-course-info {
  display: grid;
  gap: 0.15rem;
  align-content: center;
  text-align: right;
}

.admin-course-title {
  font-size: 1rem;
  line-height: 1.3;
  letter-spacing: -0.01em;
}

.admin-course-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.22rem;
}

.admin-course-actions {
  align-items: center;
  justify-content: flex-end;
}

.admin-course-actions .btn,
.admin-project-actions .btn {
  min-height: 34px;
  padding: 0.34rem 0.66rem;
  font-size: 0.78rem;
}

.admin-project-body {
  display: grid;
  gap: 0.24rem;
  min-width: 0;
}

.admin-project-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  color: var(--u-muted);
  font-size: 0.8rem;
}

.admin-project-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  font-size: 0.84rem;
}

.admin-project-actions {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.manage-pane {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
}

.course-edit-form .form-label,
.sem-edit-form .form-label,
.program-code-form .form-label,
.program-content-form .form-label {
  margin-bottom: 0.2rem;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--u-muted);
}

.tag-editor {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  align-items: center;
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  background: #fff;
  padding: 0.45rem 0.5rem;
}

.tag-editor__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  border: 1px solid #caddf4;
  background: #eef5ff;
  color: #1e40af;
  font-size: 0.76rem;
  font-weight: 700;
}

.tag-editor__chip button {
  border: 0;
  background: transparent;
  color: inherit;
  line-height: 1;
  padding: 0;
}

.tag-editor__input {
  flex: 1 1 170px;
  min-width: 160px;
  border: 0;
  background: transparent;
  padding: 0.2rem 0.3rem;
}

.tag-editor__input:focus {
  outline: none;
}

.sem-blocks-editor {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: #f8fbff;
  padding: 0.74rem;
}

.sem-blocks-list {
  display: grid;
  gap: 0.72rem;
}

.sem-block-card {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: #fff;
  box-shadow: var(--u-shadow-sm);
  padding: 0.72rem;
}

.sem-block-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.sem-block-card__index {
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #1e40af;
  font-weight: 800;
}

.sem-actions {
  border-top: 1px solid var(--u-border);
  padding-top: 0.7rem;
}

.sem-enroll-link {
  font-weight: 800;
}

.sem-description {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-md);
  background: #fff;
  padding: 0.9rem;
}

.sem-description__text {
  margin: 0;
  color: var(--u-muted);
}

.sem-highlight-pill,
.pill-soft {
  border: 1px solid #caddf4;
  background: #eef5ff;
  color: #1e3a8a;
}

.sem-list--columns {
  columns: 2;
  column-gap: 1.25rem;
}

.sem-list--columns li {
  break-inside: avoid;
}

.sem-metric--note {
  display: grid;
  align-items: center;
  text-align: left;
}

.sem-roadmap-toggle__left {
  display: grid;
  gap: 0.08rem;
}

.student-shell {
  display: grid;
  gap: 1rem;
}

.student-hero--light {
  border: 1px solid var(--u-border) !important;
  background: #fff !important;
}

.student-hero--slim {
  padding: 1rem;
}

.student-hero__sub {
  margin: 0.45rem 0 0;
  color: var(--u-muted);
  max-width: 56ch;
}

.student-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.62rem;
}

.student-hero__back {
  min-height: 38px;
}

.student-panel--accent {
  border-color: #c9dbf5;
  background: #fbfdff;
}

.student-panel--soft {
  background: #f9fbff;
}

.student-readout dt {
  margin-bottom: 0.2rem;
  font-size: 0.76rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--u-muted) !important;
}

.student-readout dd {
  margin-bottom: 0.52rem;
}

.student-steps {
  display: grid;
  gap: 0.42rem;
}

.student-form-grid .form-label {
  margin-bottom: 0.2rem;
  font-size: 0.77rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--u-muted);
}

.program-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
  margin-bottom: 0.58rem;
}

.program-card__status {
  font-size: 0.84rem;
  color: var(--u-muted);
  font-weight: 700;
}

.program-content-list,
.program-code-list,
.program-enroll-list {
  display: grid;
  gap: 0.45rem;
}

.content-kind-card {
  border-color: var(--u-border) !important;
  background: #fff !important;
}

.content-kind-card:hover {
  border-color: #c2d6f4 !important;
  background: #f7fbff !important;
}

.content-kind-count {
  min-width: 30px;
  text-align: center;
  font-weight: 800;
}

.content-tile {
  border-color: var(--u-border) !important;
  background: #fff;
}

.student-video__toolbar {
  margin-top: 0.55rem;
}

.student-video__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.student-video__toggle,
.student-video__hide {
  min-height: 34px;
}

.z2h-landing-hero,
.z2h-contact,
.z2h-team {
  position: relative;
}

.z2h-home-hero__copy {
  display: grid;
  gap: 0.7rem;
}

.z2h-pillar--tile {
  height: 100%;
}

.z2h-pillar--elevated {
  box-shadow: var(--u-shadow-sm);
}

.z2h-pillar--academy,
.z2h-pillar--devs {
  background: var(--u-surface);
}

.z2h-pillar__head {
  margin-bottom: 0.55rem;
}

.z2h-pillar__eyebrow {
  margin: 0 0 0.28rem;
}

.z2h-devs-head,
.z2h-courses-header,
.z2h-communities__head {
  border-bottom: 1px solid var(--u-border);
  padding-bottom: 0.62rem;
}

.z2h-case__body {
  display: grid;
  gap: 0.52rem;
}

.z2h-case-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.z2h-comm-menu {
  gap: 0.62rem;
}

.z2h-comm-link {
  font-size: 0.84rem;
}

.z2h-consult__left,
.z2h-consult__right {
  min-width: 0;
}

.z2h-consult__eyebrow {
  margin-bottom: 0.3rem;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #1e3a8a;
}

.z2h-consult__label {
  margin: 0;
  font-size: 0.78rem;
  color: var(--u-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.z2h-consult__cta {
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.z2h-hero-slim__sub {
  margin: 0.42rem 0 0;
  color: var(--u-muted);
}

.z2h-hero-slim__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  margin-top: 0.6rem;
}

.z2h-tile__content--card {
  min-height: 100%;
  display: grid;
  gap: 0.55rem;
}

.z2h-tile__cta {
  margin-top: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.45rem;
}

.z2h-select {
  min-height: 42px;
}

.z2h-input-elevated {
  border: 1px solid var(--u-border);
  border-radius: var(--u-radius-sm);
  overflow: hidden;
}

.z2h-input-elevated .input-group-text {
  border: 0;
  border-right: 1px solid var(--u-border);
  background: #fff;
}

.z2h-input-elevated .form-control {
  border: 0;
}

.z2h-input-elevated:focus-within {
  border-color: #93c5fd;
  box-shadow: 0 0 0 0.24rem rgba(37, 99, 235, 0.14);
}

.z2h-owa-title {
  letter-spacing: -0.01em;
}

.z2h-badge {
  background: #eef5ff;
  border: 1px solid #caddf4;
  color: #1e40af;
}

.z2h-socials--icons .z2h-social-chip {
  min-height: 37px;
}

.z2h-team-card--stacked,
.z2h-team-media--stacked,
.z2h-team-body--stacked {
  width: 100%;
}

.z2h-team-body {
  display: grid;
  gap: 0.35rem;
}

.sem-highlights {
  margin-bottom: 1rem;
}

.sem-star-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
}

.sem-star-card__eyebrow {
  margin: 0;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--u-muted);
}

.sem-star-card__kicker {
  margin: 0.2rem 0 0;
  color: var(--u-muted);
}

.sem-star-card__pill {
  display: inline-flex;
  border: 1px solid var(--u-border);
  border-radius: 999px;
  padding: 0.2rem 0.56rem;
  background: #f8fbff;
  color: #1e3a8a;
  font-size: 0.73rem;
  font-weight: 700;
}

.sem-star-card__cta {
  margin-top: 0.65rem;
}

.z2h-enroll-steps {
  margin-top: 1.4rem;
}

.z2h-footer-brand {
  max-width: 32ch;
}

.z2h-footer-col {
  min-width: 0;
}

.z2h-footer-left {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}

/* Remove legacy reveal/animation intensity */
.z2h-reveal,
html.js-io-reveal .z2h-reveal {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* Responsive */
@media (max-width: 991.98px) {
  body.z2h-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1036;
    background: rgba(15, 23, 42, 0.32);
  }

  .z2h-nav .z2h-nav-toggler {
    display: inline-flex;
    position: relative;
    z-index: 1042;
  }

  .z2h-nav #nav {
    position: fixed;
    right: 0;
    top: 0;
    width: min(86vw, 360px);
    height: 100dvh;
    background: #fff;
    border-left: 1px solid var(--u-border);
    box-shadow: -20px 0 36px rgba(15, 23, 42, 0.14);
    padding: 0.95rem;
    z-index: 1038;
    gap: 0.75rem;
  }

  .z2h-nav #nav:not(.show) {
    display: none;
  }

  .z2h-nav .navbar-collapse.show,
  .z2h-nav .navbar-collapse.collapsing {
    display: flex !important;
    flex-direction: column;
    overflow: auto;
  }

  .z2h-nav .z2h-nav-mobile-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.3rem;
    color: var(--u-muted);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }

  .z2h-nav .z2h-nav-close {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid var(--u-border-strong);
    background: #f8fbff;
    color: var(--u-text);
    display: grid;
    place-items: center;
    font-size: 1.22rem;
    padding: 0;
  }

  .z2h-nav .z2h-nav-main {
    width: 100%;
    gap: 0.5rem;
    margin-top: 0.2rem;
  }

  .z2h-nav .z2h-nav-main .nav-item {
    width: 100%;
  }

  .z2h-nav .z2h-nav-main .nav-link {
    width: 100%;
    min-height: 46px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--u-border);
    background: #fff;
  }

  .z2h-nav .z2h-nav-main .dropdown-toggle::after {
    margin-left: auto;
    margin-right: 0.15rem;
  }

  .z2h-nav .z2h-nav-main .dropdown-menu {
    position: static !important;
    float: none;
    transform: none !important;
    min-width: 0;
    width: 100%;
    margin: 0.32rem 0 0;
    border: 1px solid var(--u-border);
    border-radius: 12px;
    box-shadow: none;
    padding: 0.32rem;
  }

  .z2h-nav .z2h-nav-main .dropdown-item {
    min-height: 40px;
    display: flex;
    align-items: center;
  }

  .z2h-nav .z2h-nav-actions {
    width: 100%;
    margin-left: 0;
    flex-direction: column;
    margin-top: auto;
    padding-top: 0.8rem;
    border-top: 1px solid var(--u-border);
  }

  .z2h-nav .z2h-nav-pill {
    width: 100%;
    min-height: 46px;
    justify-content: center;
    font-size: 0.96rem;
  }

  .z2h-home .z2h-home-hero__grid,
  .z2h-hero-slim__body,
  .student-hero__content,
  .z2h-contact-hero__body,
  .z2h-consult__inner,
  .sem-detail-grid,
  .sem-roadmap-panel__grid {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .z2h-pillar__meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sem-detail-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .z2h-team-grid,
  .sem-star-grid,
  .sem-highlights__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .z2h-instructors-grid,
  .z2h-instructors-grid--single {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-course-info {
    text-align: left;
    width: 100%;
  }

  .admin-project-item {
    grid-template-columns: 86px 1fr;
  }

  .admin-project-actions {
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: flex-end;
  }

  .student-panel__header,
  .student-panel__header--tight {
    flex-direction: column;
    align-items: flex-start;
  }

  .sem-list--columns {
    columns: 1;
  }

  .z2h-footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  #main {
    padding-top: 1.4rem !important;
    padding-bottom: 2.4rem !important;
  }

  .z2h-home .z2h-home-hero__title,
  .student-hero__title,
  .z2h-hero-slim__title {
    font-size: clamp(1.45rem, 7vw, 1.95rem);
  }

  .z2h-home .z2h-home-hero__ctas .btn,
  .z2h-hero-slim__actions .btn,
  .student-hero__actions .btn,
  .z2h-contact__cta .btn {
    width: 100%;
  }

  .admin-project-item {
    grid-template-columns: 1fr;
  }

  .admin-project-thumb img {
    width: 100%;
    height: 170px;
  }

  .admin-project-actions {
    justify-content: flex-start;
  }

  .z2h-tile__cta .btn {
    width: 100%;
  }

  .z2h-team-grid,
  .sem-star-grid,
  .sem-highlights__grid,
  .z2h-instructors-grid,
  .z2h-instructors-grid--single,
  .z2h-footer-grid {
    grid-template-columns: 1fr;
  }

  .z2h-pillar__meta {
    grid-template-columns: 1fr;
  }

  .sem-detail-metrics {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}

/*
  Phase 4: Public minimal theme
  Inspired by Coursera/TestDriven-like clarity:
  - White/black base
  - FastAPI green accents
  - Reduced decorative noise
  - Strong mobile readability
*/
body.z2h-public-skin {
  --z2h-public-bg: #ffffff;
  --z2h-public-surface: #ffffff;
  --z2h-public-soft: #f5f7f8;
  --z2h-public-text: #0f1115;
  --z2h-public-muted: #5e6470;
  --z2h-public-border: #d8dde4;
  --z2h-public-border-strong: #b8bfca;
  --z2h-public-accent: #009688;
  --z2h-public-accent-strong: #007f73;
  --z2h-public-shadow: 0 10px 22px rgba(15, 17, 21, 0.06);
  --z2h-public-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfc 100%);
  color: var(--z2h-public-text);
}

body.z2h-public-skin #main {
  padding-top: 1.55rem !important;
  padding-bottom: 2.8rem !important;
}

body.z2h-public-skin .z2h-nav {
  background: rgba(255, 255, 255, 0.98) !important;
  border-bottom: 1px solid var(--z2h-public-border);
  box-shadow: 0 5px 20px rgba(15, 17, 21, 0.04);
  backdrop-filter: blur(8px);
}

body.z2h-public-skin .z2h-brand__glyph {
  border: 0;
  background: transparent;
  color: var(--z2h-public-accent);
}

body.z2h-public-skin .z2h-brand__name {
  color: var(--z2h-public-text);
}

body.z2h-public-skin .z2h-brand__meta {
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link {
  color: #1f232b;
  border-radius: 11px;
  font-weight: 700;
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link:hover {
  color: #0f1115;
  background: #f3f5f7;
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link.is-current,
body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link[aria-current="page"] {
  color: #0f1115;
  background: #eef8f6;
  border-color: #bfe4dd;
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-menu {
  border-color: var(--z2h-public-border);
  box-shadow: 0 14px 28px rgba(15, 17, 21, 0.1);
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-item {
  color: #11141a;
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-item:hover,
body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-item:focus-visible {
  color: #0f1115;
  background: #f3f5f7;
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-item.is-current,
body.z2h-public-skin .z2h-nav .z2h-nav-main .dropdown-item[aria-current="page"] {
  color: #0f1115;
  background: #eef8f6;
}

body.z2h-public-skin .z2h-nav .z2h-nav-pill {
  border-radius: 999px;
  min-height: 39px;
}

body.z2h-public-skin .z2h-nav .z2h-nav-pill--primary {
  background: var(--z2h-public-accent);
  border-color: var(--z2h-public-accent);
  color: #ffffff !important;
}

body.z2h-public-skin .z2h-nav .z2h-nav-pill--primary:hover {
  background: var(--z2h-public-accent-strong);
  border-color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-nav .z2h-nav-pill--ghost {
  background: #ffffff;
  border-color: var(--z2h-public-border-strong);
  color: #11141a !important;
}

body.z2h-public-skin .z2h-nav .z2h-nav-pill--ghost:hover {
  background: #f3f5f7;
  border-color: #aeb6c1;
}

body.z2h-public-skin .z2h-nav-toggler {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body.z2h-public-skin .z2h-nav .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 16 16'%3E%3Cpath stroke='%230f1115' stroke-width='1.7' stroke-linecap='round' d='M2 4h12M2 8h12M2 12h12'/%3E%3C/svg%3E");
}

body.z2h-public-skin .z2h-public-page {
  color: var(--z2h-public-text);
}

body.z2h-public-skin .z2h-public-page h1,
body.z2h-public-skin .z2h-public-page h2,
body.z2h-public-skin .z2h-public-page h3,
body.z2h-public-skin .z2h-public-page h4,
body.z2h-public-skin .z2h-public-page h5 {
  color: var(--z2h-public-text);
}

body.z2h-public-skin .z2h-public-page p,
body.z2h-public-skin .z2h-public-page li {
  color: inherit;
}

body.z2h-public-skin .z2h-public-page .text-muted,
body.z2h-public-skin .z2h-public-page .z2h-subtle {
  color: var(--z2h-public-muted) !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero,
body.z2h-public-skin .z2h-public-page .z2h-hero-slim,
body.z2h-public-skin .z2h-public-page .z2h-pillar,
body.z2h-public-skin .z2h-public-page .z2h-semillero-stars,
body.z2h-public-skin .z2h-public-page .z2h-devs-showcase,
body.z2h-public-skin .z2h-public-page .z2h-communities,
body.z2h-public-skin .z2h-public-page .z2h-featured,
body.z2h-public-skin .z2h-public-page .z2h-consult,
body.z2h-public-skin .z2h-public-page .z2h-gradient-tile,
body.z2h-public-skin .z2h-public-page .z2h-contact-hero,
body.z2h-public-skin .z2h-public-page .z2h-contact-card,
body.z2h-public-skin .z2h-public-page .z2h-enroll-card {
  background: var(--z2h-public-surface) !important;
  border: 1px solid var(--z2h-public-border) !important;
  border-radius: var(--z2h-public-radius) !important;
  box-shadow: var(--z2h-public-shadow) !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__bg,
body.z2h-public-skin .z2h-public-page .z2h-pillar__bg,
body.z2h-public-skin .z2h-public-page .z2h-hero-slim::before {
  display: none !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero {
  padding: 1.65rem 1.3rem !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__grid {
  gap: 1.2rem;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__title {
  font-size: clamp(1.8rem, 4.8vw, 3rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__line,
body.z2h-public-skin .z2h-public-page .z2h-home-hero__line--scroll {
  color: #0f1115 !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__lead {
  color: var(--z2h-public-muted) !important;
  font-size: 1rem;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__mini-card {
  border: 1px solid var(--z2h-public-border);
  background: var(--z2h-public-soft);
  border-radius: 14px;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__mini-card h2 {
  font-size: 1rem;
  margin: 0 0 0.35rem;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__tags span {
  background: #f0f2f5;
  border-color: var(--z2h-public-border);
  color: #131720;
}

body.z2h-public-skin .z2h-public-page .z2h-hero-slim,
body.z2h-public-skin .z2h-public-page .z2h-contact-hero {
  padding: 1.2rem 1.1rem;
}

body.z2h-public-skin .z2h-public-page .z2h-hero-slim__eyebrow,
body.z2h-public-skin .z2h-public-page .z2h-home-hero__eyebrow,
body.z2h-public-skin .z2h-public-page .z2h-pillar__eyebrow,
body.z2h-public-skin .z2h-public-page .z2h-eyebrow,
body.z2h-public-skin .z2h-public-page .sem-section-eyebrow {
  color: var(--z2h-public-accent) !important;
  letter-spacing: 0.08em !important;
}

body.z2h-public-skin .z2h-public-page .z2h-home-hero__ctas,
body.z2h-public-skin .z2h-public-page .z2h-hero-slim__actions,
body.z2h-public-skin .z2h-public-page .z2h-contact__cta,
body.z2h-public-skin .z2h-public-page .z2h-tile__cta {
  gap: 0.55rem;
}

body.z2h-public-skin .z2h-public-page .btn,
body.z2h-public-skin .z2h-public-page .btn-sm {
  border-radius: 12px;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-page .btn-cta,
body.z2h-public-skin .z2h-public-page .btn-primary {
  background: var(--z2h-public-accent);
  border-color: var(--z2h-public-accent);
  color: #ffffff !important;
}

body.z2h-public-skin .z2h-public-page .btn-cta:hover,
body.z2h-public-skin .z2h-public-page .btn-primary:hover {
  background: var(--z2h-public-accent-strong);
  border-color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-page .btn-ghost,
body.z2h-public-skin .z2h-public-page .btn-owa-outline,
body.z2h-public-skin .z2h-public-page .btn-outline-secondary {
  background: #ffffff;
  border-color: var(--z2h-public-border-strong);
  color: #12151b !important;
}

body.z2h-public-skin .z2h-public-page .btn-ghost:hover,
body.z2h-public-skin .z2h-public-page .btn-owa-outline:hover,
body.z2h-public-skin .z2h-public-page .btn-outline-secondary:hover {
  background: #f3f5f7;
  border-color: #aab3bf;
}

body.z2h-public-skin .z2h-public-page .z2h-link-underline {
  color: #101318;
  text-decoration-color: var(--z2h-public-accent);
}

body.z2h-public-skin .z2h-public-page .z2h-link-underline:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-page .z2h-pill,
body.z2h-public-skin .z2h-public-page .z2h-chip,
body.z2h-public-skin .z2h-public-page .z2h-hero-chip,
body.z2h-public-skin .z2h-public-page .z2h-meta-pill,
body.z2h-public-skin .z2h-public-page .chip,
body.z2h-public-skin .z2h-public-page .chip-soft,
body.z2h-public-skin .z2h-public-page .pill-soft,
body.z2h-public-skin .z2h-public-page .sem-star-card__pill,
body.z2h-public-skin .z2h-public-page .z2h-case__badge {
  background: #f2f4f6;
  border-color: var(--z2h-public-border);
  color: #141820;
}

body.z2h-public-skin .z2h-public-page .z2h-pillar__meta > div,
body.z2h-public-skin .z2h-public-page .sem-stat,
body.z2h-public-skin .z2h-public-page .sem-metric {
  background: #f8f9fa;
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-page .z2h-meta__big,
body.z2h-public-skin .z2h-public-page .sem-stat__value,
body.z2h-public-skin .z2h-public-page .sem-metric__value {
  color: #0f1115;
}

body.z2h-public-skin .z2h-public-page .z2h-pillar__list li::before {
  background: var(--z2h-public-accent);
}

body.z2h-public-skin .z2h-public-page .sem-star-card,
body.z2h-public-skin .z2h-public-page .z2h-case,
body.z2h-public-skin .z2h-public-page .z2h-tile,
body.z2h-public-skin .z2h-public-page .z2h-team-card,
body.z2h-public-skin .z2h-public-page .z2h-instructor-card,
body.z2h-public-skin .z2h-public-page .sem-roadmap-item {
  border: 1px solid var(--z2h-public-border) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(15, 17, 21, 0.05) !important;
  background: #ffffff !important;
}

body.z2h-public-skin .z2h-public-page .z2h-case__client,
body.z2h-public-skin .z2h-public-page .z2h-case__desc,
body.z2h-public-skin .z2h-public-page .sem-star-card__tagline,
body.z2h-public-skin .z2h-public-page .sem-star-card__note,
body.z2h-public-skin .z2h-public-page .z2h-tile__desc,
body.z2h-public-skin .z2h-public-page .z2h-team-role {
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-page .z2h-tile__media-overlay {
  background: linear-gradient(180deg, rgba(15, 17, 21, 0.08), rgba(15, 17, 21, 0.45));
}

body.z2h-public-skin .z2h-public-page .z2h-tile:hover,
body.z2h-public-skin .z2h-public-page .z2h-case:hover,
body.z2h-public-skin .z2h-public-page .sem-star-card:hover,
body.z2h-public-skin .z2h-public-page .z2h-team-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(15, 17, 21, 0.08) !important;
}

body.z2h-public-skin .z2h-public-page .z2h-comm-item {
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-page .z2h-comm-toggle,
body.z2h-public-skin .z2h-public-page .sem-roadmap-toggle {
  background: #f7f8f9;
}

body.z2h-public-skin .z2h-public-page .z2h-comm-badge--accent {
  color: var(--z2h-public-accent-strong);
  background: #e6f5f2;
  border-color: #b7e6dd;
}

body.z2h-public-skin .z2h-public-page .z2h-social-chip {
  border-color: var(--z2h-public-border);
  background: #ffffff;
  color: #12151b;
}

body.z2h-public-skin .z2h-public-page .z2h-social-chip:hover {
  background: #f4f6f8;
}

body.z2h-public-skin .z2h-public-page .z2h-social-ico {
  background: #0f1115;
}

body.z2h-public-skin .z2h-public-page .z2h-filters {
  border-color: var(--z2h-public-border) !important;
  border-radius: 16px;
  box-shadow: 0 8px 18px rgba(15, 17, 21, 0.05);
}

body.z2h-public-skin .z2h-public-page .z2h-searchgroup .input-group-text {
  background: #f4f6f8;
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-page .form-control,
body.z2h-public-skin .z2h-public-page .form-select,
body.z2h-public-skin .z2h-public-page .input-group-text {
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-page .form-control:focus,
body.z2h-public-skin .z2h-public-page .form-select:focus,
body.z2h-public-skin .z2h-public-page .btn:focus-visible {
  border-color: #7ad8cb;
  box-shadow: 0 0 0 0.22rem rgba(0, 150, 136, 0.18);
}

body.z2h-public-skin .z2h-auth-screen {
  max-width: 980px;
}

body.z2h-public-skin .z2h-auth-screen .row {
  --bs-gutter-y: 0.9rem;
}

body.z2h-public-skin .z2h-auth-screen .z2h-auth-card {
  border: 1px solid var(--z2h-public-border);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 14px 28px rgba(15, 17, 21, 0.065);
}

body.z2h-public-skin .z2h-auth-screen .z2h-auth-card .card-body {
  padding: clamp(1.05rem, 2.4vw, 1.55rem) !important;
}

body.z2h-public-skin .z2h-auth-screen .form-label {
  margin-bottom: 0.26rem;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--z2h-public-muted);
  font-weight: 700;
}

body.z2h-public-skin .z2h-auth-screen .form-control,
body.z2h-public-skin .z2h-auth-screen .form-select {
  min-height: 44px;
  border-radius: 12px;
}

body.z2h-public-skin .z2h-auth-screen textarea.form-control {
  min-height: 104px;
}

body.z2h-public-skin .z2h-auth-screen .btn {
  min-height: 44px;
}

body.z2h-public-skin .z2h-auth-screen .small a {
  color: #101318;
  text-decoration-color: var(--z2h-public-accent);
  text-underline-offset: 0.2rem;
}

body.z2h-public-skin .z2h-auth-screen .small a:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-course .breadcrumb {
  padding: 0.58rem 0.78rem;
  border: 1px solid var(--z2h-public-border);
  border-radius: 12px;
  background: #f7f8f9;
  margin-bottom: 1rem;
}

body.z2h-public-skin .z2h-public-course .lead {
  color: var(--z2h-public-muted);
  font-size: 1.03rem;
}

body.z2h-public-skin .z2h-public-course .list-unstyled li {
  border-bottom: 1px solid var(--z2h-public-border);
  padding: 0.42rem 0;
}

body.z2h-public-skin .z2h-public-course .list-unstyled li:last-child {
  border-bottom: 0;
}

body.z2h-public-skin .z2h-public-course code {
  background: #f4f6f8;
  border: 1px solid var(--z2h-public-border);
  border-radius: 8px;
  padding: 0.2rem 0.38rem;
}

body.z2h-public-skin .z2h-public-course .alert-light {
  background: #f6f7f9;
  border-color: var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-course .z2h-step-index {
  background: #e6f5f2;
  color: var(--z2h-public-accent-strong);
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-course aside .card {
    position: sticky;
    top: 5.9rem;
  }
}

body.z2h-public-skin .z2h-footer {
  background: #ffffff;
  color: #11141a;
  border-top: 1px solid var(--z2h-public-border);
}

body.z2h-public-skin .z2h-footer-title,
body.z2h-public-skin .z2h-footer-logo {
  color: #11141a;
}

body.z2h-public-skin .z2h-footer-tag,
body.z2h-public-skin .z2h-footer-list a,
body.z2h-public-skin .z2h-footer-bottom {
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-footer-bottom {
  border-top-color: var(--z2h-public-border);
}

@media (max-width: 991.98px) {
  body.z2h-public-skin .z2h-nav #nav {
    width: min(86vw, 360px);
    background: #ffffff;
    border-left: 1px solid var(--z2h-public-border);
    box-shadow: -16px 0 26px rgba(15, 17, 21, 0.14);
  }

  body.z2h-public-skin .z2h-nav .z2h-nav-close {
    background: #f4f6f8;
    border-color: var(--z2h-public-border);
    color: #0f1115;
  }

  body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link {
    justify-content: flex-start;
    padding-left: 0.95rem;
    border-color: var(--z2h-public-border);
    background: #ffffff;
  }

  body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link.is-current,
  body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link[aria-current="page"] {
    background: #eef8f6;
    border-color: #bfe4dd;
  }

  body.z2h-public-skin .z2h-nav .z2h-nav-actions {
    border-top-color: var(--z2h-public-border);
  }

  body.z2h-public-skin .z2h-public-page .z2h-home-hero__grid,
  body.z2h-public-skin .z2h-public-page .z2h-hero-slim__body,
  body.z2h-public-skin .z2h-public-page .z2h-contact-hero__body,
  body.z2h-public-skin .z2h-public-page .z2h-consult__inner {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  body.z2h-public-skin .z2h-public-page .z2h-home-hero__panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.z2h-public-skin #main {
    padding-top: 1.05rem !important;
    padding-bottom: 2rem !important;
  }

  body.z2h-public-skin .z2h-public-page .z2h-home-hero,
  body.z2h-public-skin .z2h-public-page .z2h-hero-slim,
  body.z2h-public-skin .z2h-public-page .z2h-pillar,
  body.z2h-public-skin .z2h-public-page .z2h-semillero-stars,
  body.z2h-public-skin .z2h-public-page .z2h-devs-showcase,
  body.z2h-public-skin .z2h-public-page .z2h-communities,
  body.z2h-public-skin .z2h-public-page .z2h-featured,
  body.z2h-public-skin .z2h-public-page .z2h-consult,
  body.z2h-public-skin .z2h-public-page .z2h-gradient-tile,
  body.z2h-public-skin .z2h-public-page .z2h-contact-hero,
  body.z2h-public-skin .z2h-public-page .z2h-contact-card {
    border-radius: 15px !important;
    padding: 1rem !important;
  }

  body.z2h-public-skin .z2h-public-page .z2h-home-hero__title,
  body.z2h-public-skin .z2h-public-page .z2h-hero-slim__title {
    font-size: clamp(1.52rem, 8vw, 2rem);
    line-height: 1.08;
  }

  body.z2h-public-skin .z2h-public-page .z2h-home-hero__ctas .btn,
  body.z2h-public-skin .z2h-public-page .z2h-hero-slim__actions .btn,
  body.z2h-public-skin .z2h-public-page .z2h-contact__cta .btn,
  body.z2h-public-skin .z2h-public-page .z2h-tile__cta .btn,
  body.z2h-public-skin .z2h-public-course .btn {
    width: 100%;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-page .z2h-team-grid,
  body.z2h-public-skin .z2h-public-page .sem-star-grid,
  body.z2h-public-skin .z2h-public-page .z2h-instructors-grid,
  body.z2h-public-skin .z2h-public-page .z2h-instructors-grid--single {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-page .z2h-pillar__meta,
  body.z2h-public-skin .z2h-public-page .sem-star-card__stats,
  body.z2h-public-skin .z2h-public-page .sem-detail-metrics {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-page .z2h-case {
    flex-basis: 86vw;
  }

  body.z2h-public-skin .z2h-public-page .z2h-case__preview img,
  body.z2h-public-skin .z2h-public-page .z2h-case__preview--reef {
    height: 150px;
    min-height: 150px;
  }

  body.z2h-public-skin .z2h-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Phase 4.1: public index + semilleros refinements */
body.z2h-public-skin .z2h-public-index .z2h-home-hero {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 1.4rem 0 1.2rem !important;
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero__grid--minimal {
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.9fr);
  gap: 1rem 1.25rem;
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero__copy {
  max-width: 760px;
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero__lead {
  text-align: justify;
  text-justify: inter-word;
}

body.js-scroll-reveal .z2h-public-index [data-scroll-reveal] > * {
  opacity: 0;
  transform: translateY(22px);
  filter: blur(1.8px);
  transition: opacity 1.96s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 1.96s cubic-bezier(0.22, 0.61, 0.36, 1),
    filter 1.96s cubic-bezier(0.22, 0.61, 0.36, 1);
}

body.js-scroll-reveal .z2h-public-index [data-scroll-reveal] > *:nth-child(2) {
  transition-delay: 0.28s;
}

body.js-scroll-reveal .z2h-public-index [data-scroll-reveal] > *:nth-child(3) {
  transition-delay: 0.52s;
}

body.js-scroll-reveal .z2h-public-index [data-scroll-reveal] > *:nth-child(4) {
  transition-delay: 0.76s;
}

body.js-scroll-reveal .z2h-public-index [data-scroll-reveal].is-visible > * {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero__panel--image {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero-media {
  margin: 0 0 0 auto;
  width: min(100%, 420px);
  aspect-ratio: 4 / 3;
  height: auto;
  border: 0;
  border-radius: 18px;
  overflow: hidden;
  background: transparent;
  box-shadow: none;
}

body.z2h-public-skin .z2h-public-index .z2h-home-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

body.z2h-public-skin .z2h-public-index > section {
  margin-bottom: clamp(4.95rem, 8.6vw, 8.15rem) !important;
}

body.z2h-public-skin .z2h-public-index > section:last-of-type {
  margin-bottom: 0 !important;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card {
  border: 1px solid var(--z2h-public-border);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.05);
  padding: 1.12rem;
  height: 100%;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh {
  row-gap: 1rem;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card {
  border-color: #d5dee6;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 9px 20px rgba(15, 17, 21, 0.045);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.12rem 1.14rem;
  overflow: hidden;
  position: relative;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card::before {
  content: none;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card--academy {
  border-color: #cfe4df;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%);
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card--academy::before {
  content: none;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card__eyebrow {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--z2h-public-accent);
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card__title {
  margin: 0.38rem 0 0.4rem;
  font-size: 1.2rem;
  line-height: 1.25;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__title {
  margin-top: 0.24rem;
  margin-bottom: 0.12rem;
  font-size: clamp(1.24rem, 2.3vw, 1.78rem);
  line-height: 1.16;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card__desc {
  margin: 0;
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__desc {
  font-size: 0.94rem;
  line-height: 1.52;
  max-width: 56ch;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__impact {
  margin: 0;
  color: #1f2a38;
  font-size: 0.89rem;
  font-weight: 600;
  line-height: 1.5;
  max-width: 58ch;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card__list {
  margin: 0.62rem 0 0.85rem;
  padding-left: 1rem;
}

body.z2h-public-skin .z2h-public-index .z2h-service-card__list li {
  margin: 0.26rem 0;
  color: #1a1f28;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list {
  list-style: none;
  margin: 0.22rem 0 0.8rem;
  padding: 0;
  display: grid;
  gap: 0.4rem;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list li {
  position: relative;
  margin: 0;
  padding-left: 1.02rem;
  line-height: 1.5;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #8fcfc5;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list li strong {
  color: #0f1115;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.9rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
  margin-top: auto;
}

body.z2h-public-skin .z2h-public-index .sem-star-head,
body.z2h-public-skin .z2h-public-index .z2h-devs-head,
body.z2h-public-skin .z2h-public-index .z2h-communities__head,
body.z2h-public-skin .z2h-public-index .z2h-courses-header {
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
  margin-bottom: 1.12rem !important;
}

body.z2h-public-skin .z2h-public-index .sem-star-grid {
  align-items: stretch;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual {
  display: flex;
  flex-direction: column;
  height: 100%;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__top {
  display: grid;
  justify-items: start;
  align-content: start;
  gap: 0.34rem;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__meta {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  align-items: stretch;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__title {
  margin-top: 0.58rem;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__tagline {
  margin-top: 0.2rem;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__stats {
  margin-top: 0.58rem;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__preview {
  margin-top: 0.74rem;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__toggle {
  width: 100%;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.05rem 0;
  text-align: left;
  cursor: pointer;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__toggle:focus-visible {
  outline: 2px solid #99d9ce;
  outline-offset: 3px;
  border-radius: 6px;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__kicker {
  margin: 0;
  color: #3f4b5b;
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__chevron {
  width: 10px;
  height: 10px;
  border-right: 1.8px solid #667080;
  border-bottom: 1.8px solid #667080;
  transform: rotate(45deg);
  transition: transform 0.92s cubic-bezier(0.22, 0.61, 0.36, 1);
  flex: 0 0 auto;
  margin-right: 2px;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__preview.is-open .sem-star-card__chevron {
  transform: rotate(-135deg);
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__panel {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: grid-template-rows 0.96s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.96s ease;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__panel-inner {
  min-height: 0;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__preview.is-open .sem-star-card__panel {
  grid-template-rows: 1fr;
  opacity: 1;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__list--syllabus {
  margin: 0.42rem 0 0;
  padding: 0;
  list-style: none;
  counter-reset: semsyll;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__list--syllabus li {
  counter-increment: semsyll;
  position: relative;
  padding-left: 1.55rem;
  margin: 0.35rem 0;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__list--syllabus li::before {
  content: counter(semsyll);
  position: absolute;
  left: 0;
  top: 0.02rem;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 0.68rem;
  font-weight: 800;
  color: var(--z2h-public-accent-strong);
  background: #e8f7f4;
  border: 1px solid #c5ece6;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__footer {
  margin-top: auto;
  padding-top: 0.8rem;
  border-top: 1px solid var(--z2h-public-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.36rem;
  text-align: center;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__note {
  text-align: center;
}

body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__cta {
  margin: 0.04rem auto 0;
  display: inline-flex;
  justify-content: center;
}

@keyframes z2h-case-marquee {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee {
  position: relative;
  overflow: hidden;
  --z2h-case-track-gap: 0;
  --z2h-case-card-gap: 0;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::before,
body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 30px;
  pointer-events: none;
  z-index: 2;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::before {
  left: 0;
  background: linear-gradient(90deg, #ffffff 6%, rgba(255, 255, 255, 0));
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::after {
  right: 0;
  background: linear-gradient(270deg, #ffffff 6%, rgba(255, 255, 255, 0));
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case-viewport {
  overflow: hidden;
  padding: 0;
  scroll-snap-type: none;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case-track {
  display: flex;
  gap: var(--z2h-case-track-gap);
  width: max-content;
  will-change: transform;
  transform: translate3d(0, 0, 0);
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case-lane {
  display: flex;
  gap: var(--z2h-case-card-gap);
  min-width: max-content;
  flex-shrink: 0;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee[data-loop="true"] .z2h-case-track {
  animation: z2h-case-marquee var(--z2h-case-duration, 36s) linear infinite;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee.is-js-marquee[data-loop="true"] .z2h-case-track {
  animation: none;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case {
  flex: 0 0 clamp(286px, 29vw, 360px);
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0.2rem;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 0.48rem;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__preview {
  border-radius: 14px;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__preview img,
body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__preview--reef {
  height: 198px;
  min-height: 198px;
  border: 1px solid var(--z2h-public-border);
  border-radius: 14px;
  background: #f4f7f9;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__body {
  gap: 0.42rem;
  padding-inline: 0.12rem;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__top {
  margin-bottom: 0;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__client {
  font-style: normal;
  font-size: 0.73rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #687385;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__title {
  margin: 0;
  font-size: 1.04rem;
  line-height: 1.3;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__desc {
  margin: 0;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__footer {
  border-top: 0;
  padding-top: 0.05rem;
  padding-inline: 0.12rem;
}

body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.88rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.2rem 0 0.1rem !important;
}

body.z2h-public-skin .z2h-public-index .z2h-section-plain {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.2rem 0 0.1rem !important;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-communities__head {
  border-bottom: 0;
  padding-bottom: 0;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-grid {
  row-gap: 0.82rem;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card {
  display: grid;
  gap: 0.56rem;
  border: 1px solid #d9e1e8;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 8px 18px rgba(15, 17, 21, 0.035);
  text-decoration: none;
  color: #11141a;
  height: 100%;
  padding: 0.95rem 0.95rem 0.84rem;
  transition: border-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card:hover {
  border-color: #c6e1db;
  box-shadow: 0 14px 24px rgba(15, 17, 21, 0.075);
  transform: translateY(-2px);
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card h4 {
  margin: 0;
  font-size: 1.03rem;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card p {
  margin: 0;
  color: var(--z2h-public-muted);
  font-size: 0.9rem;
  line-height: 1.52;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-badge {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  border: 1px solid #c9ebe6;
  background: #e9f7f4;
  color: #0d6f64;
  padding: 0.2rem 0.6rem;
  font-size: 0.72rem;
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-link {
  display: inline-flex;
  width: fit-content;
  justify-content: center;
  margin: 0.2rem auto 0;
  font-size: 0.84rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.34s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.08rem;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header {
  align-items: flex-end;
  gap: 0.75rem 1.2rem;
  margin-bottom: 1.32rem !important;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header h3 {
  font-size: clamp(1.32rem, 2.35vw, 1.78rem);
  letter-spacing: -0.01em;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header .z2h-subtle {
  margin-top: 0.34rem !important;
  max-width: 60ch;
  line-height: 1.58;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-section-link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.88rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.08rem;
  white-space: nowrap;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-section-link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.88rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.08rem;
  white-space: nowrap;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid {
  row-gap: 0.88rem;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile {
  border-color: #d6dee5 !important;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%) !important;
  border-radius: 16px !important;
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.045) !important;
  transition: transform 0.44s ease, box-shadow 0.44s ease, border-color 0.44s ease;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile:hover {
  transform: translateY(-3px);
  border-color: #c7ddd8 !important;
  box-shadow: 0 16px 28px rgba(15, 17, 21, 0.078) !important;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__media {
  min-height: 0;
  aspect-ratio: 16 / 10;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #f4f6f8;
  border-bottom: 1px solid #edf1f4;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__media--empty {
  background: linear-gradient(180deg, #f8fafc 0%, #f2f5f8 100%);
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__media-empty-copy {
  font-size: 0.78rem;
  color: #5b6272;
  letter-spacing: 0.06em;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__topic-wrap {
  position: absolute;
  left: 0.68rem;
  top: 0.66rem;
  z-index: 1;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__topic {
  display: inline-flex;
  border-radius: 999px;
  border: 1px solid rgba(190, 205, 219, 0.9);
  background: rgba(255, 255, 255, 0.9);
  color: #203040;
  padding: 0.2rem 0.58rem;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__content {
  padding: 0.88rem 0.94rem 0.9rem;
  gap: 0.46rem;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__title {
  font-size: 1.04rem;
  line-height: 1.32;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__desc {
  margin: 0.1rem 0 0.24rem;
  font-size: 0.9rem;
  line-height: 1.54;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta {
  margin-top: 0.04rem;
  padding-top: 0.52rem;
  border-top: 1px solid #edf1f4;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.48rem;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-item {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-label {
  color: #6b7382;
  font-size: 0.67rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-value {
  color: #1b2430;
  font-size: 0.83rem;
  font-weight: 700;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-tile__cta {
  justify-content: center;
  margin-top: 0.08rem;
}

body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__cta-link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.87rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-index .z2h-consult--compact {
  height: 100%;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult--compact,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card {
  border: 1px solid #d5dee6;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 10px 20px rgba(15, 17, 21, 0.045);
  padding: 1.1rem 1.14rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  height: 100%;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult--compact::before,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card::before {
  content: none;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult--compact {
  border-color: #cfe4df;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%);
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult--compact::before {
  content: none;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__eyebrow {
  margin: 0;
  color: var(--z2h-public-accent);
  letter-spacing: 0.09em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__title {
  margin: 0;
  font-size: clamp(1.32rem, 2.25vw, 1.8rem);
  line-height: 1.16;
  color: #0f1115;
  max-width: 21ch;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__desc {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.52;
  max-width: 60ch;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__impact {
  margin: 0;
  color: #1f2a38;
  font-size: 0.89rem;
  font-weight: 600;
  line-height: 1.5;
  max-width: 58ch;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card__list {
  list-style: none;
  margin: 0.2rem 0 0.78rem;
  padding: 0;
  display: grid;
  gap: 0.38rem;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list li,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card__list li {
  position: relative;
  margin: 0;
  padding-left: 1.02rem;
  line-height: 1.5;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list li::before,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #8fcfc5;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list li strong,
body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card__list li strong {
  color: #0f1115;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__cta {
  font-size: 0.92rem;
  font-weight: 700;
  text-decoration-thickness: 1.7px;
  text-underline-offset: 3px;
  margin-top: auto;
}

body.z2h-public-skin .z2h-public-index .z2h-work-card__list {
  margin: 0 0 0.85rem;
  padding-left: 1rem;
}

body.z2h-public-skin .z2h-public-index .z2h-work-card__list li {
  margin: 0.26rem 0;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card .z2h-consult__title {
  max-width: 21ch;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card .z2h-consult__desc {
  max-width: 58ch;
}

body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card .z2h-consult__cta {
  margin-top: auto;
  width: fit-content;
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__title {
    min-height: 4.25rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__desc {
    min-height: 4.4rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__impact {
    min-height: 2.9rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list {
    min-height: 8.2rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__title {
    min-height: 4.2rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__desc {
    min-height: 3rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__impact {
    min-height: 2.9rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list {
    min-height: 8.2rem;
  }
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.2rem 0 0.38rem !important;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__body,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__body {
  align-items: end;
  gap: 0.8rem 1.1rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__title,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__title {
  line-height: 1.12;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__sub,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__sub {
  margin: 0.38rem 0 0;
  max-width: 64ch;
  line-height: 1.56;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__meta,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__meta {
  display: none !important;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-action-link,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-action-link {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.9rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-hero-action-link:hover,
body.z2h-public-skin .z2h-public-semilleros .z2h-hero-action-link:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search {
  border: 1px solid var(--z2h-public-border) !important;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 8px 18px rgba(15, 17, 21, 0.04);
  padding: 0.9rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.78fr) minmax(0, 0.78fr) auto;
  gap: 0.72rem;
  align-items: end;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__field {
  min-width: 0;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__label {
  margin: 0 0 0.28rem;
  font-size: 0.69rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--z2h-public-muted);
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-courses .z2h-searchgroup--minimal {
  border: 1px solid var(--z2h-public-border);
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
}

body.z2h-public-skin .z2h-public-courses .z2h-searchgroup--minimal .input-group-text {
  border: 0;
  background: #ffffff;
  color: #6b7382;
  padding-inline: 0.7rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-searchgroup--minimal .form-control {
  border: 0;
  min-height: 42px;
  padding-left: 0.1rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-searchgroup--minimal .form-control:focus {
  box-shadow: none;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search .z2h-select {
  min-height: 42px;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.68rem;
  min-height: 42px;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__clear {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.84rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.05rem;
  white-space: nowrap;
}

body.z2h-public-skin .z2h-public-courses .z2h-courses-search__actions .btn {
  min-height: 42px;
  border-radius: 999px;
  padding-inline: 1rem;
  white-space: nowrap;
}

body.z2h-public-skin .z2h-public-courses .z2h-tile__cta {
  justify-content: flex-start;
  margin-top: 0.08rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-tile__cta-link {
  display: inline-flex;
  width: fit-content;
  font-size: 0.87rem;
  font-weight: 700;
  color: #0f1115;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-courses .z2h-tile:hover .z2h-tile__cta-link,
body.z2h-public-skin .z2h-public-courses .z2h-tile:focus-visible .z2h-tile__cta-link {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.2rem 0 0.34rem !important;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.32fr) minmax(0, 0.82fr);
  gap: 1rem 1.25rem;
  align-items: start;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__summary {
  margin: 0.5rem 0 0;
  color: var(--z2h-public-muted);
  line-height: 1.58;
  max-width: 68ch;
  text-align: justify;
  text-justify: inter-word;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__facts {
  margin-top: 0.56rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem 0.72rem;
  color: #3f4b5b;
  font-size: 0.84rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__facts span {
  position: relative;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__facts span + span::before {
  content: "";
  position: absolute;
  left: -0.42rem;
  top: 0.54em;
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: #a8b2c0;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__links {
  margin-top: 0.56rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.52rem 1rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__links a {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.87rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-card {
  border: 1px solid var(--z2h-public-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.045);
  padding: 0.9rem;
  display: grid;
  gap: 0.66rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-card__eyebrow {
  margin: 0;
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--z2h-public-accent);
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.42rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpi {
  border: 1px solid var(--z2h-public-border);
  border-radius: 10px;
  background: #f8f9fa;
  text-align: center;
  padding: 0.38rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpi strong {
  display: block;
  line-height: 1.16;
  font-size: 1.02rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpi span {
  display: block;
  color: var(--z2h-public-muted);
  font-size: 0.68rem;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-card__note {
  margin: 0;
  color: var(--z2h-public-muted);
  font-size: 0.79rem;
  line-height: 1.45;
}

body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-card .btn {
  width: 100%;
  justify-content: center;
  min-height: 41px;
}

body.z2h-public-skin .z2h-public-semillero .sem-description--minimal,
body.z2h-public-skin .z2h-public-semillero .sem-highlights--minimal,
body.z2h-public-skin .z2h-public-semillero .sem-roadmap {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.1rem 0 !important;
}

body.z2h-public-skin .z2h-public-semillero .sem-description__text {
  margin: 0.28rem 0 0;
  color: var(--z2h-public-muted);
  line-height: 1.62;
}

body.z2h-public-skin .z2h-public-semillero .sem-highlights__list {
  margin: 0.44rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.42rem 0.85rem;
}

body.z2h-public-skin .z2h-public-semillero .sem-highlights__list li {
  position: relative;
  padding-left: 1rem;
  color: #1a1f28;
}

body.z2h-public-skin .z2h-public-semillero .sem-highlights__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #a8d8d0;
}

body.z2h-public-skin .z2h-public-semillero .sem-detail-grid {
  margin-top: 0.36rem;
}

body.z2h-public-skin .z2h-public-semillero .sem-detail-grid .sem-panel {
  border-color: #d8e0e8 !important;
  box-shadow: 0 8px 16px rgba(15, 17, 21, 0.04) !important;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap__head {
  margin-bottom: 0.72rem;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap__title {
  font-size: clamp(1.32rem, 2.5vw, 1.85rem);
  line-height: 1.2;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap__stack {
  gap: 0.62rem;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap-item {
  border-radius: 14px !important;
  box-shadow: none !important;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap-toggle {
  background: #ffffff !important;
}

body.z2h-public-skin .z2h-public-semillero .sem-roadmap-panel__grid {
  background: #fcfdfd;
}

body.z2h-public-skin .z2h-public-semillero .sem-detail-back a {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__aside {
    position: sticky;
    top: 5.9rem;
  }
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-grid {
  display: grid;
  gap: 0.95rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card {
  border: 1px solid var(--z2h-public-border);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.05);
  padding: 1rem;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr);
  gap: 1rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__head {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.45rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__badge {
  display: inline-flex;
  border: 1px solid var(--z2h-public-border);
  border-radius: 999px;
  padding: 0.2rem 0.58rem;
  font-size: 0.72rem;
  font-weight: 700;
  background: #f4f6f8;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__title {
  margin: 0;
  font-size: 1.22rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__tagline,
body.z2h-public-skin .z2h-public-semilleros .sem-program-card__desc {
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__tagline {
  margin: 0.34rem 0 0.2rem;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__desc {
  margin: 0;
  font-size: 0.9rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
  margin-top: 0.75rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-stat {
  border: 1px solid var(--z2h-public-border);
  border-radius: 10px;
  background: #f8f9fa;
  text-align: center;
  padding: 0.45rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-stat strong {
  display: block;
  line-height: 1.2;
  font-size: 1.08rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-stat span {
  font-size: 0.74rem;
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__syllabus {
  border: 1px solid var(--z2h-public-border);
  border-radius: 12px;
  background: #f7f9fa;
  padding: 0.75rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__kicker {
  margin: 0;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--z2h-public-accent);
  font-weight: 800;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__list {
  margin: 0.5rem 0 0;
  padding-left: 1rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__list li {
  margin: 0.3rem 0;
  color: #1a1f28;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__footer {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  border-top: 1px solid var(--z2h-public-border);
  padding-top: 0.7rem;
}

body.z2h-public-skin .z2h-public-semilleros .sem-program-card__note {
  color: var(--z2h-public-muted);
  font-size: 0.84rem;
}

body.z2h-public-skin .z2h-footer-minimal {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 1rem 1.4rem;
}

@media (max-width: 991.98px) {
  body.z2h-public-skin .z2h-public-index .z2h-home-hero__grid--minimal {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__panel--image {
    display: none;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero {
    padding: 1rem 0 0.85rem !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__copy {
    max-width: 100%;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__lead {
    max-width: 62ch;
    font-size: 0.97rem;
    line-height: 1.56;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__ctas {
    gap: 0.5rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__body,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__body {
    align-items: start;
    gap: 0.7rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-hero-action-link,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-action-link {
    margin-left: 0.02rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__field--query {
    grid-column: 1 / -1;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__grid {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__aside {
    width: 100%;
  }

  body.z2h-public-skin .z2h-public-semilleros .sem-program-card {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-semilleros .sem-program-card__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.z2h-public-skin .z2h-footer-minimal {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain {
    padding: 0.04rem 0 0.28rem !important;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__body,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__body {
    gap: 0.56rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-hero-slim--plain .z2h-hero-slim__actions,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-slim--plain .z2h-hero-slim__actions {
    width: 100%;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-hero-action-link,
  body.z2h-public-skin .z2h-public-semilleros .z2h-hero-action-link {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search {
    border-radius: 14px;
    padding: 0.76rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__grid {
    grid-template-columns: 1fr;
    gap: 0.62rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__actions {
    justify-content: center;
    flex-direction: column;
    align-items: stretch;
    gap: 0.44rem;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__clear {
    align-self: center;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-courses .z2h-courses-search__actions .btn {
    width: 100%;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero {
    padding: 0.04rem 0 0.26rem !important;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__summary {
    margin-top: 0.42rem;
    font-size: 0.92rem;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__facts {
    gap: 0.24rem 0.6rem;
    font-size: 0.8rem;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__links {
    flex-direction: column;
    gap: 0.38rem;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-hero__links a {
    width: fit-content;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-card {
    border-radius: 14px;
    padding: 0.82rem;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpis {
    gap: 0.3rem;
  }

  body.z2h-public-skin .z2h-public-semillero .z2h-sem-detail-kpi span {
    font-size: 0.66rem;
  }

  body.z2h-public-skin .z2h-public-semillero .sem-highlights__list {
    grid-template-columns: 1fr;
    gap: 0.34rem;
  }

  body.z2h-public-skin .z2h-public-index > section {
    margin-bottom: 4.28rem !important;
  }

  body.z2h-public-skin .z2h-public-index > section:last-of-type {
    margin-bottom: 0 !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero {
    padding: 0.88rem 0 0.7rem !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__eyebrow {
    font-size: 0.66rem;
    letter-spacing: 0.1em;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__title {
    font-size: clamp(1.46rem, 8.2vw, 1.92rem);
    line-height: 1.12;
    max-width: 17ch;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__lead {
    margin-top: 0.58rem;
    font-size: 0.93rem;
    line-height: 1.54;
    padding-inline: 0.65rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__ctas .btn {
    min-height: 40px;
    width: 60vw;
    min-width: 60vw;
    max-width: 60vw;
    padding-inline: 0.95rem;
    padding-block: 0.38rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-home-hero__ctas {
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-card,
  body.z2h-public-skin .z2h-public-index .z2h-work-card {
    padding: 0.9rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh {
    margin-bottom: 2.26rem !important;
    row-gap: 0.86rem;
    padding-bottom: 0;
    position: static;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh::after {
    display: none;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card {
    border-radius: 14px;
    padding: 0.96rem 0.98rem;
    box-shadow: 0 8px 16px rgba(15, 17, 21, 0.04);
    gap: 0.42rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__title {
    font-size: clamp(1.2rem, 6.4vw, 1.48rem);
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__desc {
    font-size: 0.92rem;
    line-height: 1.52;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__impact {
    font-size: 0.88rem;
    line-height: 1.48;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card__list {
    margin: 0.22rem 0 0.72rem;
    gap: 0.34rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-link {
    font-size: 0.86rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-service-summary--refresh .z2h-service-card--dev {
    border: 1px solid #d5dee6;
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
    box-shadow: 0 8px 16px rgba(15, 17, 21, 0.04);
    padding: 0.96rem 0.98rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-head,
  body.z2h-public-skin .z2h-public-index .z2h-devs-head,
  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header,
  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header {
    flex-direction: column;
    align-items: stretch !important;
    gap: 0.56rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-head > div,
  body.z2h-public-skin .z2h-public-index .z2h-devs-head > div,
  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header > div,
  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header > div {
    width: 100%;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-head > .btn,
  body.z2h-public-skin .z2h-public-index .z2h-devs-head .z2h-case-cta,
  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header > .z2h-section-link {
    align-self: center;
    width: min(84vw, 320px);
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header > .z2h-section-link {
    align-self: center;
    width: min(84vw, 320px);
  }

  body.z2h-public-skin .z2h-public-index .sem-star-head > .btn,
  body.z2h-public-skin .z2h-public-index .z2h-devs-head .z2h-case-cta > .btn {
    width: 100%;
    min-height: 42px;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-devs-head .z2h-case-cta {
    display: flex;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header > .z2h-section-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.44rem 0.9rem;
    border: 1px solid var(--z2h-public-border-strong);
    border-radius: 999px;
    background: #ffffff;
    color: #0f1115;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header > .z2h-section-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.44rem 0.9rem;
    border: 1px solid var(--z2h-public-border-strong);
    border-radius: 999px;
    background: #ffffff;
    color: #0f1115;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header > .z2h-section-link::after {
    display: none;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header > .z2h-section-link::after {
    display: none;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header {
    align-items: stretch !important;
    gap: 0.5rem;
    margin-bottom: 1.02rem !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header {
    align-items: stretch !important;
    gap: 0.5rem;
    margin-bottom: 1.02rem !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header h3 {
    font-size: clamp(1.24rem, 6.8vw, 1.48rem);
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header h3 {
    font-size: clamp(1.24rem, 6.8vw, 1.48rem);
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header .z2h-subtle {
    font-size: 0.91rem;
    line-height: 1.5;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header .z2h-subtle {
    font-size: 0.91rem;
    line-height: 1.5;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-courses-header .z2h-section-link {
    margin-left: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--packages .z2h-courses-header .z2h-section-link {
    margin-left: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid {
    row-gap: 0.9rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid > [class*="col-"] {
    padding-top: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid > [class*="col-"] + [class*="col-"] {
    border-top: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile {
    border: 1px solid #d5dde5 !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%) !important;
    box-shadow: 0 8px 16px rgba(15, 17, 21, 0.042) !important;
    display: block;
    padding: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile:hover {
    transform: none;
    box-shadow: 0 8px 16px rgba(15, 17, 21, 0.042) !important;
    border-color: #d5dde5 !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__media {
    min-height: 0;
    height: auto;
    aspect-ratio: 16 / 10;
    border: 1px solid var(--z2h-public-border);
    border-radius: 12px;
    border-bottom: 1px solid var(--z2h-public-border);
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__topic-wrap {
    left: 0.58rem;
    top: 0.56rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__topic {
    font-size: 0.64rem;
    padding: 0.18rem 0.5rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__content {
    padding: 0.76rem 0.8rem 0.82rem;
    gap: 0.4rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__title {
    font-size: 0.99rem;
    line-height: 1.3;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-featured-grid .z2h-course-tile .z2h-tile__desc {
    margin: 0.08rem 0 0.2rem;
    font-size: 0.86rem;
    line-height: 1.48;
    -webkit-line-clamp: 3;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta {
    grid-template-columns: 1fr;
    gap: 0.32rem;
    margin-top: 0;
    padding-top: 0.42rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.56rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-label {
    font-size: 0.64rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile__meta-value {
    font-size: 0.8rem;
    text-align: right;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__cta {
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-index .z2h-featured--refined .z2h-course-tile .z2h-tile__cta-link {
    font-size: 0.84rem;
  }

  body.z2h-public-skin .z2h-auth-screen {
    padding-inline: 0.3rem;
  }

  body.z2h-public-skin .z2h-auth-screen .z2h-auth-card {
    border-radius: 14px;
  }

  body.z2h-public-skin .z2h-auth-screen .z2h-auth-card .card-body {
    padding: 0.96rem !important;
  }

  body.z2h-public-skin .z2h-auth-screen .form-control,
  body.z2h-public-skin .z2h-auth-screen .form-select {
    min-height: 42px;
  }

  body.z2h-public-skin .z2h-public-index .z2h-semillero-stars {
    padding-top: 0.14rem !important;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels {
    margin-top: 1rem !important;
    row-gap: 0.82rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult--compact,
  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card {
    border-radius: 14px;
    padding: 0.98rem 1rem;
    box-shadow: 0 8px 16px rgba(15, 17, 21, 0.04);
    gap: 0.42rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__title {
    font-size: clamp(1.18rem, 6.2vw, 1.44rem);
    max-width: 20ch;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__desc {
    font-size: 0.92rem;
    margin-top: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__impact {
    font-size: 0.86rem;
    line-height: 1.46;
  }

  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-consult__list,
  body.z2h-public-skin .z2h-public-index .z2h-bottom-panels .z2h-work-card__list {
    margin: 0.24rem 0 0.72rem;
    gap: 0.32rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee {
    --z2h-case-track-gap: 0;
    --z2h-case-card-gap: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::before,
  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee::after {
    width: 24px;
  }

  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case {
    flex-basis: min(81vw, 314px);
  }

  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__preview img,
  body.z2h-public-skin .z2h-public-index .z2h-case-carousel--marquee .z2h-case__preview--reef {
    height: 176px;
    min-height: 176px;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-grid {
    row-gap: 0;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-grid > [class*="col-"] {
    padding-top: 0.62rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-grid > [class*="col-"] + [class*="col-"] {
    border-top: 1px solid var(--z2h-public-border);
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: 0.18rem 0.1rem 0.76rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card:hover {
    transform: none;
    box-shadow: none;
    border-color: transparent;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-badge {
    border: 0;
    background: transparent;
    color: var(--z2h-public-accent);
    padding: 0;
    font-size: 0.66rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card h4 {
    font-size: 1rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-card p {
    font-size: 0.92rem;
  }

  body.z2h-public-skin .z2h-public-index .z2h-communities--minimal .z2h-community-link {
    margin-top: 0.34rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-card--annual {
    padding: 0.94rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.34rem;
    margin-top: 0.54rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__preview {
    margin-top: 0.64rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__panel {
    transition-duration: 1.08s;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-card--annual .sem-star-card__note {
    font-size: 0.82rem;
  }

  body.z2h-public-skin .z2h-public-index .sem-star-head,
  body.z2h-public-skin .z2h-public-index .z2h-devs-head,
  body.z2h-public-skin .z2h-public-index .z2h-communities__head,
  body.z2h-public-skin .z2h-public-index .z2h-courses-header {
    margin-bottom: 0.92rem !important;
  }

  body.z2h-public-skin .z2h-public-semilleros .sem-program-card__stats {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-semilleros .sem-program-card__footer {
    flex-direction: column;
    align-items: stretch;
  }

  body.z2h-public-skin .z2h-footer-minimal {
    grid-template-columns: 1fr;
  }
}

/* Phase 4.2: nav link underline animation */
.z2h-link-reveal {
  --z2h-link-reveal-duration: 1.16s;
  --z2h-link-reveal-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --z2h-link-reveal-thickness: 2px;
  position: relative;
}

.z2h-link-reveal::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--z2h-link-reveal-thickness);
  border-radius: 999px;
  background: currentcolor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--z2h-link-reveal-duration) var(--z2h-link-reveal-ease);
  pointer-events: none;
}

.z2h-link-reveal:hover::after,
.z2h-link-reveal:focus-visible::after {
  transform: scaleX(1);
  transform-origin: left center;
}

.z2h-link-reveal:not(:hover):not(:focus-visible)::after {
  transform-origin: right center;
}

.z2h-nav a.nav-link:not(#nav-signup) {
  position: relative;
}

.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle)::after {
  content: "";
  display: block !important;
  position: absolute;
  left: 0.78rem;
  right: 0.78rem;
  bottom: 0.26rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #009688, #00b39f);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--z2h-link-reveal-duration, 1.16s) var(--z2h-link-reveal-ease, cubic-bezier(0.22, 0.61, 0.36, 1));
  pointer-events: none;
}

.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle):hover::after,
.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle):focus-visible::after,
.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle).is-current::after,
.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle)[aria-current="page"]::after {
  transform: scaleX(1);
  transform-origin: left center;
}

.z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle):not(.is-current):not([aria-current="page"]):not(:hover):not(:focus-visible)::after {
  transform-origin: right center;
}

.z2h-nav a.nav-link.dropdown-toggle::before {
  content: "";
  display: block;
  position: absolute;
  left: 0.78rem;
  right: 1.5rem;
  bottom: 0.26rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #009688, #00b39f);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--z2h-link-reveal-duration, 1.16s) var(--z2h-link-reveal-ease, cubic-bezier(0.22, 0.61, 0.36, 1));
  pointer-events: none;
}

.z2h-nav a.nav-link.dropdown-toggle:hover::before,
.z2h-nav a.nav-link.dropdown-toggle:focus-visible::before,
.z2h-nav a.nav-link.dropdown-toggle.is-current::before,
.z2h-nav .dropdown.show > a.nav-link.dropdown-toggle::before {
  transform: scaleX(1);
  transform-origin: left center;
}

.z2h-nav a.nav-link.dropdown-toggle:not(.is-current):not(:hover):not(:focus-visible)::before {
  transform-origin: right center;
}

.z2h-nav .z2h-nav-main .nav-link:hover {
  background: transparent;
  border-color: transparent;
}

.z2h-nav .z2h-nav-pill--ghost:hover {
  box-shadow: none;
}

body.z2h-public-skin .z2h-nav .z2h-nav-main .nav-link:hover {
  background: transparent;
  border-color: transparent;
}

@media (max-width: 991.98px) {
  .z2h-nav .z2h-nav-mobile-head {
    justify-content: flex-start;
    margin-bottom: 0.55rem;
    padding-bottom: 0.55rem;
    border-bottom: 1px solid var(--u-border);
  }

  .z2h-nav .z2h-nav-main .nav-link {
    justify-content: flex-start;
    text-align: left;
    padding-left: 0.92rem;
  }

  .z2h-nav a.nav-link:not(#nav-signup):not(.dropdown-toggle)::after {
    left: 0.92rem;
    right: 0.92rem;
  }

  .z2h-nav a.nav-link.dropdown-toggle::before {
    left: 0.92rem;
    right: 2rem;
  }

  body.z2h-public-skin .z2h-nav .z2h-nav-mobile-head {
    border-bottom-color: var(--z2h-public-border);
  }
}

/* Phase 4.3: footer refresh */
.z2h-footer {
  --z2h-footer-bg: #ffffff;
  --z2h-footer-text: var(--u-text);
  --z2h-footer-muted: #5f6876;
  --z2h-footer-border: var(--u-border);
  --z2h-footer-accent: #009688;
  position: relative;
  background: var(--z2h-footer-bg);
  color: var(--z2h-footer-text);
  margin-top: 2.8rem;
  border-top: 1px solid var(--z2h-footer-border);
}

body.z2h-public-skin .z2h-footer {
  --z2h-footer-text: var(--z2h-public-text);
  --z2h-footer-muted: var(--z2h-public-muted);
  --z2h-footer-border: var(--z2h-public-border);
  --z2h-footer-accent: var(--z2h-public-accent);
}

.z2h-footer::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 150, 136, 0.24) 16%,
    rgba(0, 150, 136, 0.68) 50%,
    rgba(0, 150, 136, 0.24) 84%,
    transparent 100%
  );
  pointer-events: none;
}

.z2h-footer__reveal {
  padding: 1.95rem 0 1.08rem;
}

.z2h-footer-minimal {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 1rem 1.8rem;
  align-items: start;
}

.z2h-footer-brand {
  display: grid;
  gap: 0.55rem;
  max-width: 40ch;
}

.z2h-footer-brand-link {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 0.52rem;
  color: var(--z2h-footer-text);
  font-family: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 1.04rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.z2h-footer-brand-link:hover,
.z2h-footer-brand-link:focus-visible {
  color: var(--z2h-footer-text);
}

.z2h-footer-brand-glyph {
  display: grid;
  place-items: center;
  color: var(--z2h-footer-accent);
  font-size: 0.92rem;
}

.z2h-footer-logo {
  line-height: 1;
}

.z2h-footer-tag {
  margin: 0;
  color: var(--z2h-footer-muted);
  font-size: 0.92rem;
  line-height: 1.6;
}

.z2h-footer-col {
  min-width: 0;
}

.z2h-footer-title {
  margin: 0 0 0.52rem;
  color: var(--z2h-footer-accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.z2h-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.4rem;
}

.z2h-footer-list a,
.z2h-footer-right a {
  position: relative;
  display: inline-flex;
  width: fit-content;
  color: var(--z2h-footer-muted);
  font-weight: 600;
  font-size: 0.92rem;
  padding-bottom: 0.08rem;
  transition: color 0.22s ease;
}

.z2h-footer-list a::after,
.z2h-footer-right a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1.5px;
  border-radius: 999px;
  background: linear-gradient(90deg, #009688, #00b39f);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.92s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: none;
}

.z2h-footer-list a:hover::after,
.z2h-footer-list a:focus-visible::after,
.z2h-footer-right a:hover::after,
.z2h-footer-right a:focus-visible::after {
  transform: scaleX(1);
  transform-origin: left center;
}

.z2h-footer-list a:not(:hover):not(:focus-visible)::after,
.z2h-footer-right a:not(:hover):not(:focus-visible)::after {
  transform-origin: right center;
}

.z2h-footer-list a:hover,
.z2h-footer-list a:focus-visible,
.z2h-footer-right a:hover,
.z2h-footer-right a:focus-visible {
  color: var(--z2h-footer-text);
}

.z2h-footer-bottom {
  margin-top: 1.28rem;
  padding-top: 0.8rem;
  border-top: 1px solid var(--z2h-footer-border);
  color: var(--z2h-footer-muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem 0.9rem;
  font-size: 0.84rem;
}

.z2h-footer-left {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
}

.z2h-footer-right {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.z2h-footer-right span {
  color: #a7b0bc;
}

.z2h-footer-right [aria-disabled="true"] {
  opacity: 0.56;
  pointer-events: none;
}

.z2h-footer-right [aria-disabled="true"]::after {
  display: none;
}

@media (max-width: 991.98px) {
  .z2h-footer__reveal {
    padding: 1.65rem 0 1rem;
  }

  .z2h-footer-minimal {
    grid-template-columns: 1fr 1fr;
    gap: 0.9rem 1.2rem;
  }

  .z2h-footer-brand {
    grid-column: 1 / -1;
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .z2h-footer {
    margin-top: 2.2rem;
  }

  .z2h-footer-minimal {
    grid-template-columns: 1fr;
    gap: 0.95rem;
  }

  .z2h-footer-bottom {
    margin-top: 1rem;
    padding-top: 0.7rem;
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Phase 4.4: public contact redesign */
body.z2h-public-skin .z2h-public-contact .z2h-contact-hero--minimal {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 1.2rem 0 0.95rem !important;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__body--minimal {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.95fr);
  gap: 0.95rem 1.45rem;
  align-items: start;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__copy {
  max-width: 67ch;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact__title {
  font-size: clamp(1.85rem, 4.7vw, 2.95rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact__sub {
  margin-top: 0.56rem;
  max-width: 60ch;
  color: var(--z2h-public-muted);
  line-height: 1.6;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__quick {
  display: grid;
  justify-items: flex-start;
  gap: 0.55rem;
  margin-top: 2.05rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-whatsapp {
  min-height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding-inline: 1.12rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 12px 24px rgba(0, 150, 136, 0.2);
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-whatsapp i {
  font-size: 1.02rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-quick-note {
  margin: 0;
  color: var(--z2h-public-muted);
  font-size: 0.9rem;
  line-height: 1.52;
  max-width: 39ch;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(0, 0.9fr);
  gap: 1rem 1.25rem;
  align-items: start;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-panel {
  min-width: 0;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-panel--form {
  border: 1px solid var(--z2h-public-border);
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.05);
  padding: 1.05rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-panel--meta {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0.16rem 0 0;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-form-intro {
  margin: 0 0 0.82rem;
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-form .form-control {
  min-height: 44px;
  border-radius: 12px;
  border-color: var(--z2h-public-border);
  padding: 0.6rem 0.72rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-form textarea.form-control {
  min-height: 150px;
  resize: vertical;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-form-actions {
  display: flex;
  align-items: center;
  gap: 0.62rem;
  flex-wrap: wrap;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-meta-group + .z2h-contact-meta-group {
  margin-top: 1rem;
  padding-top: 0.9rem;
  border-top: 1px solid var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-meta-title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--z2h-public-text);
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-list {
  list-style: none;
  margin: 0.56rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.55rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-list li {
  display: grid;
  gap: 0.12rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-label {
  color: var(--z2h-public-muted);
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-link,
body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-value {
  color: var(--z2h-public-text);
  font-weight: 600;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-channel-link:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-contact .z2h-socials {
  gap: 0.45rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-social-chip {
  border-radius: 999px;
  font-size: 0.86rem;
  padding: 0.34rem 0.72rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-team-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.45rem;
  margin-top: 0.55rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-team-inline span {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--z2h-public-border);
  background: #f7f8f9;
  border-radius: 999px;
  padding: 0.22rem 0.58rem;
  font-size: 0.79rem;
  color: #151920;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-team-note {
  margin: 0.52rem 0 0;
  color: var(--z2h-public-muted);
  font-size: 0.82rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructors {
  margin-top: 0.15rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructors__head {
  margin-bottom: 0.68rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructors__row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.72rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor {
  display: flex;
  flex-direction: column;
  gap: 0.58rem;
  border: 0;
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(15, 17, 21, 0.05);
  padding: 0.72rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__body {
  min-width: 0;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__media {
  width: 100%;
  height: clamp(236px, 22vw, 304px);
  display: grid;
  place-items: center;
  background: #f7f9fa;
  border-radius: 12px;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__media img,
body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__placeholder {
  width: 100%;
  height: 100%;
  border-radius: 0;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__media img {
  object-fit: contain;
  object-position: center top;
  border: 0;
  display: block;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__placeholder {
  display: grid;
  place-items: center;
  border: 0;
  background: #f6f8f9;
  color: #6f7783;
  font-size: 1.04rem;
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__name {
  margin: 0;
  font-size: 0.96rem;
  font-weight: 800;
  color: var(--z2h-public-text);
}

body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__desc {
  margin: 0.28rem 0 0;
  color: var(--z2h-public-muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

@media (max-width: 991.98px) {
  body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__body--minimal,
  body.z2h-public-skin .z2h-public-contact .z2h-contact-layout {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-hero--minimal {
    padding: 1rem 0 0.82rem !important;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-form-grid {
    grid-template-columns: 1fr;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__quick {
    margin-top: 0;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-instructors__row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.z2h-public-skin .z2h-public-contact .z2h-contact-hero--minimal {
    padding: 0.9rem 0 0.72rem !important;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact__title {
    font-size: clamp(1.45rem, 8.3vw, 1.94rem);
    line-height: 1.12;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact__sub {
    font-size: 0.95rem;
    line-height: 1.55;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-whatsapp {
    width: 100%;
    justify-content: center;
    padding-inline: 0.9rem;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-hero__quick {
    justify-items: center;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-quick-note {
    text-align: center;
    max-width: 34ch;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-quick-actions {
    width: 100%;
    flex-direction: column;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-quick-actions .btn {
    width: 100%;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-panel--form {
    padding: 0.9rem;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-form-actions {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-form-actions .btn {
    align-self: center;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor {
    width: min(100%, 340px);
    margin-inline: auto;
  }

  body.z2h-public-skin .z2h-public-contact .z2h-contact-instructor__media {
    height: clamp(238px, 62vw, 292px);
  }
}

/* Phase 4.9: course detail minimalist refinement */
body.z2h-public-skin .z2h-public-course {
  padding-top: 0.08rem;
}

body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.18rem 0 0.42rem !important;
}

body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain .z2h-hero-slim__body {
  align-items: flex-end;
  gap: 0.82rem 1.2rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__copy {
  max-width: 72ch;
}

body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain .z2h-hero-slim__sub {
  margin: 0.4rem 0 0;
  max-width: 62ch;
  line-height: 1.58;
}

body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__actions {
  align-items: center;
  gap: 0.52rem 0.9rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__actions .btn {
  min-height: 42px;
  padding-inline: 1.08rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__link {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.9rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__link:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb-wrap {
  margin-bottom: 1.08rem !important;
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: 0.81rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  color: #98a2b3;
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb .breadcrumb-item {
  color: var(--z2h-public-muted);
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb .breadcrumb-item.active {
  color: #232a34;
  font-weight: 600;
}

body.z2h-public-skin .z2h-public-course .z2h-course-breadcrumb a {
  color: inherit;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.7px;
}

body.z2h-public-skin .z2h-public-course .z2h-course-cover {
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--z2h-public-border);
  background: #f4f6f8;
  object-fit: cover;
  aspect-ratio: 16 / 9;
}

body.z2h-public-skin .z2h-public-course .z2h-course-lead {
  margin: 0.24rem 0 0;
  color: var(--z2h-public-muted);
  line-height: 1.62;
  font-size: 1.02rem;
  text-align: justify;
  text-justify: inter-word;
}

body.z2h-public-skin .z2h-public-course .z2h-course-chips {
  margin-top: 0.86rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-chips .z2h-badge {
  margin: 0 !important;
  border: 1px solid var(--z2h-public-border);
  border-radius: 999px;
  background: #f6f8f9;
  color: #202733;
  font-size: 0.74rem;
  font-weight: 700;
  padding: 0.27rem 0.65rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-section-title {
  margin-bottom: 0.62rem;
  font-size: 1.04rem;
  letter-spacing: -0.01em;
}

body.z2h-public-skin .z2h-public-course .z2h-course-inline-link {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.9rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.05rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-inline-link:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-public-course .z2h-course-details {
  margin: 0.12rem 0 0;
  border-top: 1px solid var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-course .z2h-course-details li {
  display: flex;
  flex-wrap: wrap;
  gap: 0.36rem;
  align-items: baseline;
  padding: 0.54rem 0;
  border-bottom: 1px solid var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-course .z2h-course-details li strong {
  min-width: 108px;
  color: #101318;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors {
  margin-top: 0.54rem;
  gap: 0.8rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-card {
  border: 1px solid var(--z2h-public-border);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-media {
  width: 100%;
  height: clamp(228px, 24vw, 292px);
  display: grid;
  place-items: center;
  background: #f7f9fa;
  border-bottom: 1px solid var(--z2h-public-border);
  position: relative;
  flex: 0 0 auto;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-media img,
body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-placeholder {
  width: 100%;
  height: 100%;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-media img {
  object-fit: contain;
  object-position: center top;
  border-bottom: 0;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-placeholder {
  border-bottom: 0;
  background: #f7f9fa;
  color: #6f7783;
  font-size: 1.06rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-body {
  position: relative;
  z-index: 1;
  background: #ffffff;
  padding: 0.82rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-name {
  margin: 0;
}

body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-bio {
  margin: 0.28rem 0 0;
}

body.z2h-public-skin .z2h-public-course .z2h-course-aside .z2h-course-sidecard {
  border: 1px solid var(--z2h-public-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: none;
}

body.z2h-public-skin .z2h-public-course .z2h-course-sidecard__body {
  padding: 0.98rem;
  display: grid;
  gap: 0.44rem;
}

body.z2h-public-skin .z2h-public-course .z2h-course-price {
  font-size: clamp(1.35rem, 2.1vw, 1.68rem);
  line-height: 1.12;
}

body.z2h-public-skin .z2h-public-course .z2h-course-price-alt {
  margin: 0.04rem 0 0.36rem;
  color: var(--z2h-public-muted) !important;
}

body.z2h-public-skin .z2h-public-course .z2h-course-bank {
  margin-top: 0.26rem !important;
  padding-top: 0.62rem;
  border-top: 1px solid var(--z2h-public-border);
}

body.z2h-public-skin .z2h-public-course .z2h-course-bank code {
  display: inline-flex;
  margin-top: 0.14rem;
}

body.z2h-public-skin .z2h-public-course .z2h-payment-menu,
body.z2h-public-skin .z2h-public-semillero .z2h-payment-menu,
body.z2h-public-skin .z2h-public-package-detail .z2h-payment-menu {
  margin-top: 0.16rem;
  display: grid;
  gap: 0.54rem;
}

body.z2h-public-skin .z2h-payment-menu__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.58rem;
}

body.z2h-public-skin .z2h-payment-menu__chevron {
  width: 10px;
  height: 10px;
  border-right: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.68s cubic-bezier(0.22, 0.61, 0.36, 1);
  flex: 0 0 auto;
}

body.z2h-public-skin .z2h-payment-menu.is-open .z2h-payment-menu__chevron {
  transform: rotate(-135deg);
}

body.z2h-public-skin .z2h-payment-menu__options {
  display: grid;
  gap: 0.52rem;
}

body.z2h-public-skin .z2h-payment-menu__options .z2h-payment-option {
  min-height: 41px;
}

body.z2h-public-skin .z2h-payment-menu__options .z2h-payment-option--online {
  box-shadow: 0 0 0 1px rgba(0, 150, 136, 0.2), 0 10px 20px rgba(0, 150, 136, 0.18);
}

body.z2h-public-skin .z2h-payment-bank-option {
  display: grid;
  gap: 0.32rem;
}

body.z2h-public-skin .z2h-payment-bank-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.38rem;
  font-size: 0.78rem;
  color: #4f5b6d;
}

body.z2h-public-skin .z2h-payment-bank-meta code {
  display: inline-flex;
  padding: 0.1rem 0.45rem;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-steps--minimal {
  margin-top: clamp(2.16rem, 4.4vw, 3.05rem) !important;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-card--minimal {
  border: 1px solid var(--z2h-public-border);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: none;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-card--minimal .card-body {
  padding: clamp(1rem, 2.5vw, 1.45rem) !important;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-head {
  margin-bottom: 0.95rem !important;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-head__actions .btn {
  min-height: 38px;
}

body.z2h-public-skin .z2h-public-course .z2h-bank-alert {
  background: #f8f9fa;
  border-color: var(--z2h-public-border) !important;
  border-radius: 12px;
}

body.z2h-public-skin .z2h-public-course .z2h-steps li {
  margin-bottom: 0.82rem;
  padding-top: 0.52rem;
  border-top: 1px solid #ecf0f3;
}

body.z2h-public-skin .z2h-public-course .z2h-steps li:first-child {
  border-top: 0;
  padding-top: 0;
}

body.z2h-public-skin .z2h-public-course .z2h-step-content h3 {
  font-size: 0.98rem;
  letter-spacing: -0.005em;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-course .z2h-step-content p {
  margin-top: 0.28rem;
  line-height: 1.56;
}

body.z2h-public-skin .z2h-public-course .z2h-enroll-inline-cta {
  margin-left: 0 !important;
  margin-top: 0.46rem;
}

body.z2h-public-skin .z2h-public-course .z2h-note {
  margin-top: 1.02rem !important;
  border-top: 1px solid var(--z2h-public-border);
  padding-top: 0.66rem;
  line-height: 1.54;
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-course .z2h-course-aside .z2h-course-sidecard {
    position: sticky;
    top: 5.9rem;
  }
}

@media (max-width: 991.98px) {
  body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain .z2h-hero-slim__body {
    align-items: start;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__actions {
    width: 100%;
    justify-content: flex-start;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-aside {
    order: 2;
  }
}

@media (max-width: 640px) {
  body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain {
    padding: 0.02rem 0 0.28rem !important;
  }

  body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain .z2h-hero-slim__title {
    font-size: clamp(1.42rem, 8.3vw, 1.95rem);
    line-height: 1.11;
  }

  body.z2h-public-skin .z2h-public-course .z2h-hero-slim--plain .z2h-hero-slim__sub {
    font-size: 0.95rem;
    line-height: 1.56;
    padding-inline: 0.12rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__actions {
    width: 100%;
    align-items: stretch;
    gap: 0.46rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__actions .btn,
  body.z2h-public-skin .z2h-public-course .z2h-course-sidecard__body .btn,
  body.z2h-public-skin .z2h-public-course .z2h-enroll-head__actions .btn {
    width: 100%;
    justify-content: center;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-detail-hero__link {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-cover {
    border-radius: 12px;
    aspect-ratio: 4 / 3;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-lead {
    font-size: 0.97rem;
    line-height: 1.58;
    padding-inline: 0.08rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-details li {
    display: block;
    padding: 0.52rem 0;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-details li strong {
    display: block;
    min-width: 0;
    margin-bottom: 0.16rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-course-instructors .z2h-instructor-media {
    height: clamp(236px, 64vw, 304px);
  }

  body.z2h-public-skin .z2h-public-course .z2h-enroll-head {
    gap: 0.5rem !important;
  }

  body.z2h-public-skin .z2h-public-course .z2h-enroll-head__actions {
    width: 100%;
    flex-direction: column;
  }

  body.z2h-public-skin .z2h-public-course .z2h-steps li {
    margin-bottom: 0.72rem;
    padding-top: 0.46rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-step-content p {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  body.z2h-public-skin .z2h-public-course .z2h-enroll-inline-cta {
    width: auto !important;
    margin-top: 0.52rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-bank-alert {
    gap: 0.48rem;
  }

  body.z2h-public-skin .z2h-public-course .z2h-bank-alert .btn {
    width: auto !important;
    margin-left: 0 !important;
  }
}

/* Phase 5: authenticated student areas aligned with public minimalist style */
#client-dashboard,
#my-courses,
#my-course-detail {
  --z2h-stu-bg: #ffffff;
  --z2h-stu-soft: #f5f7f8;
  --z2h-stu-soft-2: #fafcfc;
  --z2h-stu-text: #0f1115;
  --z2h-stu-muted: #5e6470;
  --z2h-stu-border: #d8dde4;
  --z2h-stu-border-strong: #bcc4cf;
  --z2h-stu-accent: #009688;
  --z2h-stu-accent-strong: #007f73;
  display: grid;
  gap: 1.25rem;
  color: var(--z2h-stu-text);
}

#client-dashboard .student-hero,
#my-courses .student-hero,
#my-course-detail .student-hero {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.1rem 0 0.46rem !important;
}

#client-dashboard .student-hero__content,
#my-courses .student-hero__content,
#my-course-detail .student-hero__content {
  align-items: end;
  gap: 0.7rem 1.1rem;
}

#client-dashboard .student-eyebrow,
#my-courses .student-eyebrow,
#my-course-detail .student-eyebrow {
  color: var(--z2h-stu-accent) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: 800 !important;
}

#client-dashboard .student-hero__title,
#my-courses .student-hero__title,
#my-course-detail .student-hero__title {
  margin: 0;
  font-size: clamp(1.62rem, 3.3vw, 2.32rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--z2h-stu-text);
}

#client-dashboard .student-hero__sub,
#my-courses .student-hero__sub,
#my-course-detail .student-hero__sub {
  margin: 0.44rem 0 0;
  max-width: 64ch;
  color: var(--z2h-stu-muted);
  line-height: 1.58;
}

#client-dashboard .student-hero__chips,
#my-courses .student-hero__chips,
#my-course-detail .student-hero__chips {
  margin-top: 0.58rem;
  gap: 0.4rem;
}

#client-dashboard .student-mail,
#my-courses .student-mail,
#my-course-detail .student-mail,
#client-dashboard .chip,
#my-courses .chip,
#my-course-detail .chip,
#client-dashboard .meta-pill,
#my-courses .meta-pill,
#my-course-detail .meta-pill {
  border: 1px solid var(--z2h-stu-border);
  background: var(--z2h-stu-soft);
  color: #253041;
}

#client-dashboard .student-hero__tag {
  border: 1px solid var(--z2h-stu-border);
  background: var(--z2h-stu-soft);
  color: #253041;
}

#client-dashboard .student-hero__actions,
#my-courses .student-hero__actions,
#my-course-detail .student-hero__actions {
  gap: 0.46rem;
  align-items: center;
}

#client-dashboard .student-hero__actions .btn,
#my-courses .student-hero__actions .btn,
#my-course-detail .student-hero__actions .btn {
  min-height: 38px;
  border-radius: 999px;
  padding-inline: 0.95rem;
}

#client-dashboard .alert,
#my-courses .alert,
#my-course-detail .alert {
  border-radius: 14px;
  border: 1px solid var(--z2h-stu-border);
  box-shadow: none;
}

#client-dashboard .alert-info,
#my-courses .alert-info,
#my-course-detail .alert-info {
  background: #f4fbf9;
  border-color: #cde9e3;
  color: #1f4d46;
}

#client-dashboard .alert-danger,
#my-courses .alert-danger,
#my-course-detail .alert-danger {
  background: #fff4f4;
  border-color: #f1d0d0;
}

#client-dashboard .student-panel,
#my-courses .student-panel,
#my-course-detail .student-panel {
  border: 1px solid var(--z2h-stu-border);
  border-radius: 18px;
  background: var(--z2h-stu-bg);
  box-shadow: none;
}

#client-dashboard .student-panel__header,
#my-courses .student-panel__header,
#my-course-detail .student-panel__header {
  border-bottom: 1px solid var(--z2h-stu-border);
  padding: 0.94rem 1.02rem;
}

#client-dashboard .student-panel__body,
#my-courses .student-panel__body,
#my-course-detail .student-panel__body {
  padding: 0.95rem 1.02rem;
}

#client-dashboard .student-panel--accent {
  border-color: #cde4df;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdfd 100%);
}

#client-dashboard .student-panel--soft,
#my-course-detail .student-panel--soft {
  background: var(--z2h-stu-soft-2);
}

#client-dashboard .student-steps {
  gap: 0.52rem;
}

#client-dashboard .student-step {
  margin: 0;
  padding: 0.16rem 0;
}

#client-dashboard .student-step__index {
  width: 24px;
  height: 24px;
  background: #e9f7f4;
  color: var(--z2h-stu-accent-strong);
}

#client-dashboard .student-form-grid .form-label,
#my-course-detail .student-panel .form-label {
  margin-bottom: 0.24rem;
  font-size: 0.72rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--z2h-stu-muted);
  font-weight: 700;
}

#client-dashboard .student-form-grid .form-control,
#client-dashboard .student-form-grid .form-select {
  min-height: 42px;
  border-color: var(--z2h-stu-border);
}

#client-dashboard .z2h-input-elevated {
  border-color: var(--z2h-stu-border);
  border-radius: 12px;
}

#client-dashboard .z2h-input-elevated .input-group-text {
  color: #667085;
}

#client-dashboard .student-readout dt {
  margin-bottom: 0.14rem;
  font-size: 0.69rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--z2h-stu-muted) !important;
}

#client-dashboard .student-readout dd {
  margin-bottom: 0.48rem;
  color: #171d27;
}

#client-dashboard .program-card,
#my-courses .program-card {
  border: 1px solid var(--z2h-stu-border);
  border-radius: 14px;
  background: var(--z2h-stu-bg);
  box-shadow: none;
  padding: 0.9rem;
  display: grid;
  gap: 0.44rem;
}

#client-dashboard .program-card__head,
#my-courses .program-card__head {
  margin-bottom: 0.04rem;
}

#client-dashboard .program-card__head .badge,
#my-courses .program-card__head .badge {
  background: var(--z2h-stu-soft) !important;
  color: #4b5565 !important;
  border: 1px solid var(--z2h-stu-border);
  font-size: 0.71rem;
}

#client-dashboard .program-card__title,
#my-courses .program-card__title {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.3;
}

#client-dashboard .program-card__desc,
#my-courses .program-card__desc {
  margin: 0;
  color: var(--z2h-stu-muted);
  font-size: 0.9rem;
  line-height: 1.52;
}

#client-dashboard .program-card__meta,
#my-courses .program-card__meta {
  margin: 0.1rem 0 0.04rem;
}

#client-dashboard .program-card__meta .meta-pill,
#my-courses .program-card__meta .meta-pill {
  border-radius: 999px;
  font-size: 0.72rem;
}

#client-dashboard .program-card__footer,
#my-courses .program-card__footer {
  margin-top: 0.1rem;
  padding-top: 0.56rem;
  border-top: 1px solid var(--z2h-stu-border);
}

#client-dashboard .program-card__status,
#my-courses .program-card__status {
  color: var(--z2h-stu-muted);
  font-size: 0.8rem;
}

#client-dashboard .program-card__footer .btn,
#my-courses .program-card__footer .btn {
  min-height: auto;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  color: #0f1115 !important;
  font-size: 0.88rem;
  font-weight: 700;
  padding: 0.02rem 0.02rem 0.08rem !important;
  position: relative;
}

#client-dashboard .program-card__footer .btn::after,
#my-courses .program-card__footer .btn::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: currentcolor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 1.16s cubic-bezier(0.22, 0.61, 0.36, 1);
}

#client-dashboard .program-card__footer .btn:hover::after,
#client-dashboard .program-card__footer .btn:focus-visible::after,
#my-courses .program-card__footer .btn:hover::after,
#my-courses .program-card__footer .btn:focus-visible::after {
  transform: scaleX(1);
}

#client-dashboard .program-card__footer .btn:not(:hover):not(:focus-visible)::after,
#my-courses .program-card__footer .btn:not(:hover):not(:focus-visible)::after {
  transform-origin: right center;
}

#my-courses #programs-empty,
#client-dashboard #programs-empty {
  border: 1px dashed var(--z2h-stu-border);
  border-radius: 14px;
  background: var(--z2h-stu-soft-2);
  color: var(--z2h-stu-muted) !important;
  padding: 0.9rem;
  text-align: center;
}

#my-course-detail #prog-start:empty {
  display: none;
}

#my-course-detail .student-panel--soft {
  border-color: var(--z2h-stu-border);
}

#my-course-detail .content-kind-card {
  border: 1px solid var(--z2h-stu-border) !important;
  border-radius: 12px;
  background: #ffffff !important;
  box-shadow: none !important;
  min-height: 66px;
  padding: 0.66rem 0.74rem;
  transition: border-color 0.26s ease, background-color 0.26s ease, transform 0.26s ease;
}

#my-course-detail .content-kind-card:hover {
  border-color: #a8d6cf !important;
  background: #f6fbfa !important;
  transform: translateY(-1px);
}

#my-course-detail .content-kind-card.active {
  border-color: #70bbb0 !important;
  background: #eff9f7 !important;
}

#my-course-detail .content-kind-count {
  border: 1px solid var(--z2h-stu-border);
  border-radius: 999px;
  min-width: 30px;
  padding-inline: 0.4rem;
  font-size: 0.73rem;
  line-height: 1.45;
}

#my-course-detail .content-kind-count--full {
  background: #dff4ef;
  color: #1d5c54;
}

#my-course-detail .content-kind-count--empty {
  background: #eef2f4;
  color: #596172;
}

#my-course-detail #content-view {
  min-height: 260px;
}

#my-course-detail .content-tile {
  border: 1px solid var(--z2h-stu-border) !important;
  border-radius: 14px !important;
  background: #ffffff;
  box-shadow: none;
  padding: 0.9rem !important;
}

#my-course-detail .content-tile .badge.text-bg-light {
  background: var(--z2h-stu-soft) !important;
  color: #4b5565 !important;
  border: 1px solid var(--z2h-stu-border);
}

#my-course-detail .content-tile .btn-primary {
  background: #ffffff !important;
  border: 1px solid var(--z2h-stu-border-strong) !important;
  color: #0f1115 !important;
  border-radius: 999px;
  min-height: 36px;
  font-size: 0.8rem;
  font-weight: 700;
}

#my-course-detail .content-tile .btn-primary:hover {
  background: var(--z2h-stu-soft) !important;
  border-color: #aeb9c7 !important;
}

#my-course-detail .student-video__actions {
  gap: 0.38rem;
}

#my-course-detail .student-video__toggle,
#my-course-detail .student-video__hide {
  min-height: 34px;
  border-radius: 999px;
  padding-inline: 0.82rem;
}

#my-course-detail .student-embed iframe {
  border: 1px solid var(--z2h-stu-border);
  border-radius: 12px;
  background: #0d1117;
}

@media (max-width: 991.98px) {
  #client-dashboard .student-hero__content,
  #my-courses .student-hero__content,
  #my-course-detail .student-hero__content {
    align-items: start;
  }

  #client-dashboard .student-hero__actions,
  #my-courses .student-hero__actions,
  #my-course-detail .student-hero__actions {
    width: 100%;
    justify-content: flex-start;
  }

  #client-dashboard .student-readout dt,
  #client-dashboard .student-readout dd {
    width: 100%;
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  #client-dashboard,
  #my-courses,
  #my-course-detail {
    gap: 0.92rem;
  }

  #client-dashboard .student-hero,
  #my-courses .student-hero,
  #my-course-detail .student-hero {
    padding: 0.04rem 0 0.3rem !important;
  }

  #client-dashboard .student-hero__title,
  #my-courses .student-hero__title,
  #my-course-detail .student-hero__title {
    font-size: clamp(1.44rem, 8.2vw, 1.96rem);
    line-height: 1.12;
  }

  #client-dashboard .student-hero__sub,
  #my-courses .student-hero__sub,
  #my-course-detail .student-hero__sub {
    font-size: 0.95rem;
    line-height: 1.58;
  }

  #client-dashboard .student-hero__actions,
  #my-courses .student-hero__actions,
  #my-course-detail .student-hero__actions {
    flex-direction: column;
    align-items: stretch;
    gap: 0.42rem;
  }

  #client-dashboard .student-hero__actions .btn,
  #my-courses .student-hero__actions .btn,
  #my-course-detail .student-hero__actions .btn {
    width: 100%;
    justify-content: center;
  }

  #client-dashboard .student-panel__header,
  #my-courses .student-panel__header,
  #my-course-detail .student-panel__header {
    padding: 0.82rem 0.88rem;
  }

  #client-dashboard .student-panel__body,
  #my-courses .student-panel__body,
  #my-course-detail .student-panel__body {
    padding: 0.84rem 0.88rem;
  }

  #client-dashboard .student-form-grid {
    gap: 0.52rem !important;
  }

  #client-dashboard .student-form-grid .btn-cta {
    width: 100%;
  }

  #client-dashboard .program-card,
  #my-courses .program-card {
    padding: 0.78rem;
  }

  #client-dashboard .program-card__footer,
  #my-courses .program-card__footer {
    align-items: center;
    gap: 0.45rem;
  }

  #my-course-detail .content-kind-card {
    min-height: 62px;
    padding: 0.58rem 0.62rem;
  }

  #my-course-detail .content-tile {
    padding: 0.76rem !important;
  }
}

/* Mercado Pago payment result */
body.z2h-public-skin .z2h-payment-result {
  padding-top: 0.3rem;
}

body.z2h-public-skin .z2h-payment-result .z2h-payment-card {
  border: 1px solid var(--z2h-public-border, #dbe2e8);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  box-shadow: none;
}

body.z2h-public-skin .z2h-payment-result .z2h-payment-card .btn {
  min-height: 40px;
}

@media (max-width: 640px) {
  body.z2h-public-skin .z2h-payment-result .z2h-payment-card .card-body {
    padding: 1rem !important;
  }

  body.z2h-public-skin .z2h-payment-result .z2h-payment-card .d-flex.gap-2 {
    flex-direction: column;
    align-items: stretch;
  }

  body.z2h-public-skin .z2h-payment-result .z2h-payment-card .btn {
    width: 100%;
    justify-content: center;
  }
}

/* Packages (public + admin) */
body.z2h-public-skin .z2h-public-index .z2h-featured--packages {
  margin-top: clamp(2rem, 5vw, 3.2rem) !important;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-slim--plain,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-slim--plain {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.2rem 0 0.38rem !important;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-slim--plain .z2h-hero-slim__body,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-slim--plain .z2h-hero-slim__body {
  align-items: end;
  gap: 0.8rem 1.1rem;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-slim--plain .z2h-hero-slim__title,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-slim--plain .z2h-hero-slim__title {
  line-height: 1.12;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-slim--plain .z2h-hero-slim__sub,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-slim--plain .z2h-hero-slim__sub {
  margin: 0.38rem 0 0;
  max-width: 64ch;
  line-height: 1.56;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-action-link,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-action-link {
  display: inline-flex;
  width: fit-content;
  color: #0f1115;
  font-size: 0.9rem;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
  padding-bottom: 0.06rem;
}

body.z2h-public-skin .z2h-public-packages .z2h-hero-action-link:hover,
body.z2h-public-skin .z2h-public-package-detail .z2h-hero-action-link:hover {
  color: var(--z2h-public-accent-strong);
}

body.z2h-public-skin .z2h-package-card {
  border: 1px solid var(--z2h-public-border, #dbe2e8);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fcfdfd 100%);
  box-shadow: none;
  padding: 1rem 1.05rem;
  display: flex;
  flex-direction: column;
  gap: 0.72rem;
}

body.z2h-public-skin .z2h-public-packages .z2h-package-list-grid {
  row-gap: 0.96rem;
}

body.z2h-public-skin .z2h-public-packages .z2h-package-card--list {
  border-radius: 16px;
  border-color: var(--z2h-public-border, #dbe2e8);
  background: #ffffff;
  box-shadow: none;
  padding: 0.94rem 0.98rem;
  gap: 0.54rem;
}

body.z2h-public-skin .z2h-package-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body.z2h-public-skin .z2h-package-card__eyebrow {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #0a8f86;
  font-weight: 700;
}

body.z2h-public-skin .z2h-package-card__price {
  font-size: 0.78rem;
  color: #4f596c;
  font-weight: 700;
}

body.z2h-public-skin .z2h-package-card__title {
  margin: 0;
  font-size: clamp(1.06rem, 1.6vw, 1.22rem);
  line-height: 1.24;
  letter-spacing: -0.012em;
}

body.z2h-public-skin .z2h-package-card__tagline,
body.z2h-public-skin .z2h-package-card__desc {
  margin: 0;
  color: #546074;
  font-size: 0.94rem;
  line-height: 1.56;
}

body.z2h-public-skin .z2h-package-card__tagline {
  color: #243044;
  font-weight: 600;
}

body.z2h-public-skin .z2h-public-packages .z2h-package-card__meta {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #556174;
  font-weight: 700;
}

body.z2h-public-skin .z2h-package-card__programs {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.45rem;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__preview {
  margin-top: 0.08rem;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__toggle {
  width: 100%;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.58rem;
  padding: 0.04rem 0;
  text-align: left;
  cursor: pointer;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__toggle:focus-visible {
  outline: 2px solid #99d9ce;
  outline-offset: 3px;
  border-radius: 6px;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__kicker {
  color: #3f4b5b;
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__chevron {
  width: 10px;
  height: 10px;
  border-right: 1.8px solid #667080;
  border-bottom: 1.8px solid #667080;
  transform: rotate(45deg);
  transition: transform 0.92s cubic-bezier(0.22, 0.61, 0.36, 1);
  flex: 0 0 auto;
  margin-right: 2px;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__preview.is-open .z2h-package-card__chevron {
  transform: rotate(-135deg);
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__panel {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: grid-template-rows 0.96s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.96s ease;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__panel-inner {
  min-height: 0;
  overflow: hidden;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__preview.is-open .z2h-package-card__panel {
  grid-template-rows: 1fr;
  opacity: 1;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__programs {
  margin-top: 0.4rem;
}

body.z2h-public-skin .z2h-public-index .z2h-package-grid {
  align-items: flex-start;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo {
  padding: 1.08rem 1.14rem;
  gap: 0.66rem;
}

body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__footer {
  margin-top: 0.24rem;
  padding-top: 0.14rem;
}

body.z2h-public-skin .z2h-package-card__programs li {
  font-size: 0.88rem;
  color: #546074;
  line-height: 1.45;
}

body.z2h-public-skin .z2h-package-card__programs li span {
  font-weight: 600;
  color: #263145;
}

body.z2h-public-skin .z2h-package-card__programs a.z2h-link-reveal {
  color: #009688;
  font-weight: 700;
  --z2h-link-reveal-duration: 1.24s;
  --z2h-link-reveal-thickness: 1.8px;
}

body.z2h-public-skin .z2h-package-card__programs a.z2h-link-reveal:hover,
body.z2h-public-skin .z2h-package-card__programs a.z2h-link-reveal:focus-visible {
  color: #007f74;
}

body.z2h-public-skin .z2h-package-card__footer {
  margin-top: auto;
  padding-top: 0.25rem;
  display: flex;
  justify-content: center;
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo {
    display: grid;
    grid-template-rows: auto minmax(3rem, auto) minmax(3.95rem, auto) minmax(5.85rem, auto) auto auto;
    gap: 0.68rem;
    align-content: start;
  }

  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__tagline.is-empty,
  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__desc.is-empty {
    visibility: hidden;
  }

  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__tagline,
  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__desc {
    overflow: hidden;
    display: block;
    max-height: calc((1.56em * 3) + 0.34rem);
  }

  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__tagline {
    line-clamp: 3;
  }

  body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__desc {
    line-clamp: 3;
  }

  @supports (-webkit-line-clamp: 3) {
    body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__tagline,
    body.z2h-public-skin .z2h-public-index .z2h-package-card--promo .z2h-package-card__desc {
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 3;
      max-height: none;
    }
  }
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-hero__desc {
  margin: 0.6rem 0 0;
  color: #546074;
  font-size: 0.98rem;
  line-height: 1.64;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.36rem 0.52rem;
  margin-top: 0.58rem;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-hero__meta span {
  display: inline-flex;
  align-items: center;
  font-size: 0.78rem;
  color: #4f5b6f;
  border: 1px solid var(--z2h-public-border, #dbe2e8);
  border-radius: 999px;
  padding: 0.18rem 0.56rem;
  background: #ffffff;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-panel {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-panel__title {
  margin-bottom: 0.7rem !important;
  letter-spacing: -0.01em;
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-includes {
  display: grid;
  gap: 0.56rem;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include {
  border: 1px solid var(--z2h-public-border, #dbe2e8);
  border-radius: 12px;
  background: #ffffff;
  padding: 0.68rem 0.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  transition: border-color 0.24s ease, transform 0.24s ease, background-color 0.24s ease;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include:hover {
  border-color: #9fcfc7;
  background: #f8fcfb;
  transform: translateY(-1px);
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include__main {
  display: grid;
  gap: 0.14rem;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include__type {
  font-size: 0.73rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #0a8f86;
  font-weight: 700;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include__title {
  color: #182032;
  font-weight: 600;
  font-size: 0.94rem;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-include__arrow {
  font-size: 0.76rem;
  font-weight: 700;
  color: #5a667a;
  white-space: nowrap;
}

body.z2h-public-skin .z2h-public-package-detail .z2h-package-sidecard {
  border: 1px solid var(--z2h-public-border, #dbe2e8);
  border-radius: 16px;
  background: #ffffff;
  box-shadow: none;
}

@media (min-width: 992px) {
  body.z2h-public-skin .z2h-public-package-detail .z2h-package-sidecard {
    position: sticky;
    top: 5.9rem;
  }
}

#admin-packages .admin-program-picker {
  border: 1px solid var(--u-border);
  border-radius: 12px;
  background: #fbfcfe;
  max-height: 260px;
  overflow: auto;
  padding: 0.65rem;
  display: grid;
  gap: 0.45rem;
}

#admin-packages .admin-program-option {
  display: flex;
  align-items: start;
  gap: 0.5rem;
  font-size: 0.86rem;
  color: #243046;
}

#admin-packages .admin-program-option input[type="checkbox"] {
  margin-top: 0.22rem;
}

/* Phase 10: admin pages aligned with public minimal design */
body.z2h-admin-skin {
  --u-bg: #ffffff;
  --u-surface: #ffffff;
  --u-surface-soft: #f5f7f8;
  --u-text: #0f1115;
  --u-muted: #5e6470;
  --u-border: #d8dde4;
  --u-border-strong: #b8bfca;
  --u-primary: #009688;
  --u-primary-strong: #007f73;
  --u-primary-soft: #e8f7f4;
}

body.z2h-admin-skin.z2h-body {
  background:
    radial-gradient(980px 360px at 8% -12%, rgba(0, 150, 136, 0.07), transparent 62%),
    radial-gradient(860px 340px at 92% -8%, rgba(0, 127, 115, 0.05), transparent 60%),
    #ffffff;
}

body.z2h-admin-skin .container[id^="admin-"] {
  max-width: 1160px;
}

body.z2h-admin-skin .container[id^="admin-"] .admin-page-head {
  border-bottom: 0;
  margin-bottom: 1.2rem !important;
}

body.z2h-admin-skin .container[id^="admin-"] .admin-card,
body.z2h-admin-skin .container[id^="admin-"] .card {
  border: 1px solid var(--u-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdfd 100%);
  box-shadow: 0 10px 22px rgba(15, 17, 21, 0.05);
}

body.z2h-admin-skin .container[id^="admin-"] .card-header {
  border-bottom: 1px solid var(--u-border);
  background: transparent !important;
}

body.z2h-admin-skin .container[id^="admin-"] .form-control,
body.z2h-admin-skin .container[id^="admin-"] .form-select {
  border-color: var(--u-border);
  border-radius: 10px;
}

body.z2h-admin-skin .container[id^="admin-"] .form-control:focus,
body.z2h-admin-skin .container[id^="admin-"] .form-select:focus,
body.z2h-admin-skin .container[id^="admin-"] .btn:focus-visible,
body.z2h-admin-skin .container[id^="admin-"] .form-check-input:focus {
  border-color: #99d9ce;
  box-shadow: 0 0 0 0.2rem rgba(0, 150, 136, 0.15);
}

body.z2h-admin-skin .container[id^="admin-"] .btn-primary,
body.z2h-admin-skin .container[id^="admin-"] .btn-cta {
  background: var(--u-primary);
  border-color: var(--u-primary);
}

body.z2h-admin-skin .container[id^="admin-"] .btn-primary:hover,
body.z2h-admin-skin .container[id^="admin-"] .btn-cta:hover {
  background: var(--u-primary-strong);
  border-color: var(--u-primary-strong);
}

body.z2h-admin-skin .container[id^="admin-"] .btn-outline-secondary,
body.z2h-admin-skin .container[id^="admin-"] .btn-outline-primary {
  border-color: var(--u-border-strong);
  color: #243046;
  background: #ffffff;
}

body.z2h-admin-skin .container[id^="admin-"] .btn-outline-secondary:hover,
body.z2h-admin-skin .container[id^="admin-"] .btn-outline-primary:hover {
  border-color: #99d9ce;
  color: var(--u-primary-strong);
  background: #f4fbfa;
}

body.z2h-admin-skin .container[id^="admin-"] .admin-view-toggle .btn.active,
body.z2h-admin-skin .container[id^="admin-"] .admin-manage-tabs .btn.active {
  background: #e8f7f4;
  border-color: #bfe6de;
  color: var(--u-primary-strong);
}

body.z2h-admin-skin .container[id^="admin-"] .admin-kpi {
  border-color: var(--u-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdfd 100%);
}

body.z2h-admin-skin .container[id^="admin-"] .admin-kpi__label {
  color: var(--u-primary-strong);
}

body.z2h-admin-skin .container[id^="admin-"] .admin-tile {
  border-color: var(--u-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdfd 100%);
}

body.z2h-admin-skin .container[id^="admin-"] .admin-tile:hover {
  border-color: #bfe6de;
  box-shadow: 0 14px 24px rgba(15, 17, 21, 0.08);
}

body.z2h-admin-skin .container[id^="admin-"] .admin-tile-icon {
  border: 1px solid #c7ece6;
  border-radius: 12px;
  background: #e8f7f4 !important;
  color: var(--u-primary-strong) !important;
}

body.z2h-admin-skin .container[id^="admin-"] .admin-course-item.is-active {
  border-color: #bfe6de;
  box-shadow: inset 3px 0 0 var(--u-primary);
}

body.z2h-admin-skin .container[id^="admin-"] .list-group-item {
  border-color: var(--u-border);
  background: #ffffff;
}

body.z2h-admin-skin .container[id^="admin-"] .table > :not(caption) > * > * {
  border-bottom-color: var(--u-border);
}

body.z2h-admin-skin .container[id^="admin-"] .table thead th {
  color: #3f4b5b;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.73rem;
  font-weight: 700;
}

body.z2h-admin-skin .container[id^="admin-"] .alert-info {
  background: #e9f9f6;
  border-color: #bfe6de;
}

body.z2h-admin-skin .container[id^="admin-"] .alert-danger {
  background: #fff3f4;
  border-color: #ffd9dd;
}

body.z2h-admin-skin #admin-registros .admin-chart-wrap {
  position: relative;
  width: 100%;
  min-height: 248px;
}

body.z2h-admin-skin #admin-registros .admin-chart-canvas {
  width: 100% !important;
  height: 248px !important;
}

@media (max-width: 991.98px) {
  body.z2h-admin-skin .container[id^="admin-"] {
    padding-left: 0.86rem;
    padding-right: 0.86rem;
  }

  body.z2h-admin-skin .container[id^="admin-"] .admin-page-head {
    gap: 0.68rem !important;
  }

  body.z2h-admin-skin .container[id^="admin-"] .admin-page-head > div:last-child {
    width: 100%;
    justify-content: space-between;
  }

  body.z2h-admin-skin .container[id^="admin-"] .admin-page-head > div:last-child .btn {
    white-space: nowrap;
  }

  body.z2h-admin-skin #admin-registros .admin-chart-wrap {
    min-height: 210px;
  }

  body.z2h-admin-skin #admin-registros .admin-chart-canvas {
    height: 210px !important;
  }

  body.z2h-public-skin .z2h-public-packages .z2h-hero-slim__body,
  body.z2h-public-skin .z2h-public-package-detail .z2h-hero-slim__body {
    gap: 0.6rem;
  }

  body.z2h-public-skin .z2h-public-packages .z2h-package-card--list {
    padding: 0.86rem 0.9rem;
    gap: 0.5rem;
  }

  body.z2h-public-skin .z2h-public-package-detail .z2h-package-detail-hero__meta {
    gap: 0.28rem;
  }

  body.z2h-public-skin .z2h-public-package-detail .z2h-package-include {
    align-items: flex-start;
    padding: 0.64rem 0.72rem;
  }

  body.z2h-public-skin .z2h-public-package-detail .z2h-package-include__arrow {
    font-size: 0.72rem;
  }
}
