:root{
  --bg:#070b10;
  --panel:#0f1622;
  --panel2:#0b111a;
  --text:#e7eefc;
  --muted:#9fb0cc;
  --cyan:#00b6ff;
  --cyan2:#2ad3ff;
  --line:#253246;
  --danger:#ff4d4d;
  --ok:#2bd36d;
  --hot:#ff2222;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 14px;
  --font: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);position:relative}

/* Znak wodny w tle (assets/logo.png) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:url("/assets/logo.png") center center / min(720px, 55vw) no-repeat;
  opacity:.10;
  pointer-events:none;
  z-index:0;
  filter:grayscale(1);
}

/* Upewnij się, że cała zawartość jest nad znakiem wodnym */
.topbar,.shell{position:relative;z-index:1}
a{color:inherit;text-decoration:none}

.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#05070b,#080d14);
  position:sticky;top:0;z-index:50;
}
.topbar__left{display:flex;align-items:center;gap:14px;min-width:0}
.topbar__brand{display:flex;align-items:center;gap:10px;min-width:0}
.topbar__logo{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35));opacity:.95}
.topbar__title{
  font-weight:900;letter-spacing:.8px;color:var(--cyan);
  text-transform:uppercase;
}
.topbar__right{display:flex;align-items:center;gap:12px}
.topbar__user{color:var(--muted);font-size:13px}

.topnav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}
.topnav__link{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 10px;border-radius:12px;border:1px solid transparent;
  color:var(--muted);font-weight:800;font-size:13px;white-space:nowrap;
}
.topnav__link:hover{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.02)}
.topnav__link.is-active{border-color:rgba(0,182,255,.35);color:var(--text);background:rgba(0,182,255,.06)}
.topnav__sep{width:1px;height:22px;background:var(--line);display:inline-block;margin:0 2px}

.shell{min-height:calc(100vh - 56px)}
.sidebar{
  padding:14px;border-right:1px solid var(--line);background:var(--panel2)
}
.nav{
  display:block;padding:10px 12px;border-radius:12px;
  color:var(--muted);margin-bottom:8px;border:1px solid transparent;
}
.nav:hover{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.02)}
.nav.is-active{border-color:rgba(0,182,255,.35);color:var(--text);background:rgba(0,182,255,.06)}
.nav__sep{height:1px;background:var(--line);margin:12px 0}

.main{padding:14px 8px;max-width:98vw;margin:0 auto}
.h1{margin:0 0 8px 0;font-size:22px}
.muted{color:var(--muted);margin:0 0 14px 0;font-size:13px;line-height:1.45}

.flash{padding:10px 12px;border-radius:12px;margin:0 0 14px 0;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.flash--error{border-color:rgba(255,77,77,.35);background:rgba(255,77,77,.06)}
.flash--ok{border-color:rgba(43,211,109,.35);background:rgba(43,211,109,.06)}
.flash--info{border-color:rgba(90,160,255,.35);background:rgba(90,160,255,.06)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--text);cursor:pointer;
  font-weight:700;font-size:13px;gap:8px;
}
.btn:hover{background:rgba(255,255,255,.06)}
.btn--primary{border-color:rgba(0,182,255,.35);background:rgba(0,182,255,.10)}
.btn--ghost{background:transparent}
.btn--danger{border-color:rgba(255,77,77,.35);background:rgba(255,77,77,.10)}
.btn--mini{padding:6px 9px;border-radius:10px;font-size:12px}

.cards{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px}
.card{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  padding:16px;box-shadow:var(--shadow);min-height:120px;
}
.card--big{display:flex;flex-direction:column;gap:8px}
.card__title{font-size:18px;font-weight:900}
.card__desc{color:var(--muted);font-size:13px;line-height:1.35}
.card__cta{margin-top:auto;color:var(--cyan2);font-weight:900}

.grid2{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:start}
.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow)}
/* Semi-transparent panel + stronger watermark under admin table */
.panel--watermark{
  /* Bez dodatkowego znaku wodnego (jest tylko jeden globalnie na body) */
  background:rgba(15,22,34,.35);
  backdrop-filter:blur(2px);
}

