/* ============================================================
   apply.css — apply.html, donate.html (forms, switcher, steps, countdown)
   ============================================================ */

/* ---------- Apply hero (shared across apply + donate) ---------- */
.apply-hero { padding: 160px 0 80px; position: relative; overflow: hidden }
.apply-hero::before { content: ""; position: absolute; inset: -100px; background: radial-gradient(circle at 70% 50%, rgba(231,84,128,.18), transparent 50%); pointer-events: none }
.apply-hero .container { position: relative }
.apply-hero h1 { font-size: clamp(48px,7vw,96px); font-weight: 900; line-height: .95; letter-spacing: -.03em; margin-top: 18px }
.apply-hero .accent { color: var(--pink); font-style: italic }
.apply-hero-sub { margin-top: 24px; max-width: 600px; font-size: 18px; line-height: 1.65; color: var(--muted) }

/* ---------- Switcher / tab bar ---------- */
.apply-switcher-section { padding: 0 0 60px }
.apply-switcher { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px }
.switcher-btn { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; padding: 28px; border-radius: 24px; border: 1px solid var(--border); background: linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)); cursor: pointer; transition: border-color .3s, background .3s, transform .3s; text-align: left }
.switcher-btn:hover { border-color: rgba(231,84,128,.5); transform: translateY(-3px) }
.switcher-btn.active { border-color: var(--pink); background: rgba(231,84,128,.1) }
.switcher-icon { display: flex; align-items: center; color: var(--pink); width: 22px; height: 22px }
.switcher-icon svg { flex: 0 0 auto }
.switcher-btn.active .switcher-icon { color: var(--pink) }
.switcher-btn:not(.active) .switcher-icon { color: rgba(255,255,255,.5) }
.switcher-label { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 18px; color: var(--white) }
.switcher-desc { font-size: 13px; color: var(--muted) }

/* ---------- Form panels ---------- */
.forms-area { padding: 0 0 120px }
.form-panel { display: none }
.form-panel.active { display: block }
.form-panel-inner { background: #0a0a0a; border: 1px solid var(--border); border-radius: 32px; padding: 50px; display: grid; grid-template-columns: 280px 1fr; gap: 60px; min-height: 480px }
.form-intro h2 { font-size: 32px; font-weight: 800; line-height: 1.05; letter-spacing: -.02em; margin-bottom: 14px }
.form-intro p { color: rgba(255,255,255,.65); line-height: 1.6; font-size: 15px }
.form-contact-info { margin-top: 32px; display: flex; flex-direction: column; gap: 14px; font-size: 14px }
.form-contact-info div { display: flex; flex-direction: column; gap: 4px }
.form-contact-info strong { font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--pink) }
.form-contact-info span { color: rgba(255,255,255,.7) }

/* Dark form fields */
.fempower-form .field label { color: rgba(255,255,255,.7) }
.fempower-form .field input,
.fempower-form .field textarea,
.fempower-form .field select {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  color: var(--white);
}
.fempower-form .field input::placeholder,
.fempower-form .field textarea::placeholder { color: rgba(255,255,255,.35) }
.fempower-form .field select option { background: #1f1f1f; color: var(--white) }

/* Partner form (white bg) */
#partner-form .field label { color: #111 }
#partner-form .field input,
#partner-form .field textarea,
#partner-form .field select {
  background: #fff; border: 1px solid rgba(0,0,0,.12); color: #111;
}
#partner-form .field input::placeholder,
#partner-form .field textarea::placeholder { color: rgba(0,0,0,.4) }
#form-partner .form-panel-inner { background: var(--white); color: var(--black) }
#form-partner .form-intro h2 { color: #111 }
#form-partner .form-intro p { color: rgba(0,0,0,.65) }
#form-partner .form-contact-info span { color: rgba(0,0,0,.7) }
#form-partner .form-footer small { color: rgba(0,0,0,.5) }
#form-partner .form-footer a { color: var(--pink) }

.form-footer { margin-top: 8px; display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap }
.form-footer small { font-size: 12px; max-width: 300px; color: rgba(255,255,255,.45); line-height: 1.5 }
.form-footer a { color: var(--pink) }

.req { color: var(--pink) }

