/* ── Discord Join System ─────────────────────────────────────────── */

:root {
    --djs-bg:         #0d1117;
    --djs-card:       #161b22;
    --djs-border:     #30363d;
    --djs-text:       #e6edf3;
    --djs-muted:      #8b949e;
    --djs-accent:     #5865f2;   /* Discord blurple */
    --djs-accent-h:   #4752c4;
    --djs-success:    #3fb950;
    --djs-error:      #f85149;
    --djs-gold:       #d29922;
    --djs-radius:     12px;
    --djs-radius-sm:  6px;
    --djs-shadow:     0 8px 32px rgba(0,0,0,.4);
    --djs-transition: .2s ease;
}

/* Wrap */
.djs-wrap {
    min-height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: var(--djs-bg);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Card */
.djs-card {
    width: 100%;
    max-width: 480px;
    background: var(--djs-card);
    border: 1px solid var(--djs-border);
    border-radius: var(--djs-radius);
    box-shadow: var(--djs-shadow);
    padding: 2.5rem 2rem;
    color: var(--djs-text);
}

/* Header */
.djs-header { text-align: center; margin-bottom: 2rem; }
.djs-org-logo { max-height: 64px; margin-bottom: 1rem; }
.djs-title { font-size: 1.6rem; font-weight: 700; margin: 0 0 .5rem; }
.djs-subtitle { color: var(--djs-muted); font-size: .9rem; margin: 0; }

/* Steps */
.djs-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    margin-bottom: 2rem;
}
.djs-step {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .8rem;
    color: var(--djs-muted);
    transition: color var(--djs-transition);
}
.djs-step.active { color: var(--djs-accent); font-weight: 600; }
.djs-step.done   { color: var(--djs-success); }
.djs-step-num {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--djs-border);
    display: grid; place-items: center;
    font-size: .75rem; font-weight: 700;
}
.djs-step.active .djs-step-num { background: var(--djs-accent); color: #fff; }
.djs-step.done   .djs-step-num { background: var(--djs-success); color: #fff; }
.djs-step-divider { flex: 1; height: 1px; background: var(--djs-border); max-width: 40px; }

/* Label */
.djs-label {
    display: block;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: .5rem;
    color: var(--djs-text);
}

/* Input group */
.djs-input-group {
    display: flex;
    align-items: center;
    border: 1px solid var(--djs-border);
    border-radius: var(--djs-radius-sm);
    overflow: hidden;
    transition: border-color var(--djs-transition);
}
.djs-input-group:focus-within { border-color: var(--djs-accent); }
.djs-input-prefix {
    background: rgba(255,255,255,.04);
    padding: .65rem .75rem;
    color: var(--djs-muted);
    font-size: .8rem;
    white-space: nowrap;
    border-right: 1px solid var(--djs-border);
}
.djs-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    padding: .65rem .75rem;
    color: var(--djs-text);
    font-size: .95rem;
}
.djs-input::placeholder { color: var(--djs-muted); }

/* Feedback */
.djs-feedback {
    min-height: 1.4em;
    font-size: .83rem;
    margin: .5rem 0;
    transition: color var(--djs-transition);
}
.djs-feedback.djs-ok  { color: var(--djs-success); }
.djs-feedback.djs-err { color: var(--djs-error); }
.djs-checking { color: var(--djs-muted); }

/* Org preview */
.djs-org-preview {
    display: flex;
    align-items: center;
    gap: .75rem;
    background: rgba(63,185,80,.07);
    border: 1px solid rgba(63,185,80,.25);
    border-radius: var(--djs-radius-sm);
    padding: .6rem .9rem;
    margin: .5rem 0 1rem;
}
.djs-org-preview img {
    width: 40px; height: 40px;
    border-radius: 4px;
    object-fit: contain;
    background: rgba(255,255,255,.05);
}
.djs-org-info { flex: 1; line-height: 1.3; }
.djs-org-info strong { font-size: .9rem; display: block; }
.djs-org-sid { font-size: .75rem; color: var(--djs-muted); }
.djs-verified-badge {
    font-size: .78rem;
    color: var(--djs-success);
    font-weight: 600;
}

/* Buttons */
.djs-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    width: 100%;
    padding: .8rem 1.2rem;
    border: none;
    border-radius: var(--djs-radius-sm);
    font-size: .95rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--djs-transition), transform .1s;
    text-decoration: none;
    box-sizing: border-box;
    margin-top: .75rem;
}
.djs-btn:active { transform: scale(.98); }
.djs-btn:disabled {
    opacity: .4;
    cursor: not-allowed;
    transform: none;
}
.djs-btn-discord {
    background: var(--djs-accent);
    color: #fff;
}
.djs-btn-discord:hover:not(:disabled) { background: var(--djs-accent-h); }
.djs-btn-primary  { background: var(--djs-accent); color: #fff; }
.djs-btn-primary:hover  { background: var(--djs-accent-h); }
.djs-btn-secondary {
    background: transparent;
    border: 1px solid var(--djs-border);
    color: var(--djs-text);
}
.djs-btn-secondary:hover { background: rgba(255,255,255,.05); }

/* Discord icon */
.djs-discord-icon { width: 20px; height: 20px; flex-shrink: 0; }

/* Terms */
.djs-terms {
    font-size: .75rem;
    color: var(--djs-muted);
    text-align: center;
    margin-top: .75rem;
    line-height: 1.5;
}

/* Spinner */
.djs-spinner {
    width: 40px; height: 40px;
    border: 3px solid var(--djs-border);
    border-top-color: var(--djs-accent);
    border-radius: 50%;
    animation: djs-spin .8s linear infinite;
    margin: 1.5rem auto;
}
@keyframes djs-spin { to { transform: rotate(360deg); } }

/* ── Success page ────────────────────────────────────────────────── */

.djs-card-success { text-align: center; }

.djs-success-hero {
    position: relative;
    display: inline-block;
    margin-bottom: 1.5rem;
}
.djs-avatar-large {
    width: 96px; height: 96px;
    border-radius: 50%;
    border: 3px solid var(--djs-accent);
    object-fit: cover;
    display: block;
}
.djs-success-check {
    position: absolute;
    bottom: -4px; right: -4px;
    background: var(--djs-success);
    color: #fff;
    width: 28px; height: 28px;
    border-radius: 50%;
    display: grid; place-items: center;
    font-size: .85rem;
    font-weight: 700;
    border: 2px solid var(--djs-card);
}

.djs-summary {
    background: rgba(255,255,255,.04);
    border: 1px solid var(--djs-border);
    border-radius: var(--djs-radius-sm);
    padding: 1rem;
    margin: 1.5rem 0;
    text-align: left;
}
.djs-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .4rem 0;
    font-size: .875rem;
    border-bottom: 1px solid var(--djs-border);
}
.djs-summary-row:last-child { border-bottom: none; }
.djs-summary-label { color: var(--djs-muted); }
.djs-summary-value { font-weight: 600; }
.djs-summary-value a { color: var(--djs-accent); text-decoration: none; }
.djs-summary-value a:hover { text-decoration: underline; }

