/* ===========================
   Fincoex — Global Styles
   =========================== */
:root{
  --bg:#0a0b10;
  --ink:#f5f7fb;
  --muted:#a5adbb;

  --card:#ffffff;
  --ink-card:#111827;
  --border:#e5e7eb;

  --brand:#27c26b;
  --brand-ink:#04130b;

  --deep:#1f0f1f;
  --accent:#5b1a58;
  --accent-ink:#ffffff;

  --line:#1d2230;
  --shadow:0 10px 30px rgba(0,0,0,.12);
}

*{ box-sizing:border-box; }
html,body{
  margin:0; padding:0;
  background:var(--bg); color:var(--ink);
  font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, "Noto Sans", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

.container{ width:min(1180px,92%); margin:0 auto; }

/* Header / Mobile Nav */
.site-header{
  position:sticky; top:0; z-index:20;
  backdrop-filter: blur(10px);
  background: rgba(10,11,16,.55);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.header-wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.logo{
  display:flex; gap:.5rem; align-items:center;
  text-decoration:none; color:var(--ink);
  font-weight:800; letter-spacing:.2px;
}
.logo-mark{
  background:var(--brand); color:var(--brand-ink);
  width:30px; height:30px; display:grid; place-items:center;
  border-radius:8px; font-weight:900;
}
.logo-text{ font-size:18px; }

.nav{ display:flex; align-items:center; gap:16px; }
.nav a{ color:var(--ink); text-decoration:none; opacity:.9; padding:8px 2px; }
.nav a:hover{ opacity:1; }

.nav-toggle{
  display:none; width:40px; height:40px; border:1px solid rgba(255,255,255,.15);
  border-radius:10px; background:transparent; cursor:pointer; align-items:center; justify-content:center; gap:4px;
}
.nav-toggle span{ display:block; width:20px; height:2px; background:#fff; border-radius:2px; }

/* Buttons */
.btn{
  display:inline-block; padding:.58rem .9rem;
  border-radius:10px; border:1px solid rgba(255,255,255,.12);
  text-decoration:none; color:var(--ink); background:#131827;
  transition: filter .2s ease, transform .06s ease, opacity .2s ease;
  cursor:pointer;
}
.btn:hover{ filter:brightness(1.06); }
.btn:active{ transform: translateY(1px); }
.btn[disabled]{ opacity:.6; cursor:not-allowed; }
.btn-primary{ background:var(--brand); color:var(--brand-ink); border-color:transparent; font-weight:700; }
.btn-lg{ padding:.8rem 1.2rem; border-radius:12px; }
.btn-small{ padding:.4rem .6rem; border-radius:8px; font-size:14px; }
.btn-ghost{ background:#f3f4f6; color:#111; border-color:#e5e7eb; }

/* Hero */
.hero{
  padding:48px 0 8px;
  border-bottom:1px solid var(--line);
  background: radial-gradient(1200px 580px at 75% -10%, rgba(39,194,107,.2), transparent 60%);
}
.hero-grid{
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap:28px; align-items:center;
}
.hero h1{ font-size: clamp(28px, 3.2vw, 44px); line-height:1.08; margin:.2em 0 .4em; }
.hero p{ color:var(--muted); max-width:58ch; }
.hero-art{ width:100%; max-width:520px; margin-left:auto; filter: drop-shadow(0 20px 50px rgba(0,0,0,.35)); }
.hero-art svg{ width:100%; height:auto; display:block; }

/* Sections */
.section{ padding:34px 0; }
.section.alt{ background:#0c0f18; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }

/* Converter */
.fx-converter{ width:min(760px,100%); margin:26px auto 0; position:relative; }
.fx-row{
  display:grid; grid-template-columns: 1fr auto; gap:16px;
  background:var(--card); color:var(--ink-card);
  border:2px solid var(--deep); border-radius:22px;
  padding:16px 18px; box-shadow: var(--shadow);
}
.fx-row-bottom{ margin-top:22px; border:1px solid var(--border); border-radius:18px; }

.fx-left{ display:flex; flex-direction:column; justify-content:center; }
.fx-label{ font-size:14px; color:var(--ink-card); font-weight:600; letter-spacing:.3px; }
.fx-label.muted{ color:#6b7280; }
.fx-amount{
  margin-top:6px; border:none; outline:none; background:transparent;
  font-size:30px; line-height:1.1; font-weight:800; color:var(--ink-card);
}
.fx-amount::placeholder{ color:#a3a9b6; }
.fx-amount.muted{ color:#6b7280; }

.fx-right{ position:relative; min-width:180px; display:flex; align-items:center; gap:10px; justify-content:flex-end; }
.fx-flag{ font-size:22px; width:30px; text-align:center; }
.fx-select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background:#fff; border:1px solid var(--border);
  border-radius:12px; padding:10px 34px 10px 12px; font-size:16px; color:#111827;
}
.fx-select:focus{ outline:2px solid #cfe7ff; outline-offset:2px; }
.fx-caret{ position:absolute; right:12px; pointer-events:none; color:#6b7280; }

.fx-swap{
  position:absolute; left:50%; transform:translate(-50%,-50%);
  top: calc(50% + 2px);
  width:60px; height:60px; border-radius:999px;
  background:var(--accent); color:var(--accent-ink);
  border:6px solid #fff; display:grid; place-items:center;
  box-shadow: 0 6px 20px rgba(91,26,88,.35); cursor:pointer;
  transition: transform .08s ease, filter .2s ease;
}
.fx-swap-arrows{ font-size:20px; line-height:1; }
.fx-swap:hover{ filter:brightness(1.05); }
.fx-swap:active{ transform: translate(-50%,-50%) scale(.98); }

.fx-meta{ margin-top:14px; display:flex; align-items:center; justify-content:space-between; color:#a0a8b6; font-size:14px; }
.fx-updated{ font-size:12px; }

.after-converter{ margin-top:18px; display:flex; align-items:center; justify-content:center; }

/* Rates Table */
.table-wrap{ overflow:auto; border:1px solid var(--line); border-radius:12px; }
.rates-table{ width:100%; border-collapse:collapse; }
.rates-table th, .rates-table td{ padding:10px 12px; border-bottom:1px solid var(--line); text-align:left; }
.rates-table th{ background:#0f1220; font-weight:600; }
.rates-table tr:hover td{ background:#0f1220; }

/* Cards */
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; }
.mini-card{ background:#0f1220; border:1px solid var(--line); border-radius:16px; padding:16px; }

/* Footer */
.site-footer{ padding:28px 0; border-top:1px solid var(--line); background:#080a10; }
.footer-grid{ display:grid; grid-template-columns: 1.2fr 1fr 1fr; gap:18px; }
.logo-footer{ font-weight:800; margin-bottom:8px; }
.list{ list-style:none; padding:0; margin:0; }
.list li{ margin:6px 0; }

/* Hide number input spinners */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"] { -moz-appearance: textfield; }

/* Modal */
.modal{ position:fixed; inset:0; display:none; z-index:50; }
.modal.is-open{ display:block; }
.modal-backdrop{
  position:absolute; inset:0; background:rgba(0,0,0,.55);
  backdrop-filter: blur(2px);
}
.modal-dialog{
  position:relative; z-index:1;
  width:min(980px, 94vw);
  max-height:92vh; overflow:auto;
  margin:4vh auto; background:#fff; color:#111827;
  border-radius:24px; box-shadow:0 30px 80px rgba(0,0,0,.35);
}
.modal-close{
  position:absolute; right:14px; top:12px;
  width:34px; height:34px; border-radius:10px;
  border:1px solid #e5e7eb; background:#fff; color:#111; cursor:pointer;
  font-size:20px; line-height:1;
}
.modal-grid{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap:0; }

/* Left summary */
.modal-summary{
  background:#f6f1f6; padding:22px; border-top-left-radius:24px; border-bottom-left-radius:24px;
  min-height:420px;
}
.summary-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.summary-step{ color:#6b7280; }
.summary-rows{ margin-top:6px; }
.summary-row{ display:flex; align-items:center; justify-content:space-between; padding:10px 0; }
.summary-row span{ color:#6b7280; }
.summary-row strong{ font-weight:800; }
.summary-dash{ border:none; border-top:2px dashed #e5e0e7; margin:0; }

.summary-cta{
  margin-top:22px; background:#e9e2e9; border:1px solid #e1d3e5;
  border-radius:18px; padding:16px;
}
.summary-cta p{ margin:0 0 10px; color:#4b5563; }

/* Right content */
.modal-content{ padding:26px; }
.modal-content h3{ margin:0 0 16px; font-size:20px; }
.hide{ display:none !important; }

/* Step 1 */
.bank-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:14px; margin-top:8px; }
.bank-card{
  display:flex; align-items:center; gap:10px; padding:16px 14px;
  border-radius:14px; background:#fff; border:2px solid #e8ddea; cursor:pointer;
  transition: box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.bank-card .bank-icon{ width:28px; height:28px; display:grid; place-items:center; border-radius:8px; }
.bank-tbc{ background:#d8eff7; }
.bank-bog{ background:#fde3d8; }
.bank-name{ font-weight:700; color:#1f2937; }
.bank-card[aria-pressed="true"]{
  border-color:#5b1a58; box-shadow:0 0 0 3px rgba(91,26,88,.14);
}
.bank-note{ display:flex; align-items:flex-start; gap:8px; color:#6b7280; margin-top:18px; }
.bank-note .i{
  width:24px; height:24px; border:1px solid #d1d5db; border-radius:999px; display:grid; place-items:center;
  color:#111; font-weight:700; font-family:ui-sans-serif, system-ui;
}

/* Step 2 */
.agreement h4{ margin:0 0 10px; }
.agreement ul{ margin:0 0 14px 18px; color:#4b5563; }
.agree-check{ display:flex; align-items:center; gap:8px; font-weight:600; }
.agree-check input{ width:18px; height:18px; }

/* Step 3 */
.instr h4{ margin:0 0 12px; }
.instr .instr-row{ display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-bottom:1px dashed #e5e0e7; }
.instr .instr-row:last-child{ border-bottom:none; }
.iban-box{ display:flex; gap:10px; align-items:center; }
.iban-box code{ background:#f3f4f6; padding:.45rem .6rem; border-radius:8px; border:1px solid #e5e7eb; display:inline-block; }
.muted{ color:#6b7280; margin-top:8px; }

/* Modal footer */
.modal-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }
.modal-actions .chev{ margin-left:8px; font-weight:700; }

/* Responsive */
@media (max-width: 960px){
  .nav-toggle{ display:flex; }
  .nav{
    position: absolute;
    top: 62px; right: 0; left: 0;
    background: rgba(10,11,16,.96);
    border-top: 1px solid rgba(255,255,255,.08);
    display: none;
    flex-direction: column;
    padding: 10px 16px;
  }
  .nav a{ padding:12px 4px; border-bottom:1px solid rgba(255,255,255,.06); }
  .nav a:last-child{ border-bottom:none; }
  .nav.is-open{ display:flex; }

  .hero-grid{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }

  .fx-row{ grid-template-columns: 1fr; }
  .fx-right{ justify-content:flex-start; }
  .fx-swap{ top: calc(50% + 8px); }

  .modal-grid{ grid-template-columns: 1fr; }
  .modal-summary{ border-bottom-left-radius:0; border-top-right-radius:24px; }
  .bank-grid{ grid-template-columns: 1fr; }
}