.panel__head{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-bottom:1px solid var(--line)}
.panel__title{font-weight:900}
:root{
  --topbar-offset:64px;
}

.tableWrap{overflow:visible;position:relative}
/* Bez poziomego scrolla: tabela dopasowuje się do szerokości ekranu */
.adminTable{width:100%;border-collapse:collapse;table-layout:fixed}
.adminTable th,.adminTable td{border:1px solid rgba(255,255,255,.10);padding:4px 6px;font-size:11px;vertical-align:middle}
.adminTable td{word-break:break-word;white-space:normal}
.adminTable thead{position:sticky;top:var(--topbar-offset);z-index:30}
.adminTable thead th{
  position:sticky;
  top:var(--topbar-offset);
  z-index:31;
  background:#05070b;
  color:var(--cyan);
  text-transform:uppercase;
  font-weight:900;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  /* Wszystkie napisy mają być w poziomie (bez pionowych nagłówków) */
  writing-mode:horizontal-tb !important;
  text-orientation:mixed !important;
  transform:none !important;
  white-space:normal;
  word-break:break-word;
  line-height:1.05;
  font-size:10px;
  padding:6px 6px;
  hyphens:auto;
}

/* Nadpisz ewentualne rotacje/tryby pionowe w zagnieżdżonych elementach */
.adminTable thead th *,
.adminTable thead th span,
.adminTable thead th div{
  writing-mode:horizontal-tb !important;
  text-orientation:mixed !important;
  transform:none !important;
}
.adminTable thead th.th--nick{width:140px}
.adminTable thead th.th--wide{width:170px}
.adminTable thead th.th--caretaker{width:135px}
.adminTable thead th.th--actions{width:110px}
.adminTable td.actions{white-space:nowrap}
.adminTable td.actions .btn{padding:3px 6px}
.center{text-align:center}
.actions{white-space:nowrap}