.djs-actions {
    display: flex;
    flex-direction: column;
    gap: .6rem;
}

/* ── Status messages ────────────────────────────────────────────── */

.djs-status {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 2rem;
    border-radius: var(--djs-radius);
    text-align: center;
    font-size: .95rem;
}
.djs-success { background: rgba(63,185,80,.1);  border: 1px solid rgba(63,185,80,.3); color: var(--djs-success); }
.djs-error   { background: rgba(248,81,73,.1);  border: 1px solid rgba(248,81,73,.3); color: var(--djs-error);   }
.djs-icon    { font-size: 2rem; }

/* ── Responsive ──────────────────────────────────────────────────── */

@media (max-width: 520px) {
    .djs-card { padding: 1.5rem 1rem; }
    .djs-step span:not(.djs-step-num) { display: none; }
}

/* ── Multi-step panel layout ──────────────────────────────────────── */

.djs-panel { display: none; }
.djs-panel.active { display: block; }

.djs-panel-header { text-align: center; margin-bottom: 1.5rem; }
.djs-panel-icon   { font-size: 2.2rem; margin-bottom: .5rem; }
.djs-panel-header h2 { font-size: 1.25rem; margin: 0 0 .4rem; }
.djs-panel-header p  { color: var(--djs-muted); font-size: .875rem; margin: 0; }
.djs-panel-header code { background: rgba(255,255,255,.07); padding: 1px 5px; border-radius: 4px; }

