/* =====================================================
   DOKAN VENDOR REGISTER — register.css
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&family=Noto+Kufi+Arabic:wght@300;400;600&display=swap');

:root {
    --dvr-bg:           #f4f6f9;
    --dvr-surface:      #ffffff;
    --dvr-border:       #e0e4ec;
    --dvr-text:         #18191e;
    --dvr-text-muted:   #6b7280;
    --dvr-accent:       #3b5bdb;
    --dvr-accent-dark:  #2f4ac0;
    --dvr-accent-light: #eef2ff;
    --dvr-input-bg:     #f8f9fc;
    --dvr-shadow:       0 8px 48px rgba(0,0,0,.10);
    --dvr-shadow-sm:    0 2px 12px rgba(0,0,0,.06);
    --dvr-radius:       18px;
    --dvr-radius-sm:    10px;
    --dvr-font-en:      'DM Sans', sans-serif;
    --dvr-font-ar:      'Noto Kufi Arabic', sans-serif;
    --dvr-font-head:    'DM Serif Display', serif;
    --dvr-transition:   0.22s cubic-bezier(.4,0,.2,1);
    --dvr-success:      #16a34a;
    --dvr-deco1:        #c7d7fc;
    --dvr-deco2:        #fde6c7;
    --dvr-step-done:    #16a34a;
}
[data-theme="dark"] {
    --dvr-bg:           #0f1117;
    --dvr-surface:      #181b24;
    --dvr-border:       #272b38;
    --dvr-text:         #e8eaf0;
    --dvr-text-muted:   #7a8099;
    --dvr-accent:       #5b7cfa;
    --dvr-accent-dark:  #4a69e0;
    --dvr-accent-light: #1a2040;
    --dvr-input-bg:     #1e2230;
    --dvr-shadow:       0 8px 48px rgba(0,0,0,.45);
    --dvr-shadow-sm:    0 2px 12px rgba(0,0,0,.30);
    --dvr-deco1:        #1c2650;
    --dvr-deco2:        #302010;
}

[data-lang="ar"] { font-family: var(--dvr-font-ar); }
[data-lang="en"] { font-family: var(--dvr-font-en); }

.dvr-wrap *, .dvr-wrap *::before, .dvr-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }

.dvr-wrap {
    position: relative;
    min-height: 100vh;
    background-color: var(--dvr-bg);
    display: flex; flex-direction: column; align-items: center;
    padding: 24px 16px 60px;
    overflow: hidden;
    transition: background-color var(--dvr-transition);
    color: var(--dvr-text);
}

/* Decorative */
.dvr-deco { position: absolute; border-radius: 50%; filter: blur(90px); pointer-events: none; z-index: 0; transition: background var(--dvr-transition); }
.dvr-deco--1 { width: 480px; height: 480px; top: -140px; right: -120px; background: var(--dvr-deco1); opacity: .5; }
.dvr-deco--2 { width: 340px; height: 340px; bottom: -100px; left: -80px; background: var(--dvr-deco2); opacity: .45; }

/* Top Bar */
.dvr-topbar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 24px;
    background: var(--dvr-surface);
    border-bottom: 1px solid var(--dvr-border);
    box-shadow: var(--dvr-shadow-sm);
    transition: background var(--dvr-transition), border-color var(--dvr-transition);
}
.dvr-topbar__brand img, .dvr-topbar__brand .custom-logo { height: 36px; width: auto; }
.dvr-site-name { font-family: var(--dvr-font-head); font-size: 20px; color: var(--dvr-accent); }
.dvr-topbar__controls { display: flex; align-items: center; gap: 10px; }

