/* ============================================================
   CRESENDA · Portal de Maestros
   Identidad: sol radiante violeta → magenta · tinta ciruela
   ============================================================ */

:root{
  --ink:        #240C30;   /* wordmark / texto */
  --ink-soft:   #4a3357;
  --violet:     #7800D8;   /* violeta profundo */
  --magenta:    #A80CF0;
  --orchid:     #CC18FC;
  --orchid-lt:  #E484FC;   /* orquídea claro */
  --grad:       linear-gradient(120deg, #7800D8 0%, #A80CF0 38%, #CC18FC 68%, #E484FC 100%);
  --grad-soft:  linear-gradient(120deg, #f4ecff 0%, #fbf2ff 100%);

  --paper:      #ffffff;
  --cream:      #faf7fd;
  --line:       #ece3f5;

  --radius:     20px;
  --radius-sm:  13px;
  --shadow:     0 18px 50px -22px rgba(36,12,48,.30);
  --shadow-sm:  0 8px 26px -14px rgba(36,12,48,.28);

  --serif: 'Fraunces', Georgia, serif;
  --sans:  'Poppins', system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
em{ font-style:italic; }

.wrap{ width:min(1140px,92vw); margin-inline:auto; }

/* ---------- Tipografía de secciones ---------- */
.kicker{
  display:inline-block;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; color:var(--magenta); margin-bottom:.8rem;
}
.kicker--light{ color:var(--orchid-lt); }
.section-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(1.9rem,4vw,3rem);
  line-height:1.1; letter-spacing:-.01em;
  color:var(--ink);
}
.section-title--light{ color:#fff; }
.section-sub{ color:var(--ink-soft); font-size:1.08rem; margin-top:.7rem; }

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-weight:600; font-size:.98rem;
  padding:.85rem 1.6rem; border-radius:100px;
  cursor:pointer; border:none; transition:.25s ease;
}
.btn--solid{ background:var(--grad); color:#fff; box-shadow:0 12px 30px -12px rgba(168,12,240,.7); }
.btn--solid:hover{ transform:translateY(-2px); box-shadow:0 18px 38px -12px rgba(168,12,240,.8); }
.btn--ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--line); }
.btn--ghost:hover{ border-color:var(--magenta); color:var(--magenta); }
.btn--full{ width:100%; justify-content:center; }

/* ---------- NAV ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:.85rem clamp(1rem,5vw,3rem);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav__logo{ height:34px; }
.nav__links{ display:flex; align-items:center; gap:1.7rem; }
.nav__links a{ font-size:.95rem; font-weight:500; color:var(--ink-soft); transition:.2s; }
.nav__links a:hover{ color:var(--magenta); }
.nav__cta{
  background:var(--grad); color:#fff !important;
  padding:.5rem 1.2rem; border-radius:100px;
}
.nav__cta:hover{ transform:translateY(-1px); }

/* Botón hamburguesa (oculto en desktop) */
.nav__toggle{
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px;
}
.nav__toggle span{
  width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s;
}
.nav.is-open .nav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2){ opacity:0; }
.nav.is-open .nav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- ACCESOS RÁPIDOS (hero) ---------- */
/* Franja más ancha que el texto del hero para caber 4 en una fila */
.quick{
  margin-top:2.6rem;
  width:min(1160px,94vw); position:relative; left:50%; transform:translateX(-50%);
}
.quick__label{
  display:block; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  font-weight:600; color:var(--ink-soft); margin-bottom:.9rem;
}
.quick__chips{ display:grid; grid-template-columns:repeat(4,1fr); gap:.6rem; }
.chip{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.55rem 1.05rem; border-radius:100px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm);
  font-size:.92rem; font-weight:500; color:var(--ink); transition:.22s;
}
.chip svg{ width:17px; height:17px; color:var(--magenta); }
.chip:hover{ transform:translateY(-2px); border-color:var(--orchid); color:var(--violet); }
.chip:hover svg{ color:var(--violet); }
.chip--pendiente{ opacity:.66; }
.chip__soon{
  font-size:.66rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em;
  background:var(--grad-soft); color:var(--magenta); padding:.1rem .4rem; border-radius:6px;
}

