/* VeloNW Registration — Frontend Styles */

:root {
    --vnw-primary: #e85d04;
    --vnw-primary-dark: #c44e00;
    --vnw-dark: #1a1a1a;
    --vnw-gray: #6b7280;
    --vnw-border: #e5e7eb;
    --vnw-bg: #f9fafb;
    --vnw-radius: 8px;
    --vnw-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

/* ── Utility ─────────────────────────────────────── */
.velonw-hidden { display: none !important; }
.velonw-text-muted { color: var(--vnw-gray); font-size: 14px; }
.velonw-req { color: #dc2626; }

/* ── Notices ─────────────────────────────────────── */
.velonw-notice {
    padding: 14px 18px;
    border-radius: var(--vnw-radius);
    margin-bottom: 20px;
    font-size: 15px;
    border-left: 4px solid currentColor;
}
.velonw-notice--error { background: #fef2f2; color: #dc2626; border-color: #dc2626; }
.velonw-notice--warn  { background: #fffbeb; color: #92400e; border-color: #f59e0b; }
.velonw-notice--info  { background: #eff6ff; color: #1d4ed8; border-color: #3b82f6; }
.velonw-notice--success { background: #f0fdf4; color: #15803d; border-color: #22c55e; }

/* ── Badges ──────────────────────────────────────── */
.velonw-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.velonw-badge--open     { background: #dcfce7; color: #15803d; }
.velonw-badge--closed   { background: #f3f4f6; color: #6b7280; }
.velonw-badge--soon     { background: #dbeafe; color: #1d4ed8; }
.velonw-badge--full     { background: #fef9c3; color: #854d0e; }
.velonw-badge--earlybird{ background: #fce7f3; color: #9d174d; }

/* ── Buttons ─────────────────────────────────────── */
.velonw-btn {
    display: inline-block;
    padding: 10px 22px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    text-decoration: none;
    border: none;
    transition: background 0.15s, transform 0.1s;
    line-height: 1.4;
}
.velonw-btn:hover { transform: translateY(-1px); }
.velonw-btn--primary { background: var(--vnw-primary); color: #fff; }
.velonw-btn--primary:hover { background: var(--vnw-primary-dark); color: #fff; }
.velonw-btn--secondary { background: #fff; color: var(--vnw-dark); border: 1.5px solid var(--vnw-border); }
.velonw-btn--secondary:hover { background: var(--vnw-bg); }
.velonw-btn--danger { background: #fee2e2; color: #dc2626; }
.velonw-btn--danger:hover { background: #fecaca; }
.velonw-btn--lg { padding: 14px 32px; font-size: 16px; }
.velonw-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ── Race Card ───────────────────────────────────── */
.velonw-races { display: flex; flex-direction: column; gap: 24px; }

.velonw-race-card {
    background: #fff;
    border: 1px solid var(--vnw-border);
    border-radius: 12px;
    padding: 28px;
    box-shadow: var(--vnw-shadow);
}
.velonw-race-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.velonw-race-card__title { margin: 0; font-size: 22px; color: var(--vnw-dark); }
.velonw-race-card__meta { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 12px; }
.velonw-meta-item { font-size: 14px; color: var(--vnw-gray); }
.velonw-meta-item a { color: var(--vnw-primary); }
.velonw-race-card__desc { color: #374151; line-height: 1.6; margin: 12px 0; }
.velonw-race-card__actions { display: flex; align-items: center; gap: 16px; margin-top: 20px; }
.velonw-registered-count { font-size: 13px; color: var(--vnw-gray); }

.velonw-categories { margin: 16px 0; border-top: 1px solid var(--vnw-border); padding-top: 12px; }
.velonw-category-row {
    display: flex; align-items: center; gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid #f3f4f6;
    flex-wrap: wrap;
}
.velonw-category-name { font-weight: 500; flex: 1; }
.velonw-category-price { font-weight: 700; color: var(--vnw-primary); }
.velonw-category-spots { font-size: 12px; color: var(--vnw-gray); }

/* ── Registration Form ───────────────────────────── */
.velonw-register { max-width: 760px; }
.velonw-register__header { margin-bottom: 28px; }
.velonw-register__header h2 { margin: 0 0 6px; font-size: 26px; }

.velonw-section {
    background: #fff;
    border: 1px solid var(--vnw-border);
    border-radius: var(--vnw-radius);
    padding: 24px;
    margin-bottom: 20px;
}
.velonw-section h3 { margin: 0 0 18px; font-size: 17px; color: var(--vnw-dark); }

.velonw-grid { display: grid; gap: 16px; }
.velonw-grid--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .velonw-grid--2 { grid-template-columns: 1fr; } }

.velonw-field { display: flex; flex-direction: column; gap: 6px; }
.velonw-field label { font-weight: 500; font-size: 14px; color: #374151; }
.velonw-field input,
.velonw-field select,
.velonw-field textarea {
    padding: 9px 12px;
    border: 1.5px solid var(--vnw-border);
    border-radius: 6px;
    font-size: 15px;
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.15s;
    font-family: inherit;
}
.velonw-field input:focus,
.velonw-field select:focus,
.velonw-field textarea:focus { border-color: var(--vnw-primary); outline: none; }

.velonw-category-grid { display: flex; flex-direction: column; gap: 10px; }
.velonw-category-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 16px;
    border: 2px solid var(--vnw-border);
    border-radius: var(--vnw-radius);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}
.velonw-category-card input[type="radio"] { margin: 0; accent-color: var(--vnw-primary); }
.velonw-category-card:has(input:checked) { border-color: var(--vnw-primary); background: #fff8f5; }
.velonw-category-card:has(input:not(:disabled)):hover { border-color: var(--vnw-primary); }
.velonw-category-card--full { opacity: 0.6; cursor: default; }
.velonw-category-card__body { flex: 1; }
.velonw-category-card__body strong { display: block; }
.velonw-category-card__body small { color: var(--vnw-gray); font-size: 13px; }
.velonw-category-card__price { text-align: right; font-weight: 700; font-size: 17px; color: var(--vnw-primary); }
.velonw-category-card__price small { display: block; font-size: 12px; font-weight: 400; color: var(--vnw-gray); }

.velonw-discount-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.velonw-discount-row input { padding: 9px 12px; border: 1.5px solid var(--vnw-border); border-radius: 6px; font-size: 15px; }
#velonw-discount-result { font-size: 14px; font-weight: 500; }

.velonw-waiver-text {
    background: var(--vnw-bg);
    border: 1px solid var(--vnw-border);
    border-radius: 6px;
    padding: 16px;
    font-size: 13px;
    line-height: 1.6;
    max-height: 200px;
    overflow-y: auto;
    margin-bottom: 14px;
}

.velonw-checkbox { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.velonw-checkbox input { margin-top: 3px; accent-color: var(--vnw-primary); }

.velonw-order-summary { border-color: var(--vnw-primary); }
.velonw-summary-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 0; border-bottom: 1px solid var(--vnw-border); font-size: 15px;
}
.velonw-summary-row--total { border-bottom: none; font-size: 18px; padding-top: 12px; }

/* ── Portal ──────────────────────────────────────── */
.velonw-portal { max-width: 640px; }
.velonw-portal h2 { margin-bottom: 8px; }
.velonw-portal-lookup .velonw-grid { margin-bottom: 16px; }
.velonw-portal-lookup input { padding: 10px 12px; border: 1.5px solid var(--vnw-border); border-radius: 6px; font-size: 15px; width: 100%; box-sizing: border-box; }
.velonw-portal__card { background: #fff; border: 1px solid var(--vnw-border); border-radius: 12px; padding: 24px; box-shadow: var(--vnw-shadow); }
.velonw-portal__card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.velonw-portal__card-header h3 { margin: 0; }
.velonw-portal__table { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.velonw-portal__table th { text-align: left; color: var(--vnw-gray); padding: 8px 12px 8px 0; width: 40%; font-weight: 500; font-size: 14px; }
.velonw-portal__table td { padding: 8px 0; border-bottom: 1px solid var(--vnw-border); }
.velonw-portal__actions { margin-top: 16px; }

/* ── Race Select ─────────────────────────────────── */
.velonw-race-select-list { list-style: none; padding: 0; margin: 0; }
.velonw-race-select-link {
    display: flex; justify-content: space-between; padding: 14px 16px;
    border: 1px solid var(--vnw-border); border-radius: 8px; margin-bottom: 10px;
    text-decoration: none; color: var(--vnw-dark);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.velonw-race-select-link:hover { border-color: var(--vnw-primary); box-shadow: 0 2px 8px rgba(232,93,4,0.15); }
.velonw-race-select-link span { color: var(--vnw-gray); font-size: 14px; }

/* ── Messages ────────────────────────────────────── */
#velonw-messages { margin-bottom: 16px; }
