/* ============================================================
   Saudi IBAN Lookup — sibl.css  v2.0.0
   KSA Expats | Matches dark-green/gold hero theme
   ============================================================ */

.sibl-wrap {
    --g:      #0a3d1f;
    --gm:     #0d6632;
    --gl:     #1fa854;
    --gp:     #e8f5ee;
    --cream:  #f4fbf6;
    --cdk:    #d8eede;
    --ink:    #081a0e;
    --muted:  #3a6b4a;
    --border: rgba(10,61,31,.14);
    --gold:   #b8810a;
    --goldbg: #fff8e6;
    --goldbd: rgba(184,129,10,.25);
    --red:    #dc2626;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--ink);
    background: var(--cream);
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-top: -50px;
    margin-bottom: -50px;
    box-sizing: border-box;
    overflow-x: hidden;
}

.sibl-wrap *, .sibl-wrap *::before, .sibl-wrap *::after { box-sizing: border-box; }

/* ── Inner container ── */
.sibl-inner {
    max-width: 1060px;
    margin: 0 auto;
    padding: 0 24px 56px;
}

/* ══════════════════════════════════════════════
   HERO
══════════════════════════════════════════════ */
.sibl-hero {
    background: linear-gradient(135deg, #020e06 0%, #061a0b 40%, #0a3520 70%, #0e5530 100%);
    padding: 38px 28px 32px;
    margin-left: calc(50% - 50vw);
    width: 100vw;
    position: relative;
    overflow: hidden;
}

.sibl-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 72% 50%, rgba(31,168,84,.11) 0%, transparent 65%);
    pointer-events: none;
}

.sibl-hero-inner {
    max-width: 1060px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.sibl-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: rgba(31,168,84,.15);
    border: 1px solid rgba(31,168,84,.3);
    color: #1fa854;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    padding: 5px 13px;
    border-radius: 20px;
    margin-bottom: 14px;
}

.sibl-hero-badge-dot {
    width: 7px;
    height: 7px;
    background: #1fa854;
    border-radius: 50%;
}

.sibl-hero-title {
    font-size: clamp(26px, 4vw, 46px) !important;
    font-weight: 800 !important;
    color: #fff !important;
    line-height: 1.15 !important;
    letter-spacing: -0.5px !important;
    margin: 0 0 10px !important;
    padding: 0 !important;
    border: none !important;
    font-family: inherit !important;
}

.sibl-hero-title em { color: #1fa854; font-style: normal; }

.sibl-hero-sub {
    font-size: 13px !important;
    color: rgba(255,255,255,.5) !important;
    line-height: 1.6 !important;
    margin: 0 0 26px !important;
    font-weight: 400 !important;
    max-width: 560px;
}

/* Hero stat cards */
.sibl-hero-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}

.sibl-hero-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(31,168,84,.2);
    border-radius: 14px 14px 0 0;
    padding: 14px 18px 18px;
}

.sibl-hero-card.featured {
    background: linear-gradient(135deg, rgba(31,168,84,.22), rgba(10,61,31,.15));
    border-color: rgba(31,168,84,.45);
}

.sibl-hero-card-lbl {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #1fa854;
    margin-bottom: 5px;
}

.sibl-hero-card-val {
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 2px;
}

.sibl-hero-card.featured .sibl-hero-card-val { color: #1fa854; }

.sibl-hero-card-sub {
    font-size: 11px;
    color: rgba(255,255,255,.38);
}

/* ── Body ── */
.sibl-body { padding-top: 28px; }

/* Quick nav */
.sibl-nav {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 0 0 26px;
}

.sibl-nav-chip {
    background: #fff;
    border: 1px solid var(--border);
    color: var(--g);
    font-size: 12px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 20px;
    text-decoration: none !important;
    transition: background .15s;
    white-space: nowrap;
}

.sibl-nav-chip:hover {
    background: var(--cdk);
    color: var(--g) !important;
    text-decoration: none !important;
}

/* ══════════════════════════════════════════════
   TOOL FORM CARD
══════════════════════════════════════════════ */
.sibl-form {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 28px rgba(10,61,31,.09);
    margin-bottom: 8px;
}

.sibl-form-header {
    background: linear-gradient(135deg, var(--g), var(--gm));
    padding: 16px 24px;
}

.sibl-form-header-t {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
}

.sibl-form-header-s {
    font-size: 12px;
    color: rgba(255,255,255,.55);
    margin-top: 2px;
}

.sibl-form-body {
    padding: 24px 24px 20px;
}

.sibl-form-body > label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 8px;
}

