/* ─── register.css ────────────────────────────────────────────────────────── */

/* ── Layout tweak: wider right box for multi-step forms ────────────────────── */
.reg-box { max-width: 520px; }

/* ── Back button ───────────────────────────────────────────────────────────── */
.reg-back {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 13px; font-weight: 600; color: var(--muted);
    background: none; border: none; cursor: pointer; font-family: inherit;
    padding: 0; margin-bottom: 20px;
    transition: color var(--t);
}
.reg-back:hover { color: var(--teal); }
[dir="rtl"] .reg-back .back-arrow { transform: scaleX(-1); }

/* ── Role cards grid ───────────────────────────────────────────────────────── */
.reg-role-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 20px;
}
@media (max-width: 480px) { .reg-role-grid { grid-template-columns: 1fr; } }

.reg-role-card {
    display: flex; flex-direction: column; align-items: flex-start;
    gap: 8px; padding: 20px 18px;
    background: var(--bg); border: 1.5px solid var(--border); border-radius: 16px;
    text-align: start; cursor: pointer; font-family: inherit;
    transition: border-color var(--t) var(--ease),
                box-shadow var(--t) var(--ease), transform var(--t) var(--ease);
}
.reg-role-card:hover {
    border-color: var(--teal);
    box-shadow: 0 6px 24px rgba(46,124,133,.14);
    transform: translateY(-2px);
}
.reg-role-card strong { font-size: 15px; font-weight: 700; color: var(--text); }
.reg-role-card span   { font-size: 12px; color: var(--muted); line-height: 1.5; }

.reg-role-icon {
    width: 48px; height: 48px; border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 4px;
}
.reg-role-icon--client  { background: rgba(46,124,133,.10); color: var(--teal); }
.reg-role-icon--provider { background: rgba(217,112,61,.12); color: var(--orange); }

.reg-role-cta {
    display: inline-flex; align-items: center;
    padding: 7px 14px; border-radius: var(--r);
    font-size: 12px; font-weight: 700;
    margin-top: 4px;
    background: var(--teal); color: #fff;
}
.reg-role-cta--provider { background: var(--orange); }

