/* ============================================================
   LN OPS — DESIGN SYSTEM  (portable)
   Wklej ten plik do nowej apki:  <link rel="stylesheet" href="style.css">
   Wymaga w <head>:
     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Montserrat:wght@600;700;800&display=swap" rel="stylesheet">
     <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/all.min.css">
   Zasada naczelna: minimalizm, dużo bieli, JEDEN akcent (czerwień) używany
   oszczędnie, miękkie cienie, ZERO gradientów, czytelność najważniejszych liczb.
   ============================================================ */

:root{
  /* — Akcent (logo, aktywna pozycja, najważniejsze liczby, alert) — */
  --accent:#FF3131;        /* główna czerwień LN — używać punktowo */
  --accent-2:#EA2530;      /* hover na przyciskach */
  --accent-soft:#FFF1F1;   /* tło aktywnej zakładki / badge */
  --accent-tint:#FFF7F7;   /* delikatne tło banera */
  --accent-line:#F7D9D9;   /* obramowanie elementów w kolorze akcentu */

  /* — Tła i tekst — */
  --bg:#F6F7F9;            /* tło aplikacji */
  --card:#FFFFFF;          /* karty, panele */
  --text:#21262C;          /* tekst główny (grafit) */
  --muted:#697077;         /* tekst pomocniczy */
  --muted-2:#9AA1A8;       /* etykiety, opisy, ikony nieaktywne */

  /* — Linie — */
  --border:#ECEEF1;        /* delikatna linia / obramowanie kart */
  --border-strong:#DEE1E5; /* pola, przyciski secondary */

  /* — Statusy (oszczędnie) — */
  --green:#1F9D57;  --green-soft:#EAF6EF;   /* sukces / +zysk / opłacone */
  --amber:#B07D1A;  --amber-soft:#F9F1DF;   /* uwaga / oczekuje / zalega */
  /* alert/minus = używaj --accent + --accent-soft */

  /* — Kształt i cień — */
  --radius:14px;           /* karty */
  --radius-sm:9px;         /* przyciski, pola, badge-kwadrat */
  --shadow:0 1px 2px rgba(20,23,28,.03), 0 4px 14px rgba(20,23,28,.045); /* tylko subtelny */

  /* — Typografia — */
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif; /* UI / tekst */
  --display:'Montserrat','Inter',sans-serif; /* nagłówki i LICZBY */
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}

/* ---------- LAYOUT: lewy panel + treść ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:252px;flex-shrink:0;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:22px 14px;position:sticky;top:0;height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:26px 30px 54px;max-width:1240px;width:100%}

/* ---------- NAWIGACJA (panel) ---------- */
.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--muted-2);font-weight:700;padding:18px 10px 8px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--muted);font-weight:500;cursor:pointer;margin-bottom:2px;font-size:13.5px;transition:.15s}
.nav-item i{width:18px;text-align:center;font-size:15px;color:var(--muted-2);transition:.15s}
.nav-item:hover{background:#F4F5F7;color:var(--text)}
.nav-item:hover i{color:var(--muted)}
.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}     /* aktywne = delikatny akcent */
.nav-item.active i{color:var(--accent)}
.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px}