/* ---------- BENEFICIOS ---------- */
.beneficios{ padding:clamp(4rem,9vw,7rem) 0; background:var(--paper); }
.beneficios .section-sub{ margin-bottom:2.6rem; }
.benefits{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; }
.benefit{
  padding:1.9rem 1.7rem; border-radius:var(--radius);
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm);
  transition:.28s ease;
}
/* Todas iguales en reposo; el color aparece SOLO al pasar el mouse */
@media (hover:hover){
  .benefit:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
  .benefit:hover .benefit__icon{ background:var(--grad); color:#fff; }
}
.benefit__icon{
  width:50px; height:50px; border-radius:14px; display:grid; place-items:center;
  background:var(--grad-soft); color:var(--violet); margin-bottom:1.1rem;
  transition:.28s ease;
}
.benefit__icon svg{ width:25px; height:25px; }
.benefit h3{ font-family:var(--serif); font-weight:500; font-size:1.3rem; margin-bottom:.45rem; }
.benefit p{ color:var(--ink-soft); font-size:.97rem; }

/* ---------- PRIMEROS PASOS ---------- */
.pasos{ padding:clamp(4rem,9vw,7rem) 0; background:var(--paper); }
.pasos .section-sub{ margin-bottom:2.6rem; }
.pasos__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; list-style:none;
}
.paso{
  position:relative; padding:2rem 1.7rem 1.7rem;
  background:var(--cream); border:1px solid var(--line); border-radius:var(--radius);
  transition:.28s;
}
.paso:hover{ transform:translateY(-5px); box-shadow:var(--shadow-sm); }
.paso__num{
  display:grid; place-items:center; width:42px; height:42px; border-radius:12px;
  background:var(--grad); color:#fff; font-family:var(--serif); font-size:1.25rem; font-weight:600;
  margin-bottom:1.1rem; box-shadow:0 10px 22px -10px rgba(168,12,240,.7);
}
.paso h3{ font-family:var(--serif); font-weight:500; font-size:1.35rem; margin-bottom:.5rem; }
.paso p{ color:var(--ink-soft); font-size:.98rem; }
.paso__link{ display:inline-block; margin-top:1rem; font-weight:600; font-size:.92rem; color:var(--magenta); transition:.2s; }
.paso__link:hover{ color:var(--violet); }