.sectionRow td{padding:7px 10px;border-color:rgba(0,0,0,.35)}
.sectionRow__line{display:flex;gap:12px;align-items:center;justify-content:space-between;text-transform:uppercase;font-weight:900}
.sectionRow__left{display:flex;gap:12px;align-items:center;justify-content:flex-start;flex-wrap:wrap}
.sectionRow__sub{color:#0b0b0b;background:rgba(255,255,255,.65);padding:2px 8px;border-radius:999px;font-size:11px;font-weight:900}
.sectionToggle{width:26px;height:26px;border-radius:6px;border:1px solid rgba(0,0,0,.35);background:rgba(255,255,255,.82);color:#111;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex:0 0 auto}
.sectionToggle:hover{background:#fff}
.sectionToggle__icon{display:inline-block;font-size:12px;line-height:1;transition:transform .18s ease}
.sectionRow.is-collapsed .sectionToggle__icon{transform:rotate(-90deg)}
.dataRow.is-hidden-section{display:none !important}

.sec--senior-admin td{background:rgba(178,127,160,.85);color:#0b0b0b}
.sec--admin td{background:rgba(255,43,43,.85);color:#0b0b0b}
.sec--senior-mod td{background:rgba(255,154,210,.85);color:#0b0b0b}
.sec--mod td{background:rgba(246,180,107,.85);color:#0b0b0b}
.sec--support td{background:rgba(207,233,201,.85);color:#0b0b0b}
.sec--trial td{background:rgba(245,230,168,.85);color:#0b0b0b}
.sec--custom td{background:rgba(180,180,180,.35);color:#eaf6ff}

/* wcześniej .hot podświetlało na czerwono (np. tickety). Wyłączone na życzenie. */
.hot{background:transparent;font-weight:inherit}

/* kliknij-aby-edytować */
.adminTable td.js-editable{cursor:pointer;position:relative}
.adminTable td.js-editable:hover{background:rgba(255,255,255,.04)}
.adminTable td.js-editable.is-editing{background:rgba(255,255,255,.06)}

/* Podświetlenie całego wiersza po najechaniu (ułatwia czytanie) */
/* Podświetlenie całego wiersza (również pól "hot") */
.adminTable tr.dataRow:hover td{background:rgba(0,182,255,.10)!important}
.adminTable tr.dataRow:hover td.hot{background:rgba(0,182,255,.10)!important}
.adminTable td.js-editable.is-saving{opacity:.7}
.adminTable td.js-editable.is-error{outline:2px solid rgba(255,0,0,.35);outline-offset:-2px}
.cellEdit__input{width:100%;min-width:80px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.92);border-radius:10px;padding:8px 10px;font:inherit}
.cellEditVac{display:flex;gap:8px;align-items:center}
.cellEditVac .cellEdit__input{width:auto;min-width:140px}

/* modal szerszy dla formularza */
.modal__card--wide{max-width:min(980px,92vw)}

.form{padding:12px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.field span{color:var(--muted);font-size:12px}
.field input,.field select{
  padding:10px 11px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--text);outline:none;
}
.field input:focus,.field select:focus{border-color:rgba(0,182,255,.35)}

/* textarea (np. Notatki) */
.field textarea{
  padding:10px 11px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.35);
  color:var(--text);
  outline:none;
  resize:vertical;
}
.field textarea:focus{border-color:rgba(0,182,255,.35)}
.field textarea::placeholder{color:rgba(255,255,255,.45)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.row4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.form__actions{display:flex;gap:10px;margin-top:10px}

.hr{border:none;border-top:1px solid var(--line);margin:14px 0}

.tabs{display:flex;gap:8px;margin-bottom:12px}
.tab{padding:10px 12px;border-radius:12px;border:1px solid var(--line);color:var(--muted)}
.tab.is-active{border-color:rgba(0,182,255,.35);color:var(--text);background:rgba(0,182,255,.06)}

.check{display:flex;align-items:center;gap:10px;margin:8px 0;color:var(--text)}
.check input{width:18px;height:18px}

.rowSearch{display:flex;gap:10px;margin:0 0 12px 0}
.rowSearch input{
  flex:1;padding:10px 11px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--text);outline:none;
}

.simpleTable{width:100%;border-collapse:collapse}
.simpleTable th,.simpleTable td{border:1px solid rgba(255,255,255,.10);padding:8px 10px;font-size:13px}
.simpleTable thead th{background:#05070b;color:var(--cyan);text-transform:uppercase;font-weight:900}

.iframeWrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--panel);height:75vh}
.iframeWrap iframe{width:100%;height:100%;border:0}

/* Koło fortuny */
.wheelBox{display:grid;gap:14px;max-width:720px}
.wheelCanvasWrap{position:relative;width:520px;max-width:92vw}
.wheelCanvasWrap canvas{width:100%;height:auto;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);box-shadow:var(--shadow)}
.wheelPointer{position:absolute;left:50%;top:-6px;transform:translateX(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:24px solid rgba(0,182,255,.8);filter:drop-shadow(0 6px 14px rgba(0,0,0,.45))}
.wheelControls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.wheelResult{color:var(--text);font-weight:800}

/* Modal */
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:999}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal__card{position:relative;width:min(680px,92vw);max-height:80vh;overflow:auto;border-radius:18px;border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow)}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--line)}
.modal__title{font-weight:900;color:var(--cyan);text-transform:uppercase}
.modal__close{background:transparent;border:0;color:var(--text);font-size:26px;line-height:1;cursor:pointer}
.modal__body{padding:14px}
.modal__foot{padding:12px 14px;border-top:1px solid var(--line);display:flex;justify-content:flex-end}

.resultList{margin:10px 0 0 18px}
.resultList li{margin:4px 0}

.loginBody{display:grid;place-items:center;min-height:100vh}
.loginCard{
  width:min(420px,92vw);
  border:1px solid var(--line);border-radius:18px;background:var(--panel);
  padding:18px;box-shadow:var(--shadow)
}
.loginTitle{font-size:20px;font-weight:900;color:var(--cyan);text-transform:uppercase}
.loginSub{color:var(--muted);margin:6px 0 14px 0}
.loginHint{color:var(--muted);margin-top:12px;font-size:12px}

/* Nick jako link do notatek */
.nickLink{color:inherit;text-decoration:none;cursor:pointer}
.nickLink:hover{text-decoration:underline}

/* Sekcje: edycja kolorów (Ustawienia -> Sekcje tabeli) */
.inlineColors{display:inline-flex;align-items:center;gap:8px}
.inlineColors input[type="color"]{width:38px;height:28px;padding:0;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:transparent}

.inlineOrder{display:inline-flex;align-items:center;gap:8px}
.inlineOrder input[type="number"]{padding:6px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25);color:var(--text)}

/* Sekcje: strzałki góra/dół dla kolejności */
.orderCtrl{display:inline-flex;align-items:center;gap:8px;justify-content:center}
.orderCtrl__val{min-width:34px;text-align:center;font-weight:800;color:var(--text);opacity:.92}
.orderCtrl__btn{display:inline}
.orderCtrl .btn{width:34px;height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:10px;line-height:1}

/* ==============================
   Custom DARK SELECT
   (bo natywne <select> w Windows/Chrome nie daje stylować listy)
   Aktywacja: <select data-dark-select>
   ============================== */
.dark-select{position:relative;display:inline-block;width:100%}

/* ukryj natywny select, ale zostaw go dla submitu */
.dark-select__native{position:absolute;inset:0;opacity:0;pointer-events:none;width:100%;height:100%}

.dark-select__btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:#0b1118;color:#e6f0ff;border:1px solid rgba(90,140,200,.35);border-radius:12px;padding:10px 12px;outline:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.25)}
.dark-select__btn:focus{border-color:rgba(0,180,255,.7);box-shadow:0 0 0 3px rgba(0,180,255,.12), inset 0 0 0 1px rgba(0,0,0,.25)}
.dark-select__label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dark-select__caret{opacity:.9}

.dark-select__menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:9999;background:#0b1118;border:1px solid rgba(90,140,200,.35);border-radius:12px;padding:6px;max-height:320px;overflow:auto;box-shadow:0 16px 40px rgba(0,0,0,.45);display:none}
.dark-select.is-open .dark-select__menu{display:block}

.dark-select__item{width:100%;text-align:left;background:transparent;color:#e6f0ff;border:0;border-radius:10px;padding:10px 10px;cursor:pointer}
.dark-select__item:hover{background:rgba(0,180,255,.10)}
.dark-select__item.is-active{background:rgba(0,180,255,.18)}
.dark-select__item:disabled{opacity:.45;cursor:not-allowed}

/* =========================
   MODAL: DODAJ ADMINA (id="adminModal") — kompakt + bez poziomego scrolla
   ========================= */
#adminModal .modal__card--wide{
  max-width:min(1100px,94vw);
  max-height:92vh;
  overflow:hidden; /* usuń scroll na całym oknie */
}

#adminModal .modal__body{
  padding:10px 12px;
  overflow:hidden; /* brak pasków w środku */
}

#adminModal .form{padding:6px}
#adminModal .field{margin-bottom:6px;gap:4px}
#adminModal .field span{font-size:11px}

#adminModal .field input,
#adminModal .field select{
  padding:8px 10px;
  border-radius:12px;
  height:36px;
}