/* ── Step indicators ───────────────────────────────────────────────────────── */
.reg-steps {
    display: flex; align-items: center;
    margin: 4px 0 24px;
}
.reg-step {
    display: flex; align-items: center; gap: 8px; flex-shrink: 0;
}
.reg-step-num {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--border); color: var(--muted);
    font-size: 12px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    transition: background var(--t), color var(--t);
}
.reg-step-label { font-size: 12px; font-weight: 600; color: var(--muted); transition: color var(--t); }
.reg-step--active .reg-step-num   { background: var(--teal); color: #fff; }
.reg-step--active .reg-step-label { color: var(--teal); }
.reg-step--done .reg-step-num     { background: var(--teal); color: #fff; }
.reg-step--done .reg-step-label   { color: var(--teal); }
.reg-step-line {
    flex: 1; height: 2px; background: var(--border);
    margin: 0 8px; transition: background var(--t);
}
.reg-step-line.is-done { background: var(--teal); }

/* ── Step panel animation ──────────────────────────────────────────────────── */
#pS1, #pS2, #pS3, #pSuccess { animation: regPanelIn .2s ease; }
@keyframes regPanelIn { from { opacity: 0; transform: translateX(8px); } to { opacity: 1; transform: none; } }

/* ── Step nav (back + next row) ────────────────────────────────────────────── */
.reg-step-nav {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin-top: 4px;
}
.btn-back {
    display: inline-flex; align-items: center; gap: 8px;
    background: none; border: 1.5px solid var(--border); border-radius: var(--r);
    padding: 12px 20px; font-size: 14px; font-weight: 600;
    color: var(--text); font-family: inherit; cursor: pointer;
    transition: border-color var(--t), color var(--t);
    flex-shrink: 0;
}
.btn-back:hover { border-color: var(--teal); color: var(--teal); }
.btn-step-next  { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; }

[dir="rtl"] .next-arrow { transform: scaleX(-1); }
[dir="rtl"] .back-arrow { transform: scaleX(-1); }

/* ── Radio cards (provider type) ───────────────────────────────────────────── */
.radio-group { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.radio-card  { position: relative; display: block; }
.radio-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.radio-card-inner {
    display: flex; align-items: center; gap: 10px;
    border: 1.5px solid var(--border); border-radius: var(--r);
    padding: 14px 16px; cursor: pointer;
    font-size: 14px; font-weight: 500; color: var(--text);
    transition: border-color var(--t), background var(--t), color var(--t);
}
.radio-card input:checked + .radio-card-inner {
    border-color: var(--teal); background: rgba(46,124,133,.06); color: var(--teal);
}
.radio-card-inner:hover { border-color: var(--teal); }
.radio-card input:focus-visible + .radio-card-inner { outline: 2px solid var(--teal); outline-offset: 2px; }
@media (max-width: 400px) { .radio-group { grid-template-columns: 1fr; } }

/* ── Select ────────────────────────────────────────────────────────────────── */
.form-field select {
    width: 100%; padding: 12px 40px 12px 16px;
    border: 1.5px solid var(--border); border-radius: var(--r);
    font-size: 14px; font-family: inherit; color: var(--text);
    background: var(--bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
    appearance: none; outline: none; cursor: pointer;
    transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
[dir="rtl"] .form-field select { background-position: left 12px center; padding-right: 16px; padding-left: 40px; }
.form-field select:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(46,124,133,.12); }

/* ── Textarea ──────────────────────────────────────────────────────────────── */
.form-field textarea {
    width: 100%; padding: 12px 16px;
    border: 1.5px solid var(--border); border-radius: var(--r);
    font-size: 14px; font-family: inherit; color: var(--text);
    background: var(--bg); outline: none; resize: vertical; min-height: 80px;
    transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.form-field textarea::placeholder { color: var(--muted); opacity: .7; }
.form-field textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(46,124,133,.12); }

/* ── Checkbox ──────────────────────────────────────────────────────────────── */
.checkbox-label {
    display: flex; align-items: flex-start; gap: 10px;
    cursor: pointer; font-size: 13px; color: var(--muted); line-height: 1.5;
}
.checkbox-label input[type="checkbox"] {
    width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px;
    accent-color: var(--teal); cursor: pointer;
}
.checkbox-label a { color: var(--teal); font-weight: 500; }

/* ── Field helpers ─────────────────────────────────────────────────────────── */
.req { color: #DC2626; font-weight: 600; margin-inline-start: 2px; }
.field-hint { font-size: 12px; color: var(--muted); margin-top: 5px; line-height: 1.4; }

/* ── Two-column row ────────────────────────────────────────────────────────── */
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px) { .form-row-2 { grid-template-columns: 1fr; } }

/* ── Categories grid ───────────────────────────────────────────────────────── */
.categories-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 10px; margin-top: 10px;
}
.cat-chip { position: relative; }
.cat-chip input { position: absolute; opacity: 0; width: 0; height: 0; }
.cat-chip-inner {
    display: flex; align-items: center; gap: 8px;
    border: 1.5px solid var(--border); border-radius: var(--r);
    padding: 10px 12px; cursor: pointer;
    font-size: 13px; font-weight: 500; color: var(--text);
    transition: border-color var(--t), background var(--t), color var(--t);
    line-height: 1.3;
}
.cat-chip input:checked + .cat-chip-inner {
    border-color: var(--teal); background: rgba(46,124,133,.07); color: var(--teal);
}
.cat-chip-inner:hover { border-color: var(--teal); }
.cat-chip input:focus-visible + .cat-chip-inner { outline: 2px solid var(--teal); outline-offset: 2px; }
.cat-chip-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── Terms box ─────────────────────────────────────────────────────────────── */
.terms-box {
    text-align: center; background: var(--bg2);
    border: 1px solid var(--border); border-radius: 16px;
    padding: 28px 24px; margin-bottom: 24px;
}
.terms-box-icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: rgba(46,124,133,.10); color: var(--teal);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}
.terms-box h3 { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.terms-box p  { font-size: 13px; color: var(--muted); line-height: 1.6; }

/* ── Success state ─────────────────────────────────────────────────────────── */
.reg-success {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 16px 0 8px;
}
.reg-success-icon {
    width: 72px; height: 72px; border-radius: 50%;
    background: rgba(22,163,74,.10); color: #16A34A;
    display: flex; align-items: center; justify-content: center; margin-bottom: 20px;
}
.reg-success h3 { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 10px; }
.reg-success p  { font-size: 14px; color: var(--muted); line-height: 1.6; max-width: 340px; margin-bottom: 28px; }
.reg-success-btn { text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }

/* ── Google-user profile header ────────────────────────────────────────────── */
.reg-google-user {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 16px; border-radius: 14px;
    background: var(--bg2); border: 1px solid var(--border);
    margin-bottom: 24px;
}
.reg-google-avatar {
    width: 44px; height: 44px; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    background: var(--border);
}
.reg-google-user strong { display: block; font-size: 14px; font-weight: 700; color: var(--text); }
.reg-google-user span   { font-size: 12px; color: var(--muted); }

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .reg-box { max-width: 100%; }
}
@media (max-width: 520px) {
    .categories-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
    .reg-steps .reg-step-label { display: none; }
}
