/* AlesVPN — согласовано с Android theme (Color.kt, NeonBackground) */
:root {
  --bg-0: #050508;
  --bg-1: #0a0612;
  --purple: #b366ff;
  --purple-dim: #6b3fa0;
  --cyan: #00e5ff;
  --text: #f5f0ff;
  --muted: #9ca3af;
  --glass: rgba(27, 15, 46, 0.5);
  --line: rgba(179, 102, 255, 0.22);
  --font: "Manrope", system-ui, sans-serif;
}

* {
  box-sizing: border-box;
}
::selection {
  background: color-mix(in srgb, var(--purple) 45%, transparent);
  color: var(--text);
}
html {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  font-family: var(--font);
  background: var(--bg-0);
}
.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 100;
  padding: 0.5rem 1rem;
  background: var(--cyan);
  color: #0a040e;
  font-weight: 700;
  border-radius: 8px;
}
.skip-link:focus {
  left: 0.75rem;
  top: 0.75rem;
}

#bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  isolation: isolate;
  background: linear-gradient(165deg, var(--bg-0), var(--bg-1) 40%, #06040c);
  pointer-events: none;
}

.stars-css {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(1.2px 1.2px at 15% 20%, #fff3 0 50%, transparent 52%),
    radial-gradient(1px 1px at 55% 65%, rgba(0, 229, 255, 0.2) 0 50%, transparent 52%),
    radial-gradient(1.4px 1.4px at 82% 30%, #fffa 0 50%, transparent 52%),
    radial-gradient(0.8px 0.8px at 40% 80%, #fff2 0 50%, transparent 52%),
    radial-gradient(1.1px 1.1px at 6% 45%, #fff2 0 50%, transparent 52%),
    radial-gradient(0.9px 0.9px at 33% 12%, rgba(255, 255, 255, 0.2) 0 50%, transparent 52%),
    radial-gradient(1px 1px at 91% 72%, #fff1 0 50%, transparent 52%),
    radial-gradient(0.7px 0.7px at 48% 91%, rgba(0, 229, 255, 0.12) 0 50%, transparent 52%);
  background-size: 110% 110%, 100% 100%, 100% 100%, 100% 100%, 100% 100%, 100% 100%,
    100% 100%, 100% 100%;
  animation: shift 100s ease-in-out infinite;
  opacity: 0.86;
}

/* Статичный плотный слой — мелкие точки по всему экрану */
.stars-css-dense {
  position: absolute;
  inset: 0;
  opacity: 0.68;
  background-image: radial-gradient(0.55px 0.55px at 3% 7%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(0.5px 0.5px at 11% 19%, rgba(255, 255, 255, 0.32), transparent),
    radial-gradient(0.45px 0.45px at 19% 4%, rgba(0, 229, 255, 0.2), transparent),
    radial-gradient(0.5px 0.5px at 27% 14%, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.55px 0.55px at 35% 28%, rgba(255, 255, 255, 0.35), transparent),
    radial-gradient(0.4px 0.4px at 44% 9%, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(0.5px 0.5px at 52% 21%, rgba(179, 102, 255, 0.18), transparent),
    radial-gradient(0.45px 0.45px at 60% 6%, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.5px 0.5px at 68% 18%, rgba(255, 255, 255, 0.26), transparent),
    radial-gradient(0.45px 0.45px at 76% 3%, rgba(0, 229, 255, 0.15), transparent),
    radial-gradient(0.5px 0.5px at 84% 15%, rgba(255, 255, 255, 0.33), transparent),
    radial-gradient(0.4px 0.4px at 92% 27%, rgba(255, 255, 255, 0.22), transparent),
    radial-gradient(0.5px 0.5px at 8% 35%, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.45px 0.45px at 16% 48%, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(0.5px 0.5px at 24% 40%, rgba(0, 229, 255, 0.14), transparent),
    radial-gradient(0.45px 0.45px at 32% 55%, rgba(255, 255, 255, 0.35), transparent),
    radial-gradient(0.5px 0.5px at 40% 45%, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.4px 0.4px at 48% 62%, rgba(179, 102, 255, 0.12), transparent),
    radial-gradient(0.5px 0.5px at 56% 50%, rgba(255, 255, 255, 0.32), transparent),
    radial-gradient(0.45px 0.45px at 64% 38%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.5px 0.5px at 72% 57%, rgba(255, 255, 255, 0.27), transparent),
    radial-gradient(0.4px 0.4px at 80% 44%, rgba(0, 229, 255, 0.12), transparent),
    radial-gradient(0.5px 0.5px at 88% 52%, rgba(255, 255, 255, 0.34), transparent),
    radial-gradient(0.45px 0.45px at 96% 64%, rgba(255, 255, 255, 0.24), transparent),
    radial-gradient(0.5px 0.5px at 4% 72%, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.4px 0.4px at 13% 80%, rgba(255, 255, 255, 0.22), transparent),
    radial-gradient(0.5px 0.5px at 22% 68%, rgba(255, 255, 255, 0.32), transparent),
    radial-gradient(0.45px 0.45px at 31% 90%, rgba(0, 229, 255, 0.15), transparent),
    radial-gradient(0.5px 0.5px at 39% 75%, rgba(255, 255, 255, 0.26), transparent),
    radial-gradient(0.45px 0.45px at 47% 88%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 55% 70%, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.5px 0.5px at 63% 95%, rgba(179, 102, 255, 0.1), transparent),
    radial-gradient(0.5px 0.5px at 71% 78%, rgba(255, 255, 255, 0.33), transparent),
    radial-gradient(0.45px 0.45px at 79% 85%, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(0.5px 0.5px at 87% 73%, rgba(0, 229, 255, 0.11), transparent),
    radial-gradient(0.4px 0.4px at 95% 90%, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.45px 0.45px at 2% 58%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.5px 0.5px at 97% 40%, rgba(255, 255, 255, 0.28), transparent);
  pointer-events: none;
}

/* Плитка 56×56 — повтор по всему вьюпорту, сотни мелких точек */
.stars-tile {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.52;
  background-size: 56px 56px;
  background-repeat: repeat;
  background-image: radial-gradient(0.5px 0.5px at 3px 2px, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(0.4px 0.4px at 20px 20px, rgba(255, 255, 255, 0.32), transparent),
    radial-gradient(0.45px 0.45px at 37px 33px, rgba(0, 229, 255, 0.18), transparent),
    radial-gradient(0.35px 0.35px at 2px 4px, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(0.4px 0.4px at 19px 17px, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.4px 0.4px at 36px 30px, rgba(255, 255, 255, 0.22), transparent),
    radial-gradient(0.45px 0.45px at 12px 0px, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.35px 0.35px at 26px 13px, rgba(179, 102, 255, 0.12), transparent),
    radial-gradient(0.4px 0.4px at 11px 39px, rgba(255, 255, 255, 0.33), transparent),
    radial-gradient(0.4px 0.4px at 28px 6px, rgba(0, 229, 255, 0.1), transparent),
    radial-gradient(0.4px 0.4px at 45px 1px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 9px 18px, rgba(255, 255, 255, 0.26), transparent),
    radial-gradient(0.35px 0.35px at 1px 12px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 33px 2px, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.4px 0.4px at 50px 8px, rgba(255, 255, 255, 0.15), transparent),
    radial-gradient(0.4px 0.4px at 6px 25px, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.35px 0.35px at 15px 8px, rgba(0, 229, 255, 0.12), transparent),
    radial-gradient(0.45px 0.45px at 32px 21px, rgba(255, 255, 255, 0.24), transparent),
    radial-gradient(0.35px 0.35px at 42px 12px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 24px 38px, rgba(255, 255, 255, 0.3), transparent);
}
.stars-tile-b {
  opacity: 0.38;
  background-position: 28px 14px;
  background-image: radial-gradient(0.45px 0.45px at 11px 2px, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.4px 0.4px at 2px 13px, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(0.4px 0.4px at 21px 24px, rgba(0, 229, 255, 0.12), transparent),
    radial-gradient(0.35px 0.35px at 40px 35px, rgba(255, 255, 255, 0.22), transparent),
    radial-gradient(0.4px 0.4px at 3px 46px, rgba(255, 255, 255, 0.28), transparent),
    radial-gradient(0.4px 0.4px at 22px 1px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 41px 12px, rgba(255, 255, 255, 0.26), transparent),
    radial-gradient(0.35px 0.35px at 2px 23px, rgba(255, 255, 255, 0.18), transparent),
    radial-gradient(0.45px 0.45px at 21px 34px, rgba(179, 102, 255, 0.1), transparent),
    radial-gradient(0.4px 0.4px at 40px 45px, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(0.4px 0.4px at 1px 0px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 20px 11px, rgba(0, 229, 255, 0.1), transparent),
    radial-gradient(0.35px 0.35px at 0px 33px, rgba(255, 255, 255, 0.24), transparent),
    radial-gradient(0.4px 0.4px at 19px 44px, rgba(255, 255, 255, 0.22), transparent),
    radial-gradient(0.4px 0.4px at 38px 1px, rgba(255, 255, 255, 0.26), transparent),
    radial-gradient(0.4px 0.4px at 17px 10px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 36px 21px, rgba(255, 255, 255, 0.32), transparent),
    radial-gradient(0.4px 0.4px at 15px 32px, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(0.4px 0.4px at 34px 43px, rgba(255, 255, 255, 0.15), transparent);
}

.comets {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}
.comet {
  --comet-dur: 14s;
  --comet-delay: 0s;
  --comet-rot: 35deg;
  --comet-sx: 0;
  --comet-sy: 0;
  --comet-ex: 0;
  --comet-ey: 0;
  --comet-scale: 0.8;
  position: absolute;
  left: 0;
  top: 0;
  width: clamp(64px, 8vw, 100px);
  height: 2px;
  margin-left: -1px;
  border-radius: 1px;
  /* Хвост сзади: яркий «нос» в +local X, совпадает с направлением полёта после rotate(atan2(Δy,Δx)) */
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(179, 102, 255, 0.1) 40%,
    rgba(0, 230, 255, 0.28) 62%,
    rgba(255, 255, 255, 0.9) 100%
  );
  box-shadow: 0 0 4px color-mix(in srgb, var(--cyan) 30%, transparent),
    0 0 6px color-mix(in srgb, var(--cyan) 6%, transparent);
  opacity: 0;
  transform: translate(var(--comet-sx), var(--comet-sy)) rotate(var(--comet-rot)) scale(var(--comet-scale));
  animation: comet-streak var(--comet-dur) linear infinite;
  animation-delay: var(--comet-delay);
}
@keyframes comet-streak {
  0% {
    opacity: 0;
    transform: translate(var(--comet-sx), var(--comet-sy)) rotate(var(--comet-rot)) scale(var(--comet-scale));
  }
  5% {
    opacity: 0.9;
  }
  90% {
    opacity: 0.72;
  }
  100% {
    opacity: 0;
    transform: translate(var(--comet-ex), var(--comet-ey)) rotate(var(--comet-rot)) scale(calc(var(--comet-scale) * 0.8));
  }
}

@keyframes shift {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(1%, -0.5%);
  }
}

.glow-tr {
  z-index: 2;
  position: absolute;
  top: -12%;
  right: -5%;
  width: min(400px, 45vw);
  height: min(400px, 45vw);
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--purple) 36%, transparent) 0%,
    transparent 68%
  );
  filter: blur(2px);
  animation: bob 20s ease-in-out infinite;
}
.glow-bl {
  z-index: 2;
  position: absolute;
  bottom: 10%;
  left: -8%;
  width: min(300px, 40vw);
  height: min(300px, 40vw);
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--purple-dim) 28%, transparent) 0%,
    transparent 70%
  );
  filter: blur(2px);
  animation: bob 24s ease-in-out -6s infinite;
}
@keyframes bob {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(-6px, 4px) scale(1.03);
  }
}

.earth {
  z-index: 2;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 36vh;
  max-height: 380px;
  border-radius: 100% 100% 0 0;
  background: linear-gradient(180deg, transparent, rgba(5, 5, 8, 0.88)),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(0, 229, 255, 0.05) 39px 40px),
    repeating-linear-gradient(0deg, transparent 0 25px, rgba(179, 102, 255, 0.05) 25px 26px);
  transform: scale(1.12);
  transform-origin: bottom;
  opacity: 0.45;
  mask-image: linear-gradient(180deg, #0004, #000a);
}
#star-canvas {
  /* Внутри #bg, над CSS-слоями: иначе #bg рисовался бы поверх canvas (старый баг). */
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.9;
}

.wrap {
  position: relative;
  z-index: 1;
  max-width: 1024px;
  margin: 0 auto;
  padding: 1rem 1.15rem 3.5rem;
}
header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.25rem 0 1.75rem;
}
header .header-download {
  padding: 0.52rem 1rem;
  font-size: 0.86rem;
  border-radius: 12px;
  white-space: nowrap;
}
.logo {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  color: var(--text);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: 0.04em;
}
.logo span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 12px var(--cyan);
}
nav.nav a {
  color: var(--muted);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.88rem;
  margin-left: 0.85rem;
}
nav.nav a:first-of-type {
  margin-left: 0;
}
nav.nav a:hover {
  color: var(--text);
}
nav.nav a:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 4px;
  border-radius: 6px;
  color: var(--text);
}

h1 {
  font-size: clamp(2.1rem, 5.5vw, 3.15rem);
  line-height: 1.1;
  margin: 0 0 0.9rem;
  max-width: 16ch;
  background: linear-gradient(120deg, #fff, var(--cyan) 40%, var(--purple));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.sub {
  color: var(--muted);
  max-width: 50ch;
  line-height: 1.6;
  font-size: 1.08rem;
  margin: 0 0 1.5rem;
}
.sub-tight {
  margin: -0.4rem 0 1rem;
  max-width: 60ch;
}
.pill {
  display: inline-block;
  font-size: 0.8rem;
  color: var(--muted);
  border: 1px solid var(--line);
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  margin-bottom: 1.1rem;
  background: var(--glass);
}
.pill b {
  color: var(--cyan);
  font-weight: 600;
  margin-left: 0.35rem;
}
.dns-hint {
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--muted);
  background: color-mix(in srgb, var(--cyan) 6%, var(--bg-0));
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, transparent);
  border-radius: 12px;
  padding: 0.75rem 1rem;
  margin: 0 0 1.25rem;
  max-width: 55ch;
}
.dns-hint strong {
  color: var(--text);
  font-weight: 600;
}
.cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 2.5rem;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.86rem 1.35rem;
  border-radius: 14px;
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  font-family: inherit;
  transition: 0.18s box-shadow, 0.12s transform;
}
.btn:hover {
  transform: translateY(-1px);
}
.btn:active {
  transform: scale(0.98);
}
.btn-main {
  color: #0a040e;
  background: linear-gradient(130deg, var(--cyan), #4befff);
  box-shadow: 0 4px 32px color-mix(in srgb, var(--cyan) 32%, transparent);
}
.btn-ghost {
  color: var(--text);
  background: var(--glass);
  border-color: var(--line);
}
.btn-ghost:hover {
  border-color: color-mix(in srgb, var(--cyan) 50%, var(--line));
  background: color-mix(in srgb, var(--glass), var(--cyan) 8%);
}
.btn:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 3px;
}
.security {
  margin: 0 0 2rem;
  max-width: 55ch;
  line-height: 1.6;
  font-size: 0.95rem;
  color: var(--muted);
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: var(--glass);
  border: 1px solid var(--line);
}