.sibl-input-wrap {
    position: relative;
    margin-bottom: 6px;
}

#sibl-input {
    width: 100%;
    padding: 14px 46px 14px 16px;
    font-family: inherit;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: .1em;
    color: var(--ink);
    background: #fff;
    border: 1.5px solid var(--border);
    border-radius: 10px;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    text-transform: uppercase;
    box-sizing: border-box;
}

#sibl-input:focus {
    border-color: var(--gm);
    box-shadow: 0 0 0 3px rgba(13,102,50,.1);
}

#sibl-input::placeholder {
    color: #bbb;
    font-weight: 300;
    text-transform: none;
    letter-spacing: normal;
}

.sibl-clear {
    position: absolute;
    right: 13px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: #aaa;
    font-size: 15px;
    padding: 0;
    transition: color .2s;
    line-height: 1;
}

.sibl-clear:hover { color: var(--ink); }

.sibl-char-count {
    font-size: 11px;
    color: var(--muted);
    text-align: right;
    margin-bottom: 14px;
}

.sibl-btn {
    width: 100%;
    padding: 15px;
    background: linear-gradient(135deg, var(--g), var(--gm));
    color: #fff;
    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .3px;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: opacity .2s, transform .15s;
}

.sibl-btn:hover  { opacity: .9; transform: translateY(-1px); }
.sibl-btn:active { transform: translateY(0); }
.sibl-btn-icon   { font-size: 16px; }

/* ── Sample chips ── */
.sibl-examples {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--cdk);
}

.sibl-examples-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 9px;
}

.sibl-chips { display: flex; flex-wrap: wrap; gap: 7px; }

.sibl-chip {
    font-size: 12px;
    font-family: monospace;
    background: var(--gp);
    border: 1px solid rgba(13,102,50,.2);
    color: var(--g);
    padding: 6px 14px;
    border-radius: 20px;
    cursor: pointer;
    font-weight: 700;
    transition: background .15s, color .15s, border-color .15s;
}

.sibl-chip:hover {
    background: var(--gm);
    color: #fff;
    border-color: var(--gm);
}

/* ══════════════════════════════════════════════
   RESULT
══════════════════════════════════════════════ */
.sibl-result {
    margin-top: 20px;
    border-radius: 16px;
    overflow: hidden;
    animation: siblFadeIn .3s ease;
    box-shadow: 0 4px 20px rgba(10,61,31,.1);
}

@keyframes siblFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.sibl-result-header {
    padding: 14px 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .05em;
}

.sibl-result.sibl-valid .sibl-result-header {
    background: linear-gradient(135deg, var(--g), var(--gm));
    color: #fff;
}

.sibl-result.sibl-invalid .sibl-result-header {
    background: #fdf0ee;
    color: var(--red);
    border: 1.5px solid rgba(220,38,38,.2);
    border-bottom: none;
}

.sibl-result-body {
    background: #fff;
    border: 1.5px solid;
    border-top: none;
    border-radius: 0 0 16px 16px;
    padding: 20px;
}

.sibl-result.sibl-valid .sibl-result-body   { border-color: rgba(10,61,31,.15); }
.sibl-result.sibl-invalid .sibl-result-body { border-color: rgba(220,38,38,.2); }

.sibl-iban-display {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: .1em;
    color: var(--g);
    margin-bottom: 16px;
    word-break: break-all;
    font-variant-numeric: tabular-nums;
    padding: 14px 16px;
    background: var(--gp);
    border-radius: 10px;
    border: 1px solid rgba(13,102,50,.15);
}