/* ---------- HERO ---------- */
.hero{
  position:relative; overflow:hidden;
  padding:clamp(4rem,11vw,8rem) 1rem clamp(4rem,9vw,7rem);
  text-align:center;
  background:
    radial-gradient(1100px 600px at 50% -10%, #f6ecff 0%, transparent 60%),
    var(--paper);
}
.hero__inner{ position:relative; z-index:2; width:min(880px,92vw); margin-inline:auto; }
.hero__eyebrow{
  font-size:.82rem; letter-spacing:.22em; text-transform:uppercase;
  font-weight:600; color:var(--magenta); margin-bottom:1.4rem;
}
.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.1rem,5.4vw,4rem); line-height:1.08;
  letter-spacing:-.015em; color:var(--ink);
}
.hero__title em{
  font-style:italic;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__title-soft{ color:var(--ink-soft); font-weight:400; font-size:.7em; }
.hero__lead{
  max-width:620px; margin:1.8rem auto 0;
  font-size:1.12rem; color:var(--ink-soft);
}
.hero__actions{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; margin-top:2.2rem; }

/* Sol radiante (eco del logo) */
.hero__sun{
  position:absolute; top:-32%; left:50%; transform:translateX(-50%);
  width:760px; height:760px; z-index:1; opacity:.5;
  animation:spin 80s linear infinite;
}
.hero__sun span{
  position:absolute; top:50%; left:50%;
  width:5px; height:150px; border-radius:6px;
  background:var(--grad);
  transform-origin:center -10px;
  transform:rotate(calc(var(--i)*7.5deg)) translateY(-180px);
  opacity:calc(.25 + (var(--i) / 96));
}
@keyframes spin{ to{ transform:translateX(-50%) rotate(360deg); } }

/* ---------- MANIFIESTO ---------- */
.manifiesto{ padding:clamp(4rem,9vw,7rem) 0; background:var(--cream); }
.manifiesto__grid{
  display:grid; grid-template-columns:1fr 1.1fr; gap:2.5rem;
  margin-top:2.5rem; align-items:start;
}
.manifiesto__lead p{
  font-family:var(--serif); font-size:clamp(1.4rem,2.5vw,1.9rem);
  line-height:1.3; color:var(--ink);
}
.manifiesto__lead strong{ color:var(--violet); font-weight:600; }
.manifiesto__body p{ color:var(--ink-soft); font-size:1.08rem; margin-bottom:1rem; }
.manifiesto__punch{
  color:var(--ink) !important; font-weight:500;
  border-left:3px solid var(--orchid); padding-left:1.1rem;
}
.seed{
  margin-top:3rem; padding:clamp(2rem,4vw,3.2rem);
  background:#fff; border-radius:var(--radius); box-shadow:var(--shadow);
  border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.seed::before{
  content:""; position:absolute; right:-60px; top:-60px;
  width:240px; height:240px; border-radius:50%;
  background:var(--grad); opacity:.10; filter:blur(8px);
}
.seed h3{ font-family:var(--serif); font-weight:500; font-size:1.7rem; margin-bottom:1rem; }
.seed p{ color:var(--ink-soft); margin-bottom:1rem; max-width:760px; }
.seed__premise{
  font-family:var(--serif); font-size:1.25rem !important; font-style:italic;
  color:var(--violet) !important; font-weight:500;
}

/* ---------- PILARES ---------- */
.pilares{
  padding:clamp(4rem,9vw,7rem) 0;
  background:var(--ink);
  background-image:radial-gradient(900px 500px at 80% 0%, rgba(168,12,240,.35), transparent 60%);
  color:#fff;
}
.pilares__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.6rem;
}
.pilar{
  padding:2.2rem 1.8rem; border-radius:var(--radius);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  transition:.3s;
}
/* Las tres iguales en reposo; toman el color de marca SOLO al pasar el mouse. */
@media (hover:hover){
  .pilar:hover{
    transform:translateY(-6px);
    background:var(--grad); border-color:transparent;
    box-shadow:0 24px 50px -20px rgba(168,12,240,.6);
  }
  .pilar:hover .pilar__num{ color:rgba(255,255,255,.9); }
  .pilar:hover p{ color:rgba(255,255,255,.95); }
}
.pilar__num{
  font-family:var(--serif); font-size:1rem; font-weight:500;
  color:var(--orchid-lt); letter-spacing:.1em;
}
.pilar h3{
  font-family:var(--serif); font-weight:500; font-size:1.7rem;
  margin:.6rem 0 .8rem; text-transform:capitalize;
}
.pilar p{ color:rgba(255,255,255,.78); font-size:1rem; }

/* ---------- RECURSOS / CARDS ---------- */
.recursos{ padding:clamp(4rem,9vw,7rem) 0; background:var(--paper); }
.recursos .section-sub{ margin-bottom:2.6rem; }
.cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem;
}
.card{
  position:relative; display:flex; flex-direction:column;
  padding:1.9rem 1.7rem; border-radius:var(--radius);
  background:#fff; border:1px solid var(--line);
  box-shadow:var(--shadow-sm); transition:.28s ease;
  overflow:hidden;
}
.card::after{
  content:""; position:absolute; inset:0 0 auto 0; height:4px;
  background:var(--grad); transform:scaleX(0); transform-origin:left; transition:.3s;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card:hover::after{ transform:scaleX(1); }
.card__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.1rem; }
.card__tag{
  font-size:.7rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--magenta); background:var(--grad-soft);
  padding:.28rem .7rem; border-radius:100px;
}
.card__icon{
  width:52px; height:52px; border-radius:14px;
  display:grid; place-items:center;
  background:var(--grad-soft); color:var(--violet);
}
.card__icon svg{ width:26px; height:26px; }
.card__title{ font-family:var(--serif); font-weight:500; font-size:1.3rem; margin-bottom:.45rem; }
.card__desc{ color:var(--ink-soft); font-size:.97rem; flex:1; }
.card__cta{
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:1.2rem; font-weight:600; font-size:.92rem; color:var(--magenta);
}
.card__cta svg{ width:17px; height:17px; transition:.25s; }
.card:hover .card__cta svg{ transform:translateX(4px); }
.card--pendiente{ opacity:.72; }
.card--pendiente .card__cta{ color:var(--ink-soft); }

/* ---------- COMUNIDAD ---------- */
.comunidad{ padding:clamp(4rem,9vw,7rem) 0; background:var(--cream); }
.comunidad__inner{
  display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center;
}
.comunidad__text p{ color:var(--ink-soft); font-size:1.08rem; margin-top:1rem; }
.comunidad__list{ list-style:none; margin:1.6rem 0 0; }
.comunidad__list li{
  position:relative; padding-left:1.9rem; margin-bottom:.7rem; color:var(--ink);
}
.comunidad__list li::before{
  content:""; position:absolute; left:0; top:.55em;
  width:11px; height:11px; border-radius:50%; background:var(--grad);
}
.comunidad__actions{ display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.8rem; }