/* Checkboxes and radios */
.checkbox-group, .radio-group { display: flex; flex-direction: column; gap: 10px; margin-top: 6px }
.check-item { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: rgba(255,255,255,.75); cursor: pointer; line-height: 1.5 }
.check-item input[type="checkbox"],
.check-item input[type="radio"] { width: auto; flex: 0 0 auto; margin-top: 3px; accent-color: var(--pink) }

/* ---------- Success card ---------- */
.success-card { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; padding: 20px 0 }
.success-icon { width: 64px; height: 64px; border-radius: 50%; background: var(--pink); display: grid; place-items: center; color: white; flex: 0 0 auto }
.success-card h3 { font-size: 32px; font-weight: 800; letter-spacing: -.02em }
.success-card p { color: var(--muted); line-height: 1.6; max-width: 520px }

/* ---------- Competition layout ---------- */
.form-panel-inner.competition-layout { grid-template-columns: 1fr; gap: 40px }
.competition-layout .countdown { margin-bottom: 8px }
.competition-layout .step-rail,
.competition-layout .step-body { display: block }
.comp-step-wrapper { display: grid; grid-template-columns: 260px 1fr; gap: 40px }

/* Step rail */
.step-rail h4 { font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--pink); margin-bottom: 24px }
.step-rail ol { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px }
.step-rail li { padding: 14px 16px; border-radius: 14px; font-size: 14px; color: rgba(255,255,255,.6); display: flex; gap: 14px; align-items: center; cursor: pointer; transition: background .25s, color .25s }
.step-rail li b { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 13px; color: rgba(255,255,255,.36) }
.step-rail li:hover { color: var(--white) }
.step-rail li.active { background: rgba(231,84,128,.12); color: var(--white) }
.step-rail li.active b { color: var(--pink) }
.step-rail li.done b { color: var(--pink) }
.progress { margin-top: 32px }
.progress .meter { height: 4px; background: rgba(255,255,255,.1); border-radius: 999px; overflow: hidden; margin-top: 10px }
.progress .meter span { display: block; height: 100%; background: var(--pink); border-radius: 999px; transition: width .5s cubic-bezier(.22,1,.36,1) }
.progress .label { display: flex; justify-content: space-between; font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--muted) }

/* Step form */
.step-title { font-family: 'Montserrat', sans-serif; font-size: 28px; font-weight: 800; letter-spacing: -.02em; color: var(--white) }
.step-sub { margin-top: 8px; color: var(--muted); font-size: 15px; line-height: 1.6; max-width: 460px }
.step-form { margin-top: 28px; display: grid; grid-template-columns: 1fr 1fr; gap: 18px }
.step-form .field.full { grid-column: 1 / -1 }

/* Upload URL box */
.upload-url-box { border: 2px dashed rgba(231,84,128,.4); border-radius: 20px; padding: 32px 24px; background: rgba(231,84,128,.05); transition: border-color .25s, background .25s; display: flex; flex-direction: column; align-items: center; gap: 14px }
.upload-url-box:focus-within { border-color: var(--pink); background: rgba(231,84,128,.08) }
.upload-icon { width: 46px; height: 46px; border-radius: 50%; background: var(--pink); display: grid; place-items: center }
.upload-url-box input[type="url"] { width: 100%; max-width: 460px; text-align: center; background: rgba(255,255,255,.06); border: 1px solid var(--border); color: var(--white); border-radius: 12px; padding: 12px 16px; font-size: 14px }
.upload-url-box input::placeholder { color: rgba(255,255,255,.35); font-size: 13px }
.field-hint { font-size: 12px; color: rgba(255,255,255,.45); margin-top: 4px }

.step-actions { margin-top: 32px; display: flex; justify-content: space-between; gap: 12px }

