/* ── Granny's Two-Step Verification v2.0.0 ── */

.granny-2sv-wrap { display:flex; justify-content:center; padding:40px 16px; }

.granny-2sv-box {
    background:#FFFAF5; border:1px solid #E8E0D8; border-radius:12px;
    padding:40px 36px; max-width:480px; width:100%; text-align:center;
    box-shadow:0 4px 24px rgba(0,0,0,.07);
}

.granny-2sv-icon { font-size:48px; line-height:1; margin-bottom:16px; }
.granny-2sv-heading { color:#1F2933; font-size:22px; margin:0 0 12px; font-family:Georgia,serif; }
.granny-2sv-sub { color:#52606D; font-size:15px; line-height:1.65; margin:0 0 24px; }

/* 6-digit inputs */
.granny-2sv-code-row { display:flex; justify-content:center; gap:10px; margin:0 0 8px; }
.granny-2sv-digit {
    width:52px; height:64px; border:2px solid #E8E0D8; border-radius:8px;
    text-align:center; font-size:28px; font-weight:700; color:#1F2933;
    background:#fff; outline:none; transition:border-color .18s, box-shadow .18s;
    -moz-appearance:textfield;
}
.granny-2sv-digit::-webkit-inner-spin-button,
.granny-2sv-digit::-webkit-outer-spin-button { -webkit-appearance:none; }
.granny-2sv-digit:focus { border-color:#FDB439; box-shadow:0 0 0 3px rgba(253,180,57,.25); }
.granny-2sv-digit.filled { border-color:#8B5A2B; background:#FFFAF5; }

/* Error / success */
.granny-2sv-error {
    background:#f8d7da; color:#721c24; border:1px solid #f5c6cb;
    border-radius:6px; padding:10px 14px; font-size:13px; margin-bottom:14px;
}
.granny-2sv-field-error { display:block; color:#721c24; font-size:12px; margin:6px 0 14px; min-height:16px; }
.granny-2sv-success-msg {
    background:#d4edda; color:#155724; border:1px solid #c3e6cb;
    border-radius:6px; padding:10px 14px; font-size:14px; margin-bottom:14px;
}

/* Button */
.granny-2sv-btn {
    display:inline-block; width:100%; background:#FDB439; color:#1F2933;
    border:none; border-radius:7px; padding:14px 0; font-size:16px;
    font-weight:700; cursor:pointer; margin-top:16px;
    transition:background .18s, color .18s; font-family:Georgia,serif;
    text-decoration:none; box-sizing:border-box;
}
.granny-2sv-btn:hover { background:#E47B02; color:#fff; }
.granny-2sv-btn:disabled { opacity:.6; cursor:not-allowed; }

/* Links */
.granny-2sv-resend-line { margin-top:18px; font-size:14px; color:#52606D; }
.granny-2sv-link { color:#E47B02; font-weight:600; text-decoration:none; }
.granny-2sv-link:hover { text-decoration:underline; }

/* Banner */
.granny-2sv-banner { width:100%; border-radius:8px; margin:0 0 24px; padding:14px 18px; box-sizing:border-box; }
.granny-2sv-banner--soft { background:#fff8e1; border:1px solid #FDB439; }
.granny-2sv-banner-inner { display:flex; align-items:center; gap:12px; }
.granny-2sv-banner-icon { font-size:22px; flex-shrink:0; }
.granny-2sv-banner-body { flex:1; font-size:14px; color:#3E4C59; line-height:1.5; }
.granny-2sv-banner-link { color:#E47B02; font-weight:600; text-decoration:none; }
.granny-2sv-banner-link:hover { text-decoration:underline; }
.granny-2sv-banner-dismiss { background:none; border:none; color:#7B8794; font-size:18px; cursor:pointer; padding:0 4px; flex-shrink:0; line-height:1; }
.granny-2sv-banner-dismiss:hover { color:#1F2933; }

@media(max-width:480px){
    .granny-2sv-box { padding:28px 18px; }
    .granny-2sv-digit { width:42px; height:54px; font-size:24px; }
    .granny-2sv-code-row { gap:6px; }
    .granny-2sv-banner-inner { flex-wrap:wrap; }
}