.dvr-lang-btn {
    display: flex; align-items: center; gap: 4px;
    background: var(--dvr-accent-light); color: var(--dvr-accent);
    border: 1.5px solid var(--dvr-accent); border-radius: 20px;
    padding: 5px 14px; font-size: 13px; font-weight: 600;
    cursor: pointer; transition: all var(--dvr-transition);
}
.dvr-lang-btn:hover { background: var(--dvr-accent); color: #fff; }
.dvr-lang-btn__sep { opacity: .4; }
[data-lang="ar"] .dvr-lang-btn__label.en,
[data-lang="en"] .dvr-lang-btn__label.ar { opacity: .45; }
[data-lang="ar"] .dvr-lang-btn__label.ar,
[data-lang="en"] .dvr-lang-btn__label.en { opacity: 1; font-weight: 700; }

.dvr-theme-btn {
    background: transparent; border: 1.5px solid var(--dvr-border);
    border-radius: 50%; width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; font-size: 17px;
    transition: border-color var(--dvr-transition), background var(--dvr-transition);
}
.dvr-theme-btn:hover { background: var(--dvr-accent-light); border-color: var(--dvr-accent); }
[data-theme="light"] .dvr-theme-btn .dark-icon { display: none; }
[data-theme="dark"] .dvr-theme-btn .light-icon { display: none; }

/* Language spans */
[data-lang="en"] [lang="ar"] { display: none !important; }
[data-lang="ar"] [lang="en"] { display: none !important; }

/* Card */
.dvr-card {
    position: relative; z-index: 1;
    margin-top: 76px;
    width: 100%; max-width: 520px;
    background: var(--dvr-surface);
    border: 1px solid var(--dvr-border);
    border-radius: var(--dvr-radius);
    box-shadow: var(--dvr-shadow);
    padding: 36px 36px 28px;
    transition: background var(--dvr-transition), border-color var(--dvr-transition);
    animation: dvr-fade-up .5s cubic-bezier(.4,0,.2,1) both;
}
@keyframes dvr-fade-up { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }

/* ── Stepper ── */
.dvr-stepper {
    display: flex; align-items: center;
    justify-content: center; gap: 0;
    margin-bottom: 32px;
}
.dvr-step {
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    flex: 0 0 auto;
}
.dvr-step__circle {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 2px solid var(--dvr-border);
    background: var(--dvr-input-bg);
    display: flex; align-items: center; justify-content: center;
    transition: all var(--dvr-transition);
    color: var(--dvr-text-muted);
    position: relative; z-index: 1;
}
.dvr-step__num { font-size: 14px; font-weight: 600; }
.dvr-step__check { display: none; }

.dvr-step--active .dvr-step__circle {
    border-color: var(--dvr-accent);
    background: var(--dvr-accent);
    color: #fff;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--dvr-accent) 20%, transparent);
}
.dvr-step--done .dvr-step__circle {
    border-color: var(--dvr-step-done);
    background: var(--dvr-step-done);
    color: #fff;
}
.dvr-step--done .dvr-step__num { display: none; }
.dvr-step--done .dvr-step__check { display: block; }

.dvr-step__label {
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .07em;
    color: var(--dvr-text-muted); white-space: nowrap;
    transition: color var(--dvr-transition);
}
[data-lang="ar"] .dvr-step__label { text-transform: none; letter-spacing: 0; font-size: 12px; }
.dvr-step--active .dvr-step__label,
.dvr-step--done .dvr-step__label { color: var(--dvr-accent); }
.dvr-step--done .dvr-step__label { color: var(--dvr-step-done); }

.dvr-step__line {
    flex: 1; height: 2px; background: var(--dvr-border);
    margin: 0 8px; margin-bottom: 24px;
    transition: background var(--dvr-transition);
    min-width: 28px;
}
.dvr-step__line--done { background: var(--dvr-step-done); }

/* Message */
.dvr-message {
    border-radius: var(--dvr-radius-sm); padding: 12px 16px;
    font-size: 14px; margin-bottom: 18px;
    display: flex; align-items: flex-start; gap: 8px;
    transition: all var(--dvr-transition);
}
.dvr-message--error { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.dvr-message--success { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }
[data-theme="dark"] .dvr-message--error { background: #2d1515; color: #f87171; border-color: #5a2020; }
[data-theme="dark"] .dvr-message--success { background: #152d1a; color: #4ade80; border-color: #205a28; }

/* Pane */
.dvr-pane { display: flex; flex-direction: column; gap: 16px; animation: dvr-fade-up .3s ease both; }
[hidden]{
    display: none !important;
}
.dvr-pane__title { font-family: var(--dvr-font-head); font-size: 26px; color: var(--dvr-text); font-weight: 400; }
[data-lang="ar"] .dvr-pane__title { font-family: var(--dvr-font-ar); font-size: 22px; }
.dvr-pane__sub { font-size: 14px; color: var(--dvr-text-muted); margin-top: -8px; }

/* Grid */
.dvr-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 480px) { .dvr-form-grid { grid-template-columns: 1fr; } }

/* Fields */
.dvr-field { display: flex; flex-direction: column; gap: 6px; }
.dvr-label {
    font-size: 12px; font-weight: 600; color: var(--dvr-text-muted);
    text-transform: uppercase; letter-spacing: .06em;
}
[data-lang="ar"] .dvr-label { text-transform: none; letter-spacing: 0; font-size: 13px; }

.dvr-input-wrap { position: relative; display: flex; align-items: center; }
.dvr-input-icon {
    position: absolute; left: 12px;
    color: var(--dvr-text-muted); display: flex; align-items: center;
    pointer-events: none; transition: color var(--dvr-transition);
}
[dir="rtl"] .dvr-input-icon { left: auto; right: 12px; }

.dvr-input {
    width: 100%; background: var(--dvr-input-bg);
    border: 1.5px solid var(--dvr-border); border-radius: var(--dvr-radius-sm);
    padding: 11px 40px; font-size: 14px; color: var(--dvr-text); font-family: inherit;
    outline: none; transition: border-color var(--dvr-transition), box-shadow var(--dvr-transition), background var(--dvr-transition);
}
.dvr-input::placeholder { color: var(--dvr-text-muted); opacity: .65; }
.dvr-input:focus {
    border-color: var(--dvr-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--dvr-accent) 15%, transparent);
    background: var(--dvr-surface);
}
.dvr-input:focus-within + .dvr-input-icon { color: var(--dvr-accent); }
.dvr-input.dvr-error { border-color: #dc2626; }

.dvr-textarea {
    resize: vertical; min-height: 80px;
    padding: 11px 14px;
}

/* Slug input */
.dvr-slug-wrap { flex-wrap: wrap; }
.dvr-slug-prefix {
    font-size: 12px; color: var(--dvr-text-muted); background: var(--dvr-input-bg);
    border: 1.5px solid var(--dvr-border); border-right: none; border-radius: var(--dvr-radius-sm) 0 0 var(--dvr-radius-sm);
    padding: 11px 10px; white-space: nowrap;
}
.dvr-input--slug { border-radius: 0 var(--dvr-radius-sm) var(--dvr-radius-sm) 0; padding-left: 10px; }

/* Toggle pw */
.dvr-toggle-pw {
    position: absolute; right: 10px;
    background: none; border: none; cursor: pointer; padding: 4px;
    color: var(--dvr-text-muted); display: flex; align-items: center;
    transition: color var(--dvr-transition);
}
[dir="rtl"] .dvr-toggle-pw { right: auto; left: 10px; }
.dvr-toggle-pw:hover { color: var(--dvr-accent); }

/* Strength meter */
.dvr-strength { display: flex; align-items: center; gap: 8px; margin-top: 4px; }
.dvr-strength__bar { flex: 1; height: 4px; background: var(--dvr-border); border-radius: 2px; overflow: hidden; }
.dvr-strength__fill { display: block; height: 100%; border-radius: 2px; width: 0; transition: width .3s, background .3s; }
.dvr-strength__fill[data-level="1"] { width: 25%; background: #ef4444; }
.dvr-strength__fill[data-level="2"] { width: 50%; background: #f97316; }
.dvr-strength__fill[data-level="3"] { width: 75%; background: #eab308; }
.dvr-strength__fill[data-level="4"] { width: 100%; background: #16a34a; }
.dvr-strength__label { font-size: 11px; color: var(--dvr-text-muted); white-space: nowrap; }

/* Error msg */
.dvr-error-msg { font-size: 12px; color: #dc2626; min-height: 16px; }

/* Checkbox */
.dvr-checkbox-label {
    display: flex; align-items: flex-start; gap: 10px;
    font-size: 14px; cursor: pointer; color: var(--dvr-text-muted); user-select: none;
}
.dvr-checkbox-label input[type="checkbox"] { display: none; }
.dvr-checkbox-custom {
    width: 18px; height: 18px; border: 1.5px solid var(--dvr-border);
    border-radius: 4px; background: var(--dvr-input-bg);
    flex-shrink: 0; margin-top: 2px;
    display: flex; align-items: center; justify-content: center;
    transition: all var(--dvr-transition);
}
.dvr-checkbox-label input:checked ~ .dvr-checkbox-custom { background: var(--dvr-accent); border-color: var(--dvr-accent); }
.dvr-checkbox-label input:checked ~ .dvr-checkbox-custom::after {
    content: ''; display: block; width: 5px; height: 9px;
    border: 2px solid #fff; border-top: none; border-left: none;
    transform: rotate(45deg) translate(-1px, -1px);
}
.dvr-checkbox-label a { color: var(--dvr-accent); text-decoration: none; }
.dvr-checkbox-label a:hover { text-decoration: underline; }

/* Buttons */
.dvr-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 12px 22px; border-radius: var(--dvr-radius-sm);
    font-size: 15px; font-weight: 600; font-family: inherit;
    cursor: pointer; text-decoration: none;
    transition: all var(--dvr-transition); border: none; white-space: nowrap;
}
.dvr-btn--primary {
    background: var(--dvr-accent); color: #fff;
    box-shadow: 0 4px 16px color-mix(in srgb, var(--dvr-accent) 35%, transparent);
}
.dvr-btn--primary:hover { background: var(--dvr-accent-dark); }
.dvr-btn--primary:active { transform: scale(.985); }
.dvr-btn--primary:disabled { opacity: .65; cursor: not-allowed; transform: none; }
.dvr-btn--ghost {
    background: transparent; color: var(--dvr-text-muted);
    border: 1.5px solid var(--dvr-border);
}
.dvr-btn--ghost:hover { border-color: var(--dvr-accent); color: var(--dvr-accent); background: var(--dvr-accent-light); }
.dvr-btn--next { width: 100%; justify-content: center; margin-top: 4px; }

.dvr-btn-row { display: flex; gap: 12px; justify-content: space-between; align-items: center; margin-top: 4px; }
.dvr-btn-row .dvr-btn--primary { flex: 1; }

.dvr-spin { animation: dvr-spin .8s linear infinite; }
@keyframes dvr-spin { from { transform: rotate(0); } to { transform: rotate(360deg); } }

/* Login link */
.dvr-login-link { text-align: center; font-size: 14px; color: var(--dvr-text-muted); margin-top: 20px; }
.dvr-login-link a { color: var(--dvr-accent); font-weight: 600; text-decoration: none; }
.dvr-login-link a:hover { text-decoration: underline; }

/* ── Success Pane ── */
.dvr-pane--success { align-items: center; text-align: center; padding: 24px 0 12px; gap: 20px; }
.dvr-success-icon {
    width: 80px; height: 80px;
    color: var(--dvr-step-done);
}
.dvr-success-ring { stroke-dasharray: 240; stroke-dashoffset: 240; animation: dvr-ring .6s ease forwards .2s; }
.dvr-success-check { stroke-dasharray: 60; stroke-dashoffset: 60; animation: dvr-check .4s ease forwards .7s; }
@keyframes dvr-ring { to { stroke-dashoffset: 0; } }
@keyframes dvr-check { to { stroke-dashoffset: 0; } }
.dvr-success__title { font-size: 28px; }
.dvr-success__sub { max-width: 340px; line-height: 1.6; }
.dvr-success-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

@media (max-width: 500px) {
    .dvr-card { padding: 24px 16px 20px; }
    .dvr-topbar { padding: 10px 16px; }
    .dvr-btn-row { flex-direction: column; }
    .dvr-btn-row .dvr-btn { width: 100%; }
}