/* Órbita decorativa */
.comunidad__art{ display:grid; place-items:center; }
.orbit{ position:relative; width:300px; height:300px; }
.orbit__core{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:90px; height:90px; border-radius:50%; background:var(--grad);
  box-shadow:0 0 60px -8px rgba(168,12,240,.7);
}
.orbit__dot{
  position:absolute; top:50%; left:50%;
  width:18px; height:18px; border-radius:50%;
  background:#fff; border:2px solid var(--orchid);
  margin:-9px; animation:orbit 18s linear infinite;
}
.orbit__dot::after{ content:""; position:absolute; inset:0; }
.orbit__dot--1{ --r:120px; --d:0s; }
.orbit__dot--2{ --r:120px; --d:-3.6s; }
.orbit__dot--3{ --r:120px; --d:-7.2s; }
.orbit__dot--4{ --r:120px; --d:-10.8s; }
.orbit__dot--5{ --r:120px; --d:-14.4s; }
@keyframes orbit{
  from{ transform:rotate(0deg) translateX(var(--r)) rotate(0deg); }
  to{   transform:rotate(360deg) translateX(var(--r)) rotate(-360deg); }
}
.orbit__dot{ animation-delay:var(--d); }

/* ---------- BUZÓN / FORM ---------- */
.buzon{ padding:clamp(4rem,9vw,7rem) 0; background:var(--paper); }
.buzon__inner{ display:grid; grid-template-columns:.95fr 1.05fr; gap:3rem; align-items:start; }
.buzon__intro p{ color:var(--ink-soft); font-size:1.08rem; margin-top:1rem; }
.form{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.4rem); box-shadow:var(--shadow-sm);
}
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ display:block; margin-bottom:1.1rem; }
.field__label{ display:block; font-size:.86rem; font-weight:600; margin-bottom:.4rem; color:var(--ink); }
.field input, .field textarea{
  width:100%; font-family:inherit; font-size:1rem; color:var(--ink);
  padding:.8rem 1rem; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  background:var(--cream); transition:.2s; resize:vertical;
}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--magenta); background:#fff;
  box-shadow:0 0 0 4px rgba(168,12,240,.10);
}
.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.form__msg:empty{ display:none; }
.alert{ padding:.9rem 1.1rem; border-radius:var(--radius-sm); margin-bottom:1.2rem; font-size:.95rem; font-weight:500; }
.alert--ok{ background:#f0fff4; color:#1a7a44; border:1px solid #b8e8c8; }
.alert--error{ background:#fff2f2; color:#c0392b; border:1px solid #f3c2c2; }

/* ---------- FOOTER ---------- */
.footer{ background:var(--ink); color:#fff; padding-top:clamp(3rem,6vw,5rem); }
.footer__inner{ display:grid; grid-template-columns:1.3fr 2fr; gap:2.5rem; padding-bottom:3rem; }
.footer__logo{ height:38px; margin-bottom:1.1rem; }
.footer__tagline{ color:var(--orchid-lt); font-size:.95rem; margin-bottom:1rem; }
.footer__legacy{ font-family:var(--serif); font-style:italic; color:rgba(255,255,255,.7); font-size:1.05rem; max-width:380px; line-height:1.45; }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer__col h4{ font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; color:var(--orchid-lt); margin-bottom:1rem; }
.footer__col a{ display:block; color:rgba(255,255,255,.78); font-size:.95rem; margin-bottom:.6rem; transition:.2s; }
.footer__col a:hover{ color:#fff; }
.footer__base{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  border-top:1px solid rgba(255,255,255,.12);
  padding:1.5rem clamp(1rem,5vw,0px); width:min(1140px,92vw); margin-inline:auto;
}
.footer__base p{ color:rgba(255,255,255,.55); font-size:.85rem; }
.footer__social{ display:flex; gap:.7rem; }
.footer__social a{
  width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.08); color:#fff; transition:.25s;
}
.footer__social a:hover{ background:var(--grad); transform:translateY(-3px); }
.footer__social svg{ width:19px; height:19px; }

/* ---------- TO TOP ---------- */
.totop{
  position:fixed; right:1.4rem; bottom:1.4rem; z-index:60;
  width:46px; height:46px; border-radius:50%;
  display:grid; place-items:center; font-size:1.2rem; color:#fff;
  background:var(--grad); box-shadow:var(--shadow-sm);
  opacity:0; pointer-events:none; transform:translateY(12px); transition:.3s;
}
.totop.show{ opacity:1; pointer-events:auto; transform:translateY(0); }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:.7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
  .nav__toggle{ display:flex; }
  .nav__links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#ffffff;
    border-bottom:1px solid var(--line);
    box-shadow:0 16px 32px -16px rgba(36,12,48,.30);
    padding:.5rem 1rem 1rem;
    max-height:0; overflow:hidden; opacity:0; pointer-events:none;
    transition:max-height .35s ease, opacity .25s ease;
  }
  .nav.is-open .nav__links{ max-height:420px; opacity:1; pointer-events:auto; }
  .nav__links a{ padding:.9rem .4rem; border-bottom:1px solid var(--line); }
  .nav__cta{ text-align:center; margin-top:.7rem; padding:.8rem 1.2rem; }
  /* Accesos rápidos: sin ensanchado y en 2 columnas */
  .quick{ width:auto; left:auto; transform:none; }
  .quick__chips{ grid-template-columns:repeat(2,1fr); }
  .benefits,
  .pasos__grid,
  .manifiesto__grid,
  .pilares__grid,
  .cards,
  .comunidad__inner,
  .buzon__inner,
  .footer__inner{ grid-template-columns:1fr; }
  .footer__cols{ grid-template-columns:1fr 1fr; }
  .comunidad__art{ order:-1; }
}
@media (max-width:560px){
  .form__row{ grid-template-columns:1fr; }
  .footer__cols{ grid-template-columns:1fr; }
  .hero__sun{ width:480px; height:480px; }
  .quick__chips{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}

/* Rotación de cada rayo del sol (sin estilos inline) */
.hero__sun span:nth-child(1){--i:0;}
.hero__sun span:nth-child(2){--i:1;}
.hero__sun span:nth-child(3){--i:2;}
.hero__sun span:nth-child(4){--i:3;}
.hero__sun span:nth-child(5){--i:4;}
.hero__sun span:nth-child(6){--i:5;}
.hero__sun span:nth-child(7){--i:6;}
.hero__sun span:nth-child(8){--i:7;}
.hero__sun span:nth-child(9){--i:8;}
.hero__sun span:nth-child(10){--i:9;}
.hero__sun span:nth-child(11){--i:10;}
.hero__sun span:nth-child(12){--i:11;}
.hero__sun span:nth-child(13){--i:12;}
.hero__sun span:nth-child(14){--i:13;}
.hero__sun span:nth-child(15){--i:14;}
.hero__sun span:nth-child(16){--i:15;}
.hero__sun span:nth-child(17){--i:16;}
.hero__sun span:nth-child(18){--i:17;}
.hero__sun span:nth-child(19){--i:18;}
.hero__sun span:nth-child(20){--i:19;}
.hero__sun span:nth-child(21){--i:20;}
.hero__sun span:nth-child(22){--i:21;}
.hero__sun span:nth-child(23){--i:22;}
.hero__sun span:nth-child(24){--i:23;}
.hero__sun span:nth-child(25){--i:24;}
.hero__sun span:nth-child(26){--i:25;}
.hero__sun span:nth-child(27){--i:26;}
.hero__sun span:nth-child(28){--i:27;}
.hero__sun span:nth-child(29){--i:28;}
.hero__sun span:nth-child(30){--i:29;}
.hero__sun span:nth-child(31){--i:30;}
.hero__sun span:nth-child(32){--i:31;}
.hero__sun span:nth-child(33){--i:32;}
.hero__sun span:nth-child(34){--i:33;}
.hero__sun span:nth-child(35){--i:34;}
.hero__sun span:nth-child(36){--i:35;}
.hero__sun span:nth-child(37){--i:36;}
.hero__sun span:nth-child(38){--i:37;}
.hero__sun span:nth-child(39){--i:38;}
.hero__sun span:nth-child(40){--i:39;}
.hero__sun span:nth-child(41){--i:40;}
.hero__sun span:nth-child(42){--i:41;}
.hero__sun span:nth-child(43){--i:42;}
.hero__sun span:nth-child(44){--i:43;}
.hero__sun span:nth-child(45){--i:44;}
.hero__sun span:nth-child(46){--i:45;}
.hero__sun span:nth-child(47){--i:46;}
.hero__sun span:nth-child(48){--i:47;}