/* Siatki: krócej (mniej wysokości) + bez wypychania szerokości */
#adminModal .row2{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px}
#adminModal .row3{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 10px}
#adminModal .row4{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px 10px}

/* Wymuś brak poziomego scrolla */
#adminModal *{box-sizing:border-box;max-width:100%}
#adminModal input,#adminModal select{min-width:0}

/* Stopka */
#adminModal .modal__foot,
#adminModal .form__actions{margin-top:8px;gap:10px}

/* Na małych ekranach: mniej kolumn, żeby nie ściskać */
@media (max-width: 760px){
  #adminModal .row4{grid-template-columns:repeat(2,minmax(0,1fr))}
  #adminModal .row3{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* === DODAJ ADMINA – jeszcze mniejsze pola === */
/* Jeśli Twój modal ma inne ID niż #addAdminModal, podmień selektor */
#addAdminModal input[type="text"],
#addAdminModal input[type="number"],
#addAdminModal input[type="date"],
#addAdminModal select,
#addAdminModal textarea {
  height: 32px !important;
  padding: 6px 9px !important;
  font-size: 13px !important;
  border-radius: 10px !important;
}

/* Placeholder/tekst w inputach trochę mniejszy */
#addAdminModal input::placeholder,
#addAdminModal textarea::placeholder {
  font-size: 12px !important;
}