/* Alerts */
.djs-alert {
    border-radius: var(--djs-radius-sm);
    padding: .85rem 1rem;
    font-size: .875rem;
    line-height: 1.5;
    margin-bottom: 1rem;
}
.djs-alert-info    { background: rgba(88,101,242,.12); border: 1px solid rgba(88,101,242,.3); color: #a5adfc; }
.djs-alert-error   { background: rgba(248,81,73,.1);  border: 1px solid rgba(248,81,73,.3);  color: #f85149; }
.djs-alert-success { background: rgba(63,185,80,.1);  border: 1px solid rgba(63,185,80,.3);  color: #3fb950; }

.djs-link { color: var(--djs-accent); text-decoration: none; }
.djs-link:hover { text-decoration: underline; }

/* Checking spinner inline */
.djs-checking-msg {
    display: flex;
    align-items: center;
    gap: .6rem;
    color: var(--djs-muted);
    font-size: .875rem;
    padding: .5rem 0;
}
.djs-spinner-sm {
    width: 16px; height: 16px;
    border: 2px solid var(--djs-border);
    border-top-color: var(--djs-accent);
    border-radius: 50%;
    animation: djs-spin .8s linear infinite;
    flex-shrink: 0;
}

/* Ghost / back button */
.djs-btn-ghost {
    background: transparent;
    border: none;
    color: var(--djs-muted);
    font-size: .85rem;
    padding: .4rem 0;
    cursor: pointer;
    width: 100%;
    text-align: center;
    margin-top: .25rem;
}
.djs-btn-ghost:hover { color: var(--djs-text); }

/* Rules box */
.djs-rules-box {
    background: rgba(255,255,255,.03);
    border: 1px solid var(--djs-border);
    border-radius: var(--djs-radius-sm);
    padding: 1rem 1.25rem;
    max-height: 280px;
    overflow-y: auto;
    font-size: .82rem;
    line-height: 1.6;
    color: var(--djs-text);
    margin-bottom: 1rem;
    scroll-behavior: smooth;
}
.djs-rules-box h3 { font-size: 1rem; margin: 0 0 .75rem; color: var(--djs-text); }
.djs-rules-box h4 { font-size: .85rem; margin: 1rem 0 .35rem; color: var(--djs-accent); }
.djs-rules-box ul { padding-left: 1.2rem; margin: 0 0 .5rem; }
.djs-rules-box li { margin-bottom: .2rem; }
.djs-rules-box p  { margin: .4rem 0; }

/* Checkbox */
.djs-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: .6rem;
    font-size: .85rem;
    color: var(--djs-text);
    cursor: pointer;
    line-height: 1.4;
}
.djs-checkbox-label input[type=checkbox] {
    margin-top: 2px;
    accent-color: var(--djs-accent);
    flex-shrink: 0;
}

/* Verification code */
.djs-vcode-box {
    background: rgba(255,255,255,.04);
    border: 1px solid var(--djs-border);
    border-radius: var(--djs-radius-sm);
    padding: 1rem;
    margin-bottom: 1rem;
    text-align: center;
}
.djs-vcode-label {
    font-size: .8rem;
    color: var(--djs-muted);
    margin: 0 0 .4rem;
}
.djs-vcode {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
}
.djs-vcode span {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: .15em;
    font-family: monospace;
    color: var(--djs-gold);
}
.djs-copy-btn {
    background: transparent;
    border: 1px solid var(--djs-border);
    border-radius: 4px;
    padding: .25rem .5rem;
    cursor: pointer;
    font-size: 1rem;
    color: var(--djs-muted);
    transition: border-color .2s;
}
.djs-copy-btn:hover { border-color: var(--djs-accent); }

/* Instructions list */
.djs-instructions {
    font-size: .85rem;
    color: var(--djs-text);
    line-height: 1.6;
    margin-bottom: 1rem;
}
.djs-instructions ol { padding-left: 1.2rem; margin: .5rem 0; }
.djs-instructions li { margin-bottom: .3rem; }
.djs-instructions a  { color: var(--djs-accent); }
.djs-note {
    font-size: .78rem;
    color: var(--djs-muted);
    margin-top: .5rem;
    font-style: italic;
}