.sibl-iban-display .sibl-cc  { color: var(--gold); font-weight: 800; }
.sibl-iban-display .sibl-grp { display: inline-block; margin-right: 4px; }

.sibl-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.sibl-info-item {
    background: var(--cream);
    border-radius: 10px;
    padding: 11px 14px;
    border: 1px solid var(--border);
}

.sibl-info-item.sibl-full { grid-column: 1 / -1; }

.sibl-info-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 4px;
}

.sibl-info-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
}

.sibl-info-value.sibl-bank {
    font-size: 15px;
    font-weight: 700;
    color: var(--g);
}

.sibl-note {
    grid-column: 1 / -1;
    background: var(--goldbg);
    border: 1px solid var(--goldbd);
    border-left: 3px solid var(--gold);
    border-radius: 0 8px 8px 0;
    padding: 10px 14px;
    font-size: 12px;
    color: #4a2e00;
    line-height: 1.6;
}

.sibl-error-msg {
    font-size: 14px;
    color: var(--red);
    line-height: 1.6;
    margin: 0;
}

/* ══════════════════════════════════════════════
   AD WRAP
══════════════════════════════════════════════ */
.sibl-ad-wrap { margin: 28px 0; text-align: center; }

/* ══════════════════════════════════════════════
   SECTION WRAPPER
══════════════════════════════════════════════ */
.sibl-section { margin-top: 36px; }

.sibl-section-title {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--ink) !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    letter-spacing: -.3px !important;
}

.sibl-section-title::before {
    content: '';
    display: block;
    width: 4px;
    height: 20px;
    background: var(--gm);
    border-radius: 2px;
    flex-shrink: 0;
}

.sibl-section-desc {
    font-size: 13px;
    color: var(--muted);
    margin: 0 0 18px !important;
    line-height: 1.6;
}

/* ══════════════════════════════════════════════
   BANK CODE TABLE
══════════════════════════════════════════════ */
.sibl-table-wrap {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(10,61,31,.06);
}

.sibl-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.sibl-table thead tr {
    background: linear-gradient(135deg, var(--g), var(--gm));
}

.sibl-table thead th {
    padding: 11px 14px;
    text-align: left;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.85);
    border: none !important;
}

.sibl-table tbody tr:nth-child(even) { background: var(--cream); }
.sibl-table tbody tr:nth-child(odd)  { background: #fff; }
.sibl-table tbody tr:hover           { background: var(--gp); }

.sibl-table tbody td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--cdk);
    color: var(--ink);
}

.sibl-table tbody td:first-child {
    font-weight: 800;
    color: var(--gm);
    font-variant-numeric: tabular-nums;
    font-family: monospace;
    font-size: 15px;
}

.sibl-table tbody td:last-child {
    font-family: monospace;
    font-size: 12px;
    color: var(--muted);
}

.sibl-table tbody tr:last-child td { border-bottom: none; }

/* ══════════════════════════════════════════════
   INFO BOXES
══════════════════════════════════════════════ */
.sibl-info-boxes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.sibl-info-box {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 20px;
    transition: box-shadow .15s, transform .15s;
}

.sibl-info-box:hover {
    box-shadow: 0 6px 20px rgba(10,61,31,.1);
    transform: translateY(-2px);
}

.sibl-info-box-icon { font-size: 26px; margin-bottom: 10px; line-height: 1; }

.sibl-info-box h3 {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ink) !important;
    margin: 0 0 8px !important;
    padding: 0 !important;
    border: none !important;
}

.sibl-info-box p {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.65;
    margin: 0 0 8px !important;
}

.sibl-info-box ul {
    margin: 0 !important;
    padding-left: 16px !important;
    font-size: 13px;
    color: var(--muted);
    line-height: 1.8;
}

.sibl-info-box li { margin: 0 !important; }

/* IBAN anatomy diagram */
.sibl-iban-anatomy { margin-top: 14px; font-family: monospace; }

.sibl-part {
    display: inline-block;
    padding: 5px 9px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .04em;
    margin-right: 3px;
}