/* Labelki ciaśniej */
#addAdminModal label,
#addAdminModal .label {
  font-size: 11px !important;
  margin-bottom: 4px !important;
}

/* Mniejsze odstępy między polami */
#addAdminModal form {
  gap: 8px 12px !important;
}

/* Jeśli masz textarea w tym modalu */
#addAdminModal textarea {
  height: 64px !important;
}

/* === DODAJ ADMINA – super kompakt (v2) === */
#addAdminModal .modal__dialog{
  width: min(980px, calc(100vw - 32px)) !important;
}

#addAdminModal .modal__body{
  padding: 12px 14px !important;
}

/* ciaśniej w siatce */
#addAdminModal form{
  gap: 6px 10px !important;
}

/* mniejsze inputy */
#addAdminModal input[type="text"],
#addAdminModal input[type="number"],
#addAdminModal input[type="date"],
#addAdminModal select,
#addAdminModal textarea{
  height: 28px !important;
  padding: 5px 8px !important;
  font-size: 12px !important;
  border-radius: 9px !important;
}

#addAdminModal textarea{
  height: 56px !important;
}

/* labelki */
#addAdminModal label,
#addAdminModal .label{
  font-size: 10.5px !important;
  margin-bottom: 3px !important;
  letter-spacing: .2px;
}

/* footer ciaśniej */
#addAdminModal .modal__footer{
  padding: 10px 14px !important;
}

/* przyciski trochę mniejsze */
#addAdminModal .btn{
  padding: 7px 12px !important;
  font-size: 12px !important;
}

/* ------------------
   Notatki (multi) 
-------------------*/
.notes{display:flex; gap:14px; align-items:stretch;}
.notes__sidebar{width:260px; min-width:220px; border-right:1px solid var(--line); padding-right:14px;}
.notes__sidebarHead{display:flex; flex-direction:column; gap:10px; margin-bottom:10px;}
.notes__list{max-height:340px; overflow:auto; padding-right:6px;}
.notes__item{border:1px solid var(--line); border-radius:12px; padding:10px 10px; margin-bottom:10px; cursor:pointer; background:rgba(0,0,0,.18);}
.notes__item:hover{background:rgba(0,0,0,.28);}
.notes__item.is-active{border-color:rgba(0,182,255,.45); box-shadow:0 0 0 3px rgba(0,182,255,.12);}
.notes__itemTitle{font-weight:700; font-size:13px;}
.notes__itemMeta{font-size:12px; opacity:.75; margin-top:4px;}
.notes__editor{flex:1; min-width:260px;}
.notes__metaLine{font-size:12px; opacity:.75; margin-top:8px;}
.notes__actions{display:flex; align-items:center; justify-content:space-between; margin-top:10px; gap:10px;}

/* pewne przyciemnienie textarea notatek (przebija cache/stare reguły) */
#notesTextarea, .notes textarea{
  background: rgba(0,0,0,.35) !important;
  color: var(--text) !important;
  border: 1px solid var(--line) !important;
  border-radius: 12px !important;
  padding: 10px 11px !important;
}
#notesTextarea::placeholder{color:rgba(255,255,255,.45) !important;}


/* Uprawnienia ról — grupowanie */
.permGroups{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.permGroup{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.02);overflow:hidden}
.permGroup__title{cursor:pointer;list-style:none;padding:10px 12px;font-weight:800;color:var(--text);user-select:none}
.permGroup__title::-webkit-details-marker{display:none}
.permGroup__title:before{content:"▾";display:inline-block;margin-right:8px;opacity:.8;transform:translateY(-1px)}
.permGroup[open] .permGroup__title:before{content:"▾"}
.permGroup:not([open]) .permGroup__title:before{content:"▸"}
.permGroup__items{padding:10px 12px;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr;gap:8px}
@media (min-width: 860px){
  .permGroup__items{grid-template-columns:1fr 1fr}
}