/* ---------- Countdown ---------- */
.countdown { display: flex; align-items: center; gap: 24px; padding: 22px 28px; border: 1px solid var(--border); border-radius: 20px; background: rgba(255,255,255,.02); flex-wrap: wrap }
.countdown-label { font-size: 13px; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); white-space: nowrap }
.countdown-units { display: flex; gap: 16px }
.countdown-units div { display: flex; flex-direction: column; align-items: center; min-width: 54px }
.countdown-units b { font-family: 'Montserrat', sans-serif; font-size: 34px; font-weight: 900; color: var(--white); letter-spacing: -.02em; line-height: 1 }
.countdown-units span { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); margin-top: 4px }
/* Urgent state (≤14 days) */
.countdown.urgent { border-color: rgba(231,84,128,.55); background: rgba(231,84,128,.08) }
.countdown.urgent .countdown-units b { color: var(--pink) }
.countdown.urgent .countdown-label { color: var(--pink) }
/* Critical state (≤3 days) */
.countdown.critical { border-color: var(--pink); background: rgba(231,84,128,.15) }
@keyframes countdown-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(231,84,128,.0)} 50%{box-shadow:0 0 0 8px rgba(231,84,128,.3)} }
.countdown.critical { animation: countdown-pulse 1.6s ease infinite }
/* Closed state */
.countdown.closed .countdown-units { display: none }
.countdown.closed .countdown-label { color: rgba(255,255,255,.55) }
@media (prefers-reduced-motion: reduce) {
  .countdown.critical { animation: none }
}

/* ---------- Donate page extras ---------- */
.donate-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px }
.donate-stat { padding: 42px; border: 1px solid var(--border); border-radius: 24px; background: linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)); display: flex; flex-direction: column; gap: 12px; transition: border-color .3s, transform .3s }
.donate-stat:hover { border-color: var(--pink); transform: translateY(-4px) }
.donate-stat b { font-family: 'Montserrat', sans-serif; font-size: 72px; font-weight: 900; color: var(--pink); letter-spacing: -.04em; line-height: 1 }
.donate-stat span { color: rgba(255,255,255,.7); font-size: 16px; line-height: 1.5 }

.payment-placeholder { border: 1px dashed rgba(231,84,128,.4); border-radius: 28px; padding: 52px; max-width: 640px; margin: 0 auto; background: rgba(231,84,128,.04) }
.payment-placeholder h3 { font-size: 28px; font-weight: 800 }

/* ---------- Mobile money modal ---------- */
.momo-overlay { position: fixed; inset: 0; z-index: 400; display: grid; place-items: center; padding: 24px; background: rgba(0,0,0,.72); backdrop-filter: blur(6px) }
.momo-dialog { background: #0e0e0e; border: 1px solid var(--border); border-radius: 24px; padding: 40px; max-width: 440px; width: 100%; position: relative; text-align: left; box-shadow: var(--shadow-card) }
.momo-dialog h3 { font-size: 26px; font-weight: 800; letter-spacing: -.02em; margin: 10px 0 0 }
.momo-close { position: absolute; top: 18px; right: 18px; width: 40px; height: 40px; border: 1px solid var(--border); border-radius: 12px; display: grid; place-items: center; color: var(--white); transition: border-color .2s, color .2s }
.momo-close:hover { border-color: var(--pink); color: var(--pink) }
.momo-note { color: var(--muted); font-size: 14px; line-height: 1.6; margin-top: 12px }
.momo-providers { margin-top: 18px; font-size: 13px; letter-spacing: .04em; color: rgba(255,255,255,.72) }
.momo-number-row { display: flex; align-items: center; gap: 12px; margin-top: 16px; padding: 16px 18px; border: 1px solid var(--border); border-radius: 14px; background: rgba(231,84,128,.07) }
.momo-number { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 22px; color: var(--white); letter-spacing: .02em; flex: 1 }
.momo-copy { padding: 8px 16px; border-radius: 999px; background: var(--pink); color: #fff; font-weight: 700; font-size: 13px; transition: background .2s }
.momo-copy.copied { background: #2e7d32 }
.momo-name { margin-top: 14px; color: rgba(255,255,255,.8); font-size: 14px }
.momo-placeholder-note { margin-top: 8px; font-size: 12px; color: rgba(255,255,255,.5) }
.momo-dialog .btn { margin-top: 24px; width: 100%; justify-content: center }

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
  .apply-switcher { grid-template-columns: 1fr }
  .form-panel-inner { grid-template-columns: 1fr; padding: 36px }
  .donate-stats { grid-template-columns: 1fr 1fr }
}
@media (max-width: 760px) {
  .apply-hero { padding: 120px 0 60px }
  .form-panel-inner { padding: 28px }
  .step-form { grid-template-columns: 1fr }
  .donate-stats { grid-template-columns: 1fr }
  .countdown { flex-direction: column; align-items: flex-start; gap: 16px }
  .countdown-units { gap: 12px }
  .countdown-units b { font-size: 26px }
}
