:root{--brand-primary:#0378a7;--brand-primary-dark:#025573;--brand-primary-light:#4fa8c8;--brand-accent:#f2a20d;--brand-accent-dark:#b87900;--brand-accent-light:#f6c14f;--text-primary:#1e1e1e;--text-inverse:#fff;--bg-page:#f4f6f9;--row-alt:#eef3f8;--buy:#0a8a3a;--sell:#cc2e2e}html,body,#root{height:100%}html{font-size:20px}@media (min-width:1600px){html{font-size:22px}}@media (min-width:1920px){html{font-size:24px}}body{background:var(--bg-page);color:var(--text-primary);margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;overflow:hidden}.no-select{-webkit-user-select:none;user-select:none}.screen{grid-template-rows:100vh;grid-template-columns:40% 60%;width:100vw;height:100vh;display:grid}.sidebar{grid-template-rows:50% auto 1fr;gap:.8rem;padding:1.2rem;display:grid}.logo-area{justify-content:flex-start;align-items:center;width:100%;height:100%;padding-left:1rem;display:flex}.logo-area img{object-fit:contain;max-width:100%;max-height:100%;margin-top:-100px}.company-name{color:var(--brand-primary);text-align:center;font-size:1.8rem;font-weight:800;line-height:1.1}.company-info{opacity:.95;margin-top:-50px;font-size:1.05rem;font-weight:700}.tagline{color:var(--brand-accent);margin-top:.6rem;font-size:1.05rem;font-weight:700}.main{grid-template-rows:auto 1fr;min-width:0;display:grid;position:relative}.visually-hidden{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.loader-overlay{z-index:20;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#f4f6f9eb;place-items:center;display:grid;position:absolute;inset:0}.loader{place-items:center;width:120px;height:120px;display:grid;position:relative}.loader .ring{border:4px solid #0378a733;border-top-color:var(--brand-primary);border-radius:50%;width:100%;height:100%;animation:.9s linear infinite rate-spin;position:absolute}.loader-logo{object-fit:contain;width:48px;height:auto}@keyframes rate-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.loader .ring{border-top-color:#0378a773;animation:none}}.rates-message{color:var(--text-primary);background:#eef3f8;border:1px solid #c5d4e3;border-radius:8px;margin:1rem 0;padding:1rem 1.1rem;font-size:1.05rem;line-height:1.45}.rates-message--error{color:var(--brand-accent);background:#fff}.rates-message p{margin:.5rem 0 0;font-size:.95rem;font-weight:600}.rates-fallback-logo{object-fit:contain;width:100%;max-width:100%;height:auto;margin:0 0 .75rem;display:block}.company-branch{margin:0 0 .5rem}.company-info .company-line{margin:.25rem 0;font-weight:700}.hours-lines p{margin:.2rem 0}.notice-heading{margin-top:.75rem;display:block}.notice-body{margin:.35rem 0 0;font-weight:600}.cell.tabular{font-variant-numeric:tabular-nums}.currency-flag{flex-shrink:0}.currency-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.header{background:linear-gradient(180deg,var(--brand-primary),var(--brand-primary-dark));color:var(--text-inverse);z-index:10;grid-template-rows:auto auto;gap:.3rem;padding:.8rem 1.2rem;display:grid;position:sticky;top:0;box-shadow:0 2px 10px #00000026}.title{text-align:center;letter-spacing:.08em;font-weight:900;font-size:inherit;text-transform:uppercase;margin:0}.subbar{opacity:.95;justify-content:center;align-items:center;font-weight:600;display:flex}.table-wrap{box-sizing:border-box;height:100%;padding:.8rem 0;overflow:hidden}.rate-table{border-collapse:separate;border-spacing:0 8px;table-layout:fixed;width:100%}.rate-thead th{color:var(--brand-primary);text-align:left;background:#fff;padding:.6rem .8rem;font-size:1.1rem;font-weight:800;position:sticky;top:0}.rate-row{background:#fff;box-shadow:0 2px 6px #0000000f}.rate-row.alt{background:var(--row-alt)}.cell{text-overflow:ellipsis;white-space:nowrap;padding:.7rem;font-size:1.2rem;overflow:hidden}.cell-flag{align-items:center;gap:.6rem;min-width:0;display:flex}.code{letter-spacing:.04em;font-weight:800}.buy{color:var(--buy);font-weight:800}.sell{color:var(--sell);font-weight:800}.footer-bar{display:none}.title{font-size:1.6rem}.subbar{font-size:1rem}.cell-flag span{font-weight:700}.notice{color:#856404;background-color:#fff3cd;border:1px solid #ffeeba;border-radius:6px;margin-top:1rem;padding:.75rem;font-size:.9rem}.working-hours{color:#034078;background-color:#e8f4ff;border:1px solid #b6e0fe;border-radius:6px;margin-top:.5rem;padding:.75rem;font-size:.9rem}@media (max-height:720px){.cell{font-size:1.1rem}.rate-thead th{font-size:1rem}}@media (max-height:600px){.cell{padding:.6rem;font-size:1rem}.rate-thead th{padding:.5rem .6rem;font-size:.95rem}}.col-currency{width:40%}.col-code{width:15%}.col-buy,.col-sell{width:22.5%}.note{opacity:.88;max-width:58ch;margin-top:.5rem;font-size:.9rem;line-height:1.4}