/* ---------- PASEK GÓRNY ---------- */
.topbar{display:flex;align-items:center;gap:18px;padding:17px 30px;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.page-title{font-family:var(--display);font-size:18px;font-weight:700;letter-spacing:-.01em}
.page-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.icon-btn{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:#fff;color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px}
.icon-btn:hover{color:var(--text);border-color:var(--text)}

/* ---------- PRZYCISKI ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-weight:600;font-size:13.5px;padding:10px 16px;transition:.15s;white-space:nowrap}
.btn i{font-size:12px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2)}
.btn-ghost{background:var(--card);color:var(--text);border:1.5px solid var(--border-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- KARTY i SIATKA ---------- */
.grid{display:grid;gap:18px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 6px}
.card-label{font-size:11.5px;color:var(--muted-2);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.card-title{font-family:var(--display);font-size:16px;font-weight:700;letter-spacing:-.01em;margin-top:3px}
.card-link{font-size:12.5px;color:var(--accent);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.card-link:hover{text-decoration:underline}

/* ---------- KARTA WSKAŹNIKA (KPI) ---------- */
.kpi{padding:20px 22px}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}
.kpi-label{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi-ico{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:#F3F4F6;color:var(--muted);font-size:15px}
.kpi-ico.is-accent{background:var(--accent-soft);color:var(--accent)}   /* tylko 1 KPI na ekranie */
.kpi-val{font-family:var(--display);font-size:27px;font-weight:800;letter-spacing:-.025em}
.kpi-val .cur{font-family:var(--font);font-size:14px;font-weight:600;color:var(--muted-2);margin-left:4px} /* "zł","%" */
.kpi-trend{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;margin-top:11px}
.kpi-trend i{font-size:10px}
.up{color:var(--green)} .down{color:var(--accent)} .neutral{color:var(--muted-2)}
.kpi-trend .muted{color:var(--muted-2);font-weight:500}

/* ---------- MINI-WSKAŹNIK (mała statystyka) ---------- */
.mk{padding:18px 20px}
.mk-label{font-size:12px;color:var(--muted);font-weight:600}
.mk-val{font-family:var(--display);font-size:22px;font-weight:800;margin-top:8px;letter-spacing:-.02em}
.mk-sub{font-size:11.5px;color:var(--muted);margin-top:4px}

/* ---------- PIGUŁKI / FILTRY ---------- */
.pills{display:flex;gap:8px;flex-wrap:wrap;padding:4px 22px 6px}
.pill{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid var(--border-strong);border-radius:999px;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;background:#fff;transition:.15s}
.pill:hover{border-color:var(--text);color:var(--text)}
.pill.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.pill .cnt{background:#EEF0F2;color:var(--muted);font-size:11px;font-weight:700;padding:0 7px;border-radius:999px;min-width:18px;text-align:center}
.pill.active .cnt{background:var(--accent);color:#fff}

/* ---------- ETYKIETY STATUSU (badge) ---------- */
.badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.b-green{background:var(--green-soft);color:var(--green)}     /* aktywny, opłacone, gotowe */
.b-amber{background:var(--amber-soft);color:var(--amber)}     /* oczekuje, zalega, czeka */
.b-accent,.b-red{background:var(--accent-soft);color:var(--accent)} /* nowy, alert, po terminie */
.b-gray{background:#F0F1F3;color:var(--muted)}                /* neutralny */

/* tag prostokątny, WERSALIKI (np. status w liście dokumentów) */
.tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:3px 8px;border-radius:5px}
.tag-red{background:var(--accent-soft);color:var(--accent)}
.tag-amber{background:var(--amber-soft);color:var(--amber)}
.tag-green{background:var(--green-soft);color:var(--green)}
.tag-gray{background:#F0F1F3;color:var(--muted)}

/* ---------- TABELA ---------- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted-2);font-weight:600;padding:13px 22px;border-bottom:1px solid var(--border)}
.tbl td{padding:14px 22px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:#FAFBFC}
.td-strong{font-weight:600}
.td-right{text-align:right}
.num{font-family:var(--display);font-weight:700}   /* liczby zawsze Montserrat */

/* ---------- LISTA z ikoną / awatarem ---------- */
.list-row{display:flex;align-items:center;gap:13px;padding:13px 22px;border-top:1px solid var(--border)}
.list-row:first-child{border-top:none}
.av-mini{width:36px;height:36px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:12.5px;background:#F0F1F3;color:var(--text)}
.ibadge{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:14px;background:#F3F4F6;color:var(--muted);flex-shrink:0}
.ibadge.is-accent{background:var(--accent-soft);color:var(--accent)}
.ibadge.is-amber{background:var(--amber-soft);color:var(--amber)}
.ibadge.is-green{background:var(--green-soft);color:var(--green)}

/* ---------- BANER (np. integracja / podpowiedź) ---------- */
.banner{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--radius);background:var(--accent-tint);border:1px solid var(--accent-line);margin-bottom:18px}
.banner-ico{width:44px;height:44px;border-radius:11px;background:#fff;border:1px solid var(--accent-line);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent);font-size:17px}
.banner-t{font-weight:700;font-size:14px}
.banner-s{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ---------- STREFA UPUSZCZANIA / ŹRÓDŁO ---------- */
.dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:30px;text-align:center;color:var(--muted);background:#FBFBFC}
.dropzone .dz-ico{color:var(--accent);font-size:24px;margin-bottom:10px}
.source-tag{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);background:var(--card);border:1px solid var(--border-strong);padding:7px 13px;border-radius:999px;font-weight:600}
.source-tag i{color:var(--accent);font-size:12px}

/* ---------- PASEK KATEGORII / WYKRES POZIOMY ---------- */
.cat-row{margin-bottom:15px}
.cat-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
.cat-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}
.cat-tag{width:9px;height:9px;border-radius:3px}
.cat-amt{font-size:13px;font-weight:700;font-family:var(--display)}
.track{height:8px;background:#EFF1F3;border-radius:6px;overflow:hidden}
.fill{height:100%;border-radius:6px}
/* Wypełnienia od najważniejszego: akcent, potem skala grafitu →
   #FF3131, #3A3F45, #787E85, #AEB4BA, #D4D8DC
   Słupki wykresu pionowego: grafit #3A3F45, koszty/tło #D7DADE,
   bieżący okres podświetlony --accent (#FF3131). */

/* ---------- FORMULARZE i OKNA (dialog) ---------- */
.inp{width:100%;font-family:inherit;font-size:14px;color:var(--text);background:#fff;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);padding:11px 12px;margin-top:6px;transition:.15s}
.inp:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
select.inp{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23697077' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}
.fld{display:block;margin-bottom:14px}
.fld-label{font-size:12.5px;font-weight:600;color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
dialog.modal{border:none;border-radius:var(--radius);box-shadow:0 12px 44px rgba(20,23,28,.20);padding:0;width:460px;max-width:92vw;position:fixed;inset:0;margin:auto}
dialog.modal::backdrop{background:rgba(20,23,28,.35)}
.modal-head{padding:18px 22px;font-family:var(--display);font-weight:700;font-size:16px;border-bottom:1px solid var(--border)}
.modal-body{padding:18px 22px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border);background:#FBFBFC;border-radius:0 0 var(--radius) var(--radius)}
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{width:384px;max-width:100%;padding:32px 32px 26px}
.login-err{background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:600;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:14px;text-align:center}
.login-hint{font-size:12px;color:var(--muted-2);text-align:center;margin-top:16px;line-height:1.6}
.logout-link{color:var(--muted-2);font-size:12px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-top:4px}
.logout-link:hover{color:var(--accent)}

/* ---------- SIATKI (klasy zamiast inline — by działały media queries) ---------- */
.grid-kpi{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-split{grid-template-columns:1.4fr 1fr}

/* ---------- RESPONSYWNOŚĆ ---------- */
@media (max-width:760px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--border);padding:12px 14px}
  .grid-kpi{grid-template-columns:repeat(2,1fr)}
  .grid-3,.grid-split{grid-template-columns:1fr}
  .content{padding:18px 16px 40px}
  .topbar{padding:14px 16px}
}
@media (max-width:430px){
  .grid-kpi{grid-template-columns:1fr}
  .kpi-val{font-size:24px}
}

/* ── Wyszukiwalny dropdown (.searchable) ─────────────────────────────── */
.ss-wrap{position:relative;width:100%}
.ss-wrap select.ss-native{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;left:0;top:0}
.ss-control{display:flex;align-items:center;gap:8px;width:100%;background:#fff;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0 12px;cursor:text;transition:border-color .12s,box-shadow .12s}
.ss-wrap.ss-open .ss-control{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.ss-input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:14px;color:var(--text);padding:11px 0;min-width:0}
.ss-input::placeholder{color:var(--muted-2)}
.ss-caret{color:var(--muted-2);font-size:12px;transition:transform .15s}
.ss-wrap.ss-open .ss-caret{transform:rotate(180deg);color:var(--accent)}
.ss-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:60;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px rgba(20,23,28,.14);max-height:280px;overflow-y:auto;padding:6px}
.ss-opt{position:relative;display:flex;flex-direction:column;gap:1px;padding:9px 11px;border-radius:8px;cursor:pointer;line-height:1.3}
.ss-opt:hover,.ss-opt.active{background:var(--accent-soft)}
.ss-opt.sel{background:var(--accent-tint)}
.ss-opt.sel::after{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--accent);position:absolute;right:12px;top:11px;font-size:11px}
.ss-opt-l{font-size:14px;font-weight:600;color:var(--text)}
.ss-sub{font-size:11.5px;color:var(--muted-2);font-variant-numeric:tabular-nums}
.ss-empty{padding:14px 12px;text-align:center;color:var(--muted-2);font-size:13px}
.modal-body{overflow:visible}

/* ── Przycisk w stanie ładowania + spinner ───────────────────────────── */
@keyframes ln-spin{to{transform:rotate(360deg)}}
.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:ln-spin .7s linear infinite;vertical-align:-2px;margin-right:7px}
.btn.loading{opacity:.95;cursor:progress;pointer-events:none}
.btn:disabled{opacity:.65;cursor:not-allowed}

/* ── Tooltip pomocniczy (hover + focus/klik) ─────────────────────────── */
.tip{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--border-strong);color:var(--muted);font-size:10px;font-weight:800;cursor:help;position:relative;outline:none;flex:none;user-select:none}
.tip:hover,.tip:focus{background:var(--accent);color:#fff}
.tip-pop{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);width:max-content;max-width:280px;background:#21262C;color:#fff;font-size:12px;font-weight:500;line-height:1.5;text-align:left;padding:10px 12px;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.22);opacity:0;visibility:hidden;transition:opacity .14s,transform .14s;z-index:70;pointer-events:none}
.tip-pop::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#21262C}
.tip:hover .tip-pop,.tip:focus .tip-pop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
@media (max-width:560px){.tip-pop{left:auto;right:-4px;transform:translateY(4px)}.tip-pop::after{left:auto;right:8px}.tip:hover .tip-pop,.tip:focus .tip-pop{transform:translateY(0)}}

/* ── Nagłówki bloków w edytorze raportu ─────────────────────────────── */
.blk-h{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.blk-h .blk-t{font-family:var(--display);font-size:15.5px;font-weight:800;color:var(--text);letter-spacing:.01em}
.blk-h .blk-ic{color:var(--accent);font-size:14px}
.blk-sub{font-size:12.5px;color:var(--muted);margin-bottom:14px;line-height:1.5}

/* ── Tabele w czacie AI (markdown GFM) ──────────────────────────────── */
.md-tblw{overflow-x:auto;margin:10px 0;border:1px solid var(--border);border-radius:10px}
table.md-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
table.md-tbl th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800;padding:8px 11px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}
table.md-tbl td{padding:8px 11px;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
table.md-tbl tbody tr:nth-child(even) td{background:#FBFBFC}
table.md-tbl tbody tr:last-child td{border-bottom:0}
table.md-tbl td:first-child{font-weight:600;color:var(--text)}

/* ── Live editor raportu (tylko zalogowani; gated editMode) ──────────── */
body:has(.le-bar){padding-bottom:72px}
.le-bar{position:fixed;left:0;right:0;bottom:0;z-index:200;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:#21262C;color:#fff;padding:11px 18px;box-shadow:0 -6px 24px rgba(0,0,0,.22)}
.le-bar-l{font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:8px}
.le-bar-l i{color:#FF6A6A}
.le-hint{font-weight:500;color:rgba(255,255,255,.62);font-size:12px}
.le-bar-r{display:flex;align-items:center;gap:9px}
.le-bar-r .btn-ghost{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.18)}
.le-bar-r .btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-sm{padding:7px 12px;font-size:12.5px}
.le-status{font-size:12px;font-weight:700;min-width:96px;text-align:right}
.le-status.le-dirty{color:#FFD27D}
.le-status.le-ok{color:#A7F3D0}
.le-status.le-err{color:#FFB4B4}
.le-sec{position:relative}
.le-hidebtn{position:absolute;top:8px;right:8px;z-index:5;display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:#fff;background:rgba(33,38,44,.85);border:0;border-radius:999px;padding:5px 11px;cursor:pointer;opacity:0;transition:opacity .12s,background .12s}
.le-sec:hover>.le-hidebtn{opacity:1}
.le-hidebtn:hover{background:var(--accent)}
.le-hidden{opacity:.42;filter:grayscale(.35)}
.le-hidden>.le-hidebtn{opacity:1;background:var(--accent)}
[data-edit]:hover{outline:1px dashed currentColor;outline-offset:3px;border-radius:3px;cursor:text}
[data-edit]:focus{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}

/* ── Dashboard: przegląd z lotu ptaka ───────────────────────────────── */
#ovBody{padding:8px 22px 20px}
.ov-alerts{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.ov-alert{display:flex;align-items:center;gap:9px;justify-content:space-between;font-size:12.5px;padding:8px 10px 8px 13px;border-radius:10px;border:1px solid}
.ov-alert.red{background:#FDEBEA;border-color:#F3C6C2;color:#A02720}
.ov-alert.amber{background:#FBF3E0;border-color:#EAD9AC;color:#8A6411}
.ov-alert-txt{display:flex;align-items:center;gap:9px;text-decoration:none;color:inherit;flex:1;min-width:0}
.ov-alert-txt:hover{text-decoration:underline}
.ov-resolve{flex:none;display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;color:#fff;background:rgba(0,0,0,.32);border:0;border-radius:999px;padding:5px 11px;cursor:pointer;white-space:nowrap}
.ov-resolve:hover{background:rgba(0,0,0,.5)}
.ov-resolve:disabled{opacity:.5;cursor:default}
.ov-okbar{display:flex;align-items:center;gap:9px;font-size:13px;padding:11px 14px;border-radius:10px;background:var(--green-soft);color:#0b7a44;margin-bottom:14px;font-weight:600}
.ov-tot{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.ov-tot>div{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:3px}
.ov-tn{font-family:var(--display);font-size:20px;font-weight:800;font-variant-numeric:tabular-nums}
.ov-tl{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
.ov-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}
@media(max-width:760px){.ov-tot{grid-template-columns:repeat(2,1fr)}.ov-cols{grid-template-columns:1fr}}
.ov-col{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:13px 15px}
.ov-col-h{font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:9px}
.ov-col-h i{color:var(--accent);margin-right:5px}
.ov-mini{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.ov-mini:last-child{border:0}
.ov-mn{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ov-mv{color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.ov-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:1px}
.ov-dot.ok{background:var(--green)} .ov-dot.amber{background:#D9A300} .ov-dot.red{background:#C0392B}
.ov-lnk{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;margin-left:5px;text-decoration:none;border:1px solid var(--border)}
.ov-lnk.g{color:#4285F4} .ov-lnk.m{color:#0866FF}
.ov-lnk:hover{background:var(--bg)}