h2 {
  font-size: 1.3rem;
  font-weight: 800;
  margin: 0 0 1rem;
  scroll-margin-top: 5rem;
}
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 0.9rem;
  margin-bottom: 2.2rem;
}
.card {
  padding: 1.2rem 1.3rem;
  border-radius: 18px;
  background: var(--glass);
  border: 1px solid var(--line);
  backdrop-filter: blur(12px);
  position: relative;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute;
  top: -20%;
  right: -20%;
  width: 100px;
  height: 100px;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--purple) 35%, transparent) 0%,
    transparent 70%
  );
  pointer-events: none;
}
.card h3 {
  margin: 0 0 0.4rem;
  font-size: 1.02rem;
}
.card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.93rem;
  line-height: 1.5;
}
.ic {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}
ol.steps {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--muted);
  line-height: 1.7;
  font-size: 0.95rem;
}
ol.steps li {
  margin-bottom: 0.35rem;
}
code {
  font-size: 0.88em;
  color: var(--cyan);
}
footer {
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--line);
  text-align: center;
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1.55;
}
footer a {
  color: var(--cyan);
  text-decoration: none;
}
footer a:hover {
  text-decoration: underline;
}
footer .footer-email {
  color: var(--cyan);
  margin: 0;
  font-weight: 600;
  user-select: all;
}
footer .footer-inn {
  margin: 0.5rem 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  user-select: all;
}
footer .foot-req,
footer .foot-legal {
  margin: 0.35rem 0 0;
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.82rem;
  user-select: text;
}
footer .foot-links {
  margin: 0.75rem 0 0.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  justify-content: center;
  align-items: center;
}
.product-offer {
  max-width: 32rem;
  margin: 0 0 2.2rem;
  padding: 1.25rem 1.35rem;
  border-radius: 18px;
  background: var(--glass);
  border: 1px solid var(--line);
  backdrop-filter: blur(12px);
  position: relative;
  overflow: hidden;
}
.product-offer::before {
  content: "";
  position: absolute;
  top: -25%;
  right: -15%;
  width: 120px;
  height: 120px;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--cyan) 25%, transparent) 0%,
    transparent 70%
  );
  pointer-events: none;
}
.product-offer h3 {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
  font-weight: 800;
}
.product-offer .price {
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--text);
  margin: 0.4rem 0 0.6rem;
  letter-spacing: 0.02em;
}
.product-offer .price-tiers-title {
  margin: 0.8rem 0 0.35rem;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.product-offer .price-tiers {
  list-style: none;
  margin: 0 0 0.75rem;
  padding: 0;
  font-size: 0.95rem;
  line-height: 1.45;
  color: var(--muted);
}
.product-offer .price-tiers li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.product-offer .price-tiers li:last-of-type {
  border-bottom: none;
}
.product-offer .price-tiers strong {
  color: var(--text);
  font-size: 1.05rem;
  font-weight: 800;
  white-space: nowrap;
}
.product-offer p {
  margin: 0;
  color: var(--muted);
  font-size: 0.94rem;
  line-height: 1.55;
}
.product-offer p + p {
  margin-top: 0.6rem;
}
.delivery-block {
  margin: 0 0 2.2rem;
  max-width: 55ch;
  line-height: 1.6;
  font-size: 0.95rem;
  color: var(--muted);
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: var(--glass);
  border: 1px solid var(--line);
}
.delivery-block strong {
  color: var(--text);
}
.oferta-article {
  max-width: 60ch;
  margin: 0 auto 2rem;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.65;
}
.oferta-article h1 {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 0.5rem;
}
.oferta-article h2 {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--text);
  margin: 1.5rem 0 0.5rem;
}
.oferta-article p {
  margin: 0 0 0.75rem;
}
.oferta-article ol,
.oferta-article ul {
  margin: 0 0 0.75rem;
  padding-left: 1.2rem;
}
.oferta-article li {
  margin-bottom: 0.35rem;
}
.oferta-meta {
  font-size: 0.88rem;
  color: var(--muted);
  margin: 0 0 1.5rem;
}
.oferta-back {
  display: inline-block;
  margin: 0 0 1.5rem;
  color: var(--cyan);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 600;
}
.oferta-back:hover {
  text-decoration: underline;
}
@media (prefers-reduced-motion: reduce) {
  .glow-tr,
  .glow-bl,
  .stars-css,
  #star-canvas {
    animation: none;
  }
  .comets {
    display: none;
  }
  .stars-css-dense {
    opacity: 0.35;
  }
  .stars-tile,
  .stars-tile-b {
    opacity: 0.22;
  }
}
