/* ============================================================
   Kisaan QR — Registration Modal  (additive — append to login.css)
   Primary: #417200 — inherits all :root tokens from login.css
   ============================================================ */

/* ── OVERLAY ──────────────────────────────────────────────── */
.kq-reg-overlay {
    position: fixed; inset: 0; z-index: 900;
    background: rgba(8,20,10,.52);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 16px;
    opacity: 0; pointer-events: none;
    transition: opacity 200ms var(--ease);
}
.kq-reg-overlay.is-open {
    opacity: 1; pointer-events: auto;
}

/* ── MODAL SHELL ──────────────────────────────────────────── */
.kq-reg-modal {
    display: flex;
    width: 100%; max-width: 860px;
    max-height: 94vh;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 28px 72px rgba(0,0,0,.22), 0 4px 14px rgba(0,0,0,.10), 0 0 0 1px rgba(0,0,0,.06);
    transform: scale(.96) translateY(10px);
    transition: transform 240ms cubic-bezier(.22,.68,0,1.15), box-shadow 240ms var(--ease);
}
.kq-reg-overlay.is-open .kq-reg-modal {
    transform: scale(1) translateY(0);
}

/* ═══════════════════════════════════════════════════════════════
   LEFT STEPPER PANEL
   Decorative rings:
     ::before  → grain texture (like login hero)
     ::after   → large ring, bottom-right corner only (retained)
═══════════════════════════════════════════════════════════════ */
.kq-reg-panel {
    width: 248px; flex-shrink: 0;
    background: linear-gradient(170deg, #1e3a00 0%, #152e00 55%, #0c1f00 100%);
    display: flex; flex-direction: column;
    padding: 28px 22px 22px;
    position: relative;  /* REQUIRED — rings are absolute children */
    overflow: hidden;
}

/* Grain texture — matches login hero ::before */
.kq-reg-panel::before {
    content: '';
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 0;
}

/* ── LARGE RING (main arc — bottom-right, partially off-panel) ── */
.kq-reg-panel::after {
    content: '';
    position: absolute;
    bottom: -85px;
    right:  -85px;
    width:  250px;
    height: 250px;
    border-radius: 50%;
    border: 42px solid rgba(255,255,255,.07);
    pointer-events: none;
    z-index: 0;
}



/* Lift all real panel content above the rings */
.kq-reg-brand,
.kq-reg-stepper,
.kq-reg-panel-foot {
    position: relative;
    z-index: 1;
}

.kq-reg-brand { margin-bottom: 30px; }
.kq-reg-brand img { height: 28px; width: auto; display: block; }

.kq-reg-stepper { flex: 1; }

.kq-rs-item {
    display: flex; align-items: flex-start; gap: 13px;
    padding: 11px 0; position: relative;
}
.kq-rs-item:not(:last-child)::after {
    content: '';
    position: absolute; left: 13px; top: 42px; bottom: -11px;
    width: 1.5px;
    background: rgba(255,255,255,.13);
}
.kq-rs-item.is-done:not(:last-child)::after,
.kq-rs-item.is-active:not(:last-child)::after { background: rgba(255,255,255,.30); }

.kq-rs-dot {
    width: 27px; height: 27px; border-radius: 50%;
    border: 1.5px solid rgba(255,255,255,.18);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; font-size: 12px; font-weight: 600;
    color: rgba(255,255,255,.28); background: transparent;
    transition: all .22s var(--ease); position: relative; z-index: 2;
}
.kq-rs-item.is-done   .kq-rs-dot { border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.14); color: #fff; }
.kq-rs-item.is-active .kq-rs-dot { border-color: #fff; background: #fff; color: #1e3a00; box-shadow: 0 0 0 3px rgba(255,255,255,.13); }

.kq-rs-meta { padding-top: 2px; }
.kq-rs-step  { font-size: 10px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: 2px; transition: color .22s; }
.kq-rs-title { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.26); transition: color .22s; }
.kq-rs-sub   { font-size: 11px; color: rgba(255,255,255,.19); margin-top: 2px; line-height: 1.45; transition: color .22s; }

.kq-rs-item.is-active .kq-rs-step,
.kq-rs-item.is-done   .kq-rs-step  { color: rgba(255,255,255,.48); }
.kq-rs-item.is-active .kq-rs-title { color: #fff; }
.kq-rs-item.is-done   .kq-rs-title { color: rgba(255,255,255,.55); }
.kq-rs-item.is-active .kq-rs-sub   { color: rgba(255,255,255,.42); }
.kq-rs-item.is-done   .kq-rs-sub   { color: rgba(255,255,255,.30); }

.kq-reg-panel-foot {
    font-size: 11px; font-weight: 500; color: rgba(255,255,255,.26);
    padding-top: 14px; border-top: 1px solid rgba(255,255,255,.09);
}
.kq-reg-panel-foot a { color: rgba(255,255,255,.50); }
.kq-reg-panel-foot a:hover { color: #fff; }

/* ── RIGHT CONTENT ────────────────────────────────────────── */
.kq-reg-content {
    flex: 1; background: var(--bg-surface);
    display: flex; flex-direction: column; overflow-y: auto;
    position: relative;
}

.kq-reg-close {
    position: absolute; top: 13px; right: 13px; z-index: 20;
    width: 28px; height: 28px; border-radius: 6px;
    border: 1px solid var(--border-default); background: var(--bg-surface);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; color: var(--text-secondary);
    transition: background var(--dur), border-color var(--dur), color var(--dur);
}
.kq-reg-close:hover { background: #fff1f1; border-color: var(--error); color: var(--error); }

.kq-reg-form-wrap { padding: 28px 28px 24px; flex: 1; }

.kq-reg-badge {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
    color: var(--color-primary);
    background: rgba(65,114,0,.08); border-radius: 99px;
    padding: 3px 10px; margin-bottom: 10px;
}
.kq-reg-badge::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--color-primary); }

.kq-reg-title { font-size: 1.2rem; font-weight: 700; color: var(--text-primary); letter-spacing: -.026em; margin-bottom: 3px; }
.kq-reg-sub   { font-size: .85rem; color: var(--text-secondary); margin-bottom: 20px; line-height: 1.55; }

.kq-reg-step { display: none; }
.kq-reg-step.is-active { display: block; animation: kq-fadein .26s var(--ease) both; }

.kq-reg-row        { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.kq-reg-row--full  { grid-template-columns: 1fr; }

.kq-reg-content .kq-field          { gap: 5px; margin-bottom: 0; }
.kq-reg-content .kq-field__label   { font-size: .8rem; }
.kq-reg-content .kq-field__input   { height: 40px; font-size: .875rem; padding: 0 12px 0 38px; }
.kq-reg-content .kq-field__input.no-icon { padding-left: 12px; }
.kq-reg-content select.kq-field__input   { appearance: none; cursor: pointer; padding-right: 30px; }
.kq-reg-content .kq-field__icon    { left: 11px; }
.kq-reg-content .kq-field__error   { font-size: .75rem; min-height: 13px; }

.kq-reg-sel-wrap { position: relative; }
.kq-reg-sel-arr  { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); pointer-events: none; color: #A8BFAF; }

.kq-field__hint { font-size: .74rem; color: #A8BFAF; margin-top: 2px; }

.kq-reg-content .kq-check__label { font-size: .82rem; }
.kq-reg-content .kq-check        { align-items: flex-start; gap: 9px; }
.kq-reg-content .kq-check__box   { margin-top: 2px; }

.kq-reg-actions {
    display: flex; align-items: center; justify-content: space-between;
    padding-top: 14px; margin-top: 6px;
    border-top: 1px solid var(--border-default);
}
.kq-reg-step-count { font-size: .8rem; color: var(--text-secondary); font-weight: 500; }

.kq-reg-btn-back {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--font); font-size: .875rem; font-weight: 600;
    padding: 9px 16px; border-radius: var(--radius-sm);
    background: var(--bg-surface); color: var(--text-primary);
    border: 1.5px solid var(--border-default); cursor: pointer;
    transition: border-color var(--dur), background var(--dur);
}
.kq-reg-btn-back:hover { border-color: #bbb; background: var(--bg-page); }

.kq-reg-btn-next,
.kq-reg-btn-submit {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--font); font-size: .875rem; font-weight: 600;
    padding: 9px 18px; border-radius: var(--radius-sm);
    background: var(--color-primary); color: #fff; border: none; cursor: pointer;
    box-shadow: 0 2px 8px rgba(65,114,0,.22);
    transition: background var(--dur), box-shadow var(--dur), transform var(--dur);
}
.kq-reg-btn-next:hover,
.kq-reg-btn-submit:hover  { background: var(--color-primary-hov); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(65,114,0,.30); }
.kq-reg-btn-next:active,
.kq-reg-btn-submit:active { transform: scale(.98); }
.kq-reg-btn-submit:disabled { opacity: .65; cursor: not-allowed; transform: none; }

.kq-reg-btn-submit .kq-btn-submit__spinner {
    display: none; width: 16px; height: 16px;
    border: 2px solid rgba(255,255,255,.35); border-top-color: #fff;
    border-radius: 50%; animation: kq-spin .7s linear infinite;
}
.kq-reg-btn-submit.is-loading .kq-reg-btn-submit__text { display: none; }
.kq-reg-btn-submit.is-loading .kq-btn-submit__spinner  { display: block; }

.kq-reg-req { color: var(--color-primary); margin-left: 1px; }

@media (max-width: 680px) {
    .kq-reg-panel     { display: none; }
    .kq-reg-modal     { max-width: 480px; }
    .kq-reg-row       { grid-template-columns: 1fr; }
    .kq-reg-form-wrap { padding: 22px 20px 20px; }
}

.kq-reg-type-row.reg-radio-button {
    margin-bottom: 20px !important;
}