.sibl-part-cc    { background: linear-gradient(135deg, var(--g), var(--gm)); color: #fff; }
.sibl-part-check { background: var(--cdk); color: var(--ink); }
.sibl-part-bank  { background: var(--gold); color: #fff; }
.sibl-part-acct  { background: var(--cdk); color: var(--ink); font-size: 11px; }

.sibl-part-labels {
    display: flex;
    gap: 3px;
    margin-top: 5px;
    font-family: -apple-system, sans-serif;
}

.sibl-part-labels span {
    font-size: 10px;
    color: var(--muted);
    text-align: center;
    font-weight: 600;
}

.sibl-part-labels span:nth-child(1) { width: 32px; }
.sibl-part-labels span:nth-child(2) { width: 30px; }
.sibl-part-labels span:nth-child(3) { width: 28px; }
.sibl-part-labels span:nth-child(4) { flex: 1; }

/* ══════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════ */
.sibl-faq {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(10,61,31,.06);
}

.sibl-faq-item { border-bottom: 1px solid var(--cdk); }
.sibl-faq-item:last-child { border-bottom: none; }

.sibl-faq-q {
    width: 100%;
    background: #fff;
    border: none;
    padding: 14px 18px;
    text-align: left;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--ink);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    transition: background .15s;
    font-family: inherit;
}

.sibl-faq-q:hover                      { background: var(--gp); }
.sibl-faq-q[aria-expanded="true"]      { background: var(--gp); }

.sibl-faq-icon {
    font-size: 20px;
    font-weight: 300;
    color: var(--gm);
    flex-shrink: 0;
    line-height: 1;
    transition: transform .2s;
}

.sibl-faq-q[aria-expanded="true"] .sibl-faq-icon { transform: rotate(45deg); }

.sibl-faq-a {
    display: none;
    padding: 0 18px 16px;
    background: var(--gp);
    border-top: 1px solid var(--cdk);
}

.sibl-faq-a p {
    font-size: 13px;
    color: var(--ink);
    line-height: 1.72;
    margin: 12px 0 0 !important;
}

/* ══════════════════════════════════════════════
   RELATED TOOLS
══════════════════════════════════════════════ */
.sibl-tools-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.sibl-tool-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 20px 12px;
    text-decoration: none !important;
    color: var(--ink) !important;
    font-size: 13px;
    font-weight: 600;
    text-align: center;
    line-height: 1.35;
    transition: border-color .2s, box-shadow .2s, transform .15s;
}

.sibl-tool-card:hover {
    border-color: var(--gm);
    box-shadow: 0 6px 20px rgba(10,61,31,.1);
    transform: translateY(-2px);
    color: var(--g) !important;
    text-decoration: none !important;
}

.sibl-tool-icon {
    font-size: 30px;
    line-height: 1;
    width: 54px;
    height: 54px;
    background: var(--gp);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 780px) {
    .sibl-hero          { padding: 24px 18px 24px; }
    .sibl-inner         { padding: 0 16px 44px; }
    .sibl-hero-cards    { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .sibl-info-boxes    { grid-template-columns: 1fr; }
    .sibl-tools-grid    { grid-template-columns: repeat(4, 1fr); gap: 9px; }
    .sibl-tool-card     { padding: 15px 8px; font-size: 11px; }
    .sibl-tool-icon     { width: 44px; height: 44px; font-size: 24px; border-radius: 10px; }
    .sibl-iban-display  { font-size: 16px; letter-spacing: .05em; }
    .sibl-info-grid     { grid-template-columns: 1fr; }
    .sibl-info-item.sibl-full { grid-column: 1; }
    .sibl-note          { grid-column: 1; }
}

@media (max-width: 480px) {
    #sibl-input         { font-size: 16px; padding: 13px 42px 13px 14px; }
    .sibl-btn           { font-size: 14px; padding: 14px; }
    .sibl-tools-grid    { grid-template-columns: repeat(2, 1fr); }
    .sibl-form-body     { padding: 18px 16px 16px; }
}
