/* ============================================================
   FitBridge — Welcome / onboarding (first-run flow)
   ============================================================ */
.welcome { position: absolute; inset: 0; z-index: 60; background: var(--bg); display: flex; flex-direction: column; }
.welcome[hidden] { display: none; }
.wlc-bar { display: flex; align-items: center; gap: 18px; padding: 26px 36px 0; }
.wlc-mark { width: 150px; height: 38px;
  background-image: url("../assets/brand/wordmark.png");
  background-repeat: no-repeat; background-position: left center; background-size: contain; }
.wlc-dots { display: flex; gap: 7px; margin-left: auto; }
.wlc-dots i { width: 30px; height: 5px; border-radius: 3px; background: var(--bg-deep); transition: background .2s; }
.wlc-dots i.done { background: var(--accent); }
.wlc-skip { font-size: 13px; font-weight: 700; color: var(--dim); }
.wlc-skip:hover { color: var(--ink); }

.wlc-stage { flex: 1; display: grid; place-items: center; padding: 24px 36px; min-height: 0; }
.wlc-card {
  width: 640px; max-width: 100%; background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 26px; box-shadow: var(--card-shadow); padding: 40px 44px; display: flex; flex-direction: column; gap: 18px;
}
.wlc-step-label { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent-strong); }
.wlc-card h2 { margin: 0; font-size: 30px; font-weight: 800; letter-spacing: -0.02em; }
.wlc-card .wlc-hint { margin: -8px 0 4px; font-size: 14.5px; color: var(--dim); line-height: 1.5; }

.wlc-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.wlc-form .span-2 { grid-column: span 2; }
.wlc-form label { display: flex; flex-direction: column; gap: 6px; font-size: 12.5px; font-weight: 700; color: var(--dim); }
.wlc-form input, .wlc-form select { padding: 12px 14px; border: 1px solid var(--card-border); border-radius: 12px; font-size: 15px; background: #fff; color: var(--ink); }
.wlc-form input:focus, .wlc-form select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

.wlc-tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.wlc-tile { display: flex; align-items: center; gap: 14px; padding: 18px 20px; border: 2px solid var(--card-border); border-radius: 16px; background: #fff; text-align: left; transition: border-color .15s, background .15s; }
.wlc-tile:hover { background: var(--hover-tint); }
.wlc-tile.is-selected { border-color: var(--accent); background: var(--accent-soft); }
.wlc-tile .te { font-size: 28px; }
.wlc-tile .tl { display: block; font-size: 16px; font-weight: 800; }
.wlc-tile .td { display: block; font-size: 12.5px; color: var(--dim); margin-top: 1px; }

.wlc-event-fields { display: grid; grid-template-columns: 2fr 1fr; gap: 14px; margin-top: 4px; }
.wlc-event-fields[hidden] { display: none; }

.wlc-choice { display: flex; gap: 14px; }
.wlc-choice .wlc-tile { flex: 1; flex-direction: column; align-items: flex-start; gap: 8px; }

/* sport-selection grid (uses the sport tiles as the picker) */
.wlc-sports { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.wlc-sport { position: relative; display: flex; flex-direction: column; align-items: center; gap: 11px; padding: 14px 14px 16px; border: 2px solid var(--card-border); border-radius: 18px; background: #fff; transition: border-color .15s, transform .12s, box-shadow .15s; }
.wlc-sport:hover { transform: translateY(-2px); }
.wlc-sport.is-selected { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.wlc-sport .ws-tile { width: 100%; aspect-ratio: 1; border-radius: 13px; background-size: cover; background-position: center; }
.wlc-sport .ws-label { font-size: 14px; font-weight: 800; color: var(--ink); }
.wlc-sport .ws-check { position: absolute; top: 9px; right: 9px; width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; opacity: 0; transform: scale(.6); transition: opacity .15s, transform .15s; }
.wlc-sport .ws-check svg { width: 13px; height: 13px; }
.wlc-sport.is-selected .ws-check { opacity: 1; transform: none; }

.wlc-ics { width: 100%; min-height: 96px; resize: none; padding: 14px; border: 1px solid var(--card-border); border-radius: 14px; font-family: var(--font-mono); font-size: 13px; background: #fff; color: var(--ink); }
.wlc-ics:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

.wlc-actions { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.wlc-actions .spacer { flex: 1; }

/* building step */
.wlc-build { display: flex; flex-direction: column; align-items: center; gap: 22px; padding: 30px 0; text-align: center; }
.wlc-spinner { width: 54px; height: 54px; border-radius: 50%; border: 5px solid var(--accent-soft); border-top-color: var(--accent); animation: wlcspin 0.9s linear infinite; }
@keyframes wlcspin { to { transform: rotate(360deg); } }
.wlc-build-rows { display: flex; flex-direction: column; gap: 10px; width: 100%; max-width: 380px; }
.wlc-build-row { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--dim); opacity: 0; transform: translateY(6px); transition: opacity .3s, transform .3s; }
.wlc-build-row.in { opacity: 1; transform: none; color: var(--ink-2); }
.wlc-build-row .bc { width: 20px; height: 20px; border-radius: 50%; background: var(--good); color: #fff; display: grid; place-items: center; flex: 0 0 20px; }
.wlc-build-row .bc svg { width: 12px; height: 12px; }
