/* How To Join — full redesign (innovative tech style) */
/* Follows project variables and typography. Works standalone via this stylesheet. */

.join-section{max-width:980px;margin:22px auto 28px;padding:0 6px;font-family:'Space Grotesk','IBM Plex Sans',sans-serif;position:relative;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.join-hero{position:relative;margin:0 auto 18px;padding:16px 16px;border:1px solid rgba(4,170,159,.35);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02));box-shadow:0 12px 32px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06)}
.join-hero::before{content:none}
.join-hero h2{margin:0 0 6px;font-family:'Space Grotesk','IBM Plex Sans',sans-serif;font-weight:700;letter-spacing:.15px;color:#e7f2ef;font-size:20px;text-align:left}
.join-hero p{margin:0;color:#cfd7e2;font-size:14px;line-height:1.6;text-align:left;font-family:'IBM Plex Sans',sans-serif;font-weight:400}

/* Text alignment policy: consistently left-aligned in Join section */
.join-section, .join-section .step-card, .join-section .detail-block { text-align: left; }
.join-section p,
.join-section .step-desc,
.join-section .detail-list,
.join-section .detail-block p,
.join-section li { text-align: left; }
/* Top progress line */
.join-accent{position:relative;height:6px;background:linear-gradient(90deg,var(--primary-accent) 0%, #66c7c0 100%);border:1px solid rgba(4,170,159,.65);border-radius:999px;overflow:hidden;margin:16px 0 18px;box-shadow:0 0 20px rgba(4,170,159,.35), 0 0 40px rgba(4,170,159,.22);animation:warmGlow 3.2s ease-in-out infinite}
.join-accent::after{content:"";position:absolute;inset:-6px;border-radius:inherit;background:radial-gradient(120% 80% at 50% 50%, rgba(4,170,159,.35), transparent 60%);filter:blur(8px);opacity:.75;pointer-events:none}
@keyframes warmGlow{0%,100%{box-shadow:0 0 16px rgba(4,170,159,.28), 0 0 32px rgba(4,170,159,.18)}50%{box-shadow:0 0 30px rgba(4,170,159,.5), 0 0 60px rgba(4,170,159,.28)}}

/* Step pills (tablist) */
.join-pills{display:flex;gap:8px;flex-wrap:nowrap;overflow:auto;padding:4px 2px;margin:6px 0}
.join-pills::-webkit-scrollbar{display:none}
.join-pill{appearance:none;border:none;background:rgba(255,255,255,.03);color:#d7e2ee;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:8px 12px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:12px;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;transition:all .25s ease;position:relative;flex:0 0 auto}
.join-pill .num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--primary-accent),#66c7c0);color:#0f1420;font-weight:800;font-size:11px;box-shadow:0 0 10px rgba(4,170,159,.35)}
.join-pill[aria-selected="true"],.join-pill.active{background:linear-gradient(135deg,rgba(4,170,159,.22),rgba(4,170,159,.12));border-color:var(--primary-accent);color:#fff;box-shadow:0 0 0 1px rgba(4,170,159,.35),0 6px 18px rgba(4,170,159,.25)}
.join-pill:hover{border-color:var(--primary-accent);color:#fff}

/* Panels */
.step-panels{margin-top:16px;display:grid;gap:20px}
.step-carousel{display:none}
@media (max-width:767px){
  /* Carousel disabled: keep grid with gaps on mobile */
  .step-panels{display:grid;gap:24px}
  .step-card{min-width:auto;margin-bottom:0}
}
.step-card{position:relative;border:1px solid rgba(4,170,159,.3);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02));padding:16px;box-shadow:0 12px 32px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.05);margin-bottom:0}
.step-card:last-of-type{margin-bottom:0}


.step-card::before{content:none}
.step-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.step-title-wrap{display:flex;align-items:center;gap:10px}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;aspect-ratio:1/1;border-radius:8px;background:linear-gradient(135deg,var(--primary-accent),#66c7c0);color:#0f1420;font-weight:800;font-family:'Exo 2',sans-serif;line-height:1;font-variant-numeric:tabular-nums;box-shadow:0 4px 12px rgba(4,170,159,.35)}
.step-title{margin:0;font-size:18px;color:#eaf3f1;font-family:'Space Grotesk','IBM Plex Sans',sans-serif;font-weight:700;letter-spacing:.15px}
.step-meta{display:flex;flex-wrap:wrap;gap:8px}
.meta-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(4,170,159,.35);background:rgba(4,170,159,.08);color:var(--primary-accent);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.25px;font-family:'Space Grotesk','IBM Plex Sans',sans-serif}
.meta-chip svg{width:14px;height:14px;color:var(--primary-accent)}
.step-desc{color:#cfd7e2;line-height:1.6;margin:6px 0 12px;font-size:14px;font-family:'IBM Plex Sans',sans-serif;font-weight:400}

/* Details */
.step-details{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.detail-block{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px}
.detail-title{margin:0 0 8px;font-size:13px;color:#bcd6d2;font-weight:700;text-transform:uppercase;letter-spacing:.25px;font-family:'Space Grotesk','IBM Plex Sans',sans-serif}
.detail-list{margin:0;padding-left:16px;color:#cfe6e2;line-height:1.6;font-size:14px;font-family:'IBM Plex Sans',sans-serif;font-weight:400}
.detail-list li{margin:6px 0}

/* CTA area */
.join-ctas{margin:12px 0 0;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;align-items:stretch}
.step-cta{margin-top:10px;display:flex;justify-content:flex-end}
.btn-primary{appearance:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,var(--primary-accent),#3CB3A7);color:#0f1420;font-weight:800;font-family:'Space Grotesk','IBM Plex Sans',sans-serif;letter-spacing:.25px;text-transform:uppercase;box-shadow:0 8px 22px rgba(4,170,159,.35);transition:transform .2s ease,box-shadow .2s ease;line-height:1}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(4,170,159,.45)}
.btn-primary.btn-wide{width:100%;justify-content:center}
@media (max-width:767px){
  #go-residents{margin-left:0}
}
.final-cta{margin:22px 0 0}

@media (max-width:767px){
  .join-ctas{justify-content:space-between;margin-bottom:6px;flex-wrap:nowrap}
  .join-ctas .btn-primary,
  .join-ctas .btn-outline{flex:1 1 0%;min-height:44px;justify-content:center;text-align:center;white-space:nowrap}
}

/* Scroll spy marker (accent glow when active) */
.step-card.active{box-shadow:0 12px 32px rgba(0,0,0,.35),0 0 0 1px rgba(4,170,159,.28),0 0 22px rgba(4,170,159,.18)}

/* Progress bar inside join-accent (mobile only) */
.join-accent{position:relative}
.join-progress{position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,rgba(255,255,255,.35),rgba(255,255,255,.12));box-shadow:0 0 16px rgba(4,170,159,.4);border-radius:inherit;transition:width .25s ease}
@media (min-width:768px){.join-progress{display:none}}

/* Sticky pills removed */
.join-pills.stuck{display:none}

/* Responsive */
@media (max-width:767px){
  .join-hero{padding:14px 12px;border-radius:14px}
  .join-hero h2{font-size:18px}
  .join-hero p{font-size:13px}
  .step-card{padding:16px}
  .step-desc{font-size:13px}
  .detail-title{font-size:12px}
  .detail-list{font-size:13px}
  .step-details{grid-template-columns:1fr}
  .step-header{flex-direction:column;align-items:flex-start;gap:8px}
  .step-num{width:30px;height:30px;font-size:14px;border-radius:10px}
  /* Единый базовый размер шрифта в карточке на мобиле */
  .step-card{line-height:1.55}
  .step-card, .step-card *{letter-spacing:.2px}
}
@media (max-width:420px){
  .step-desc{font-size:12.5px}
  .detail-list{font-size:11.5px}
}

/* Reduced motion */

/* Mobile pills, carousel, progress — rollback removed */

@media (prefers-reduced-motion: reduce){
  .join-accent{animation:none}
  .btn-primary{transition:none}
}
