/* moonsite-style admin – svetla + tmava tema (cez premenne), responzivne */
:root{
  --radius:10px;
  /* SVETLA TEMA */
  --page-bg:#ffffff;
  --navy:#1f3a63;
  --blue:#2f6cb0;
  --link:#2f6cb0;
  --btn:#4e6aa6; --btn-d:#3d5688;
  --panel:#dbe6f7; --panel-line:#bcd0ec; --panel-soft:#eef3fb;
  --orange:#e8821e; --orange-d:#cf7115;
  --ink:#2b3a4a; --muted:#76828f; --line:#d8e0ea;
  --red:#c0392b; --green:#2e8b57;
  --field-bg:#ffffff; --field-text:#2b3a4a; --field-border:#d8e0ea;
  --row-hover:#f7faff; --code-bg:#eef2f7;
  --shadow:0 10px 30px rgba(31,58,99,.08);
}
[data-theme="dark"]{
  --page-bg:#0b1220;
  --navy:#e6edf6;
  --blue:#3b82f6;
  --link:#6fa8ed;
  --btn:#36507e; --btn-d:#2b4068;
  --panel:#16202e; --panel-line:#26344a; --panel-soft:#111a27;
  --orange:#f59e0b; --orange-d:#d98908;
  --ink:#cdd6e2; --muted:#8595a6; --line:#26344a;
  --red:#e0606e; --green:#56b98a;
  --field-bg:#0f1828; --field-text:#e6edf6; --field-border:#2a3a4f;
  --row-hover:#13202f; --code-bg:#13202f;
  --shadow:0 10px 30px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
body{margin:0;background:var(--page-bg);color:var(--ink);
  font-family:"Segoe UI",Roboto,"Helvetica Neue",Arial,"Open Sans",sans-serif;font-size:14px;line-height:1.45;
  transition:background .2s,color .2s}
a{color:var(--link)}
.wrap{max-width:1060px;margin:0 auto;padding:0 16px 40px}

/* hlavicka */
.brand{display:flex;align-items:center;justify-content:space-between;gap:16px;
  flex-wrap:wrap;padding:16px 4px 12px;border-bottom:2px solid var(--blue)}
.brand-left .logo{font-size:30px;font-weight:800;letter-spacing:-1px;line-height:1}
.logo .b1{color:var(--blue)} .logo .b2{color:var(--navy)}
.brand-left .sub{color:var(--muted);font-size:11px;letter-spacing:2px;margin-top:3px;text-transform:lowercase}
.brand-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.topnav{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.topnav a{color:var(--navy);text-decoration:none;font-weight:700;text-transform:uppercase;
  font-size:12.5px;letter-spacing:.5px;padding:6px 0;border-bottom:2px solid transparent}
.topnav a:hover{color:var(--orange)}
.topnav a.on{color:var(--orange);border-bottom-color:var(--orange)}
.topnav .who{color:var(--muted);font-weight:400;text-transform:none;font-size:12px}
.topnav .who a{color:var(--blue)}

/* prepinac temy */
.theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:var(--field-bg);color:var(--navy);cursor:pointer;font-size:16px;line-height:1;
  display:inline-flex;align-items:center;justify-content:center}
.theme-toggle:hover{border-color:var(--blue)}

/* hladanie */
.search{display:flex;gap:8px;margin:14px 0}
.search input{flex:1;padding:9px 12px;border:1px solid var(--field-border);border-radius:8px;font-size:14px;
  background:var(--field-bg);color:var(--field-text)}
.search input:focus{outline:none;border-color:var(--blue)}

main{padding-top:6px}

/* panely */
.panel{background:var(--panel-soft);border:1px solid var(--panel-line);border-radius:var(--radius);margin:16px 0;padding:16px}
fieldset.panel{border:1px solid var(--panel-line)}
fieldset.panel legend{padding:0 8px;color:var(--navy);font-weight:800;font-size:15px}
.panel-title{font-weight:800;color:var(--navy);font-size:16px;margin:18px 0 8px}

/* mriezka poli */
.grid{display:grid;gap:12px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:1fr 1fr 1fr}
.g4{grid-template-columns:repeat(4,1fr)}

.cell{display:flex;flex-direction:column;gap:5px}
.cell label{font-weight:700;color:var(--navy);font-size:12px}
.cell input,.cell select,.inp{padding:8px 10px;border:1px solid var(--field-border);border-radius:8px;
  background:var(--field-bg);color:var(--field-text);font-size:14px;width:100%}
.cell input:focus,.cell select:focus,.inp:focus{outline:none;border-color:var(--blue)}
.cell.olive label{color:var(--orange-d)}

/* STAV – farebne karty */
.statusrow{display:flex;flex-wrap:wrap;gap:10px}
.statuscard{flex:1 1 150px;display:flex;align-items:center;gap:9px;padding:11px 13px;cursor:pointer;
  border:2px solid var(--line);border-radius:10px;background:var(--field-bg);font-weight:600;color:var(--ink);
  transition:border-color .12s,background .12s}
.statuscard input{margin:0;accent-color:var(--blue)}
.statuscard::before{content:"";width:11px;height:11px;border-radius:50%;background:var(--muted);flex:0 0 auto}
.statuscard.s-pripojeny::before{background:var(--green)}
.statuscard.s-docasne::before{background:var(--orange)}
.statuscard.s-neplatic::before{background:var(--red)}
.statuscard.s-ukoncena::before{background:var(--muted)}
.statuscard:has(input:checked){border-color:var(--blue);background:var(--panel)}
.statuscard.s-pripojeny:has(input:checked){border-color:var(--green)}
.statuscard.s-docasne:has(input:checked){border-color:var(--orange)}
.statuscard.s-neplatic:has(input:checked){border-color:var(--red)}
.statuscard.s-ukoncena:has(input:checked){border-color:var(--muted)}

/* tlacidla */
.btns{margin:18px 0;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn{display:inline-block;background:var(--btn);color:#fff;border:none;padding:10px 22px;border-radius:22px;
  cursor:pointer;text-decoration:none;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  transition:background .15s}
.btn:hover{background:var(--btn-d)}
.btn.red{background:var(--red)} .btn.red:hover{filter:brightness(.9)}
.btn.gray{background:#8492a0} .btn.gray:hover{background:#6f7c8a}
.btn.orange{background:var(--orange)} .btn.orange:hover{background:var(--orange-d)}
.btn.sm{padding:6px 14px;font-size:11px;border-radius:16px}

/* tabulky */
.tablewrap{width:100%;overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
th,td{padding:9px 10px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
th{background:var(--panel);color:var(--navy);font-weight:700;font-size:12px;text-transform:uppercase;
  letter-spacing:.3px;border-bottom:2px solid var(--panel-line)}
tr:hover td{background:var(--row-hover)}

/* flash */
.flash{padding:11px 14px;margin:12px 0;border-radius:8px;border:1px solid;font-size:13px}
.flash.ok{background:rgba(46,139,87,.14);border-color:var(--green);color:var(--green)}
.flash.err{background:rgba(192,57,43,.14);border-color:var(--red);color:var(--red)}
.flash.info{background:rgba(47,108,176,.14);border-color:var(--blue);color:var(--link)}

/* login */
.login-box{max-width:330px;margin:13vh auto;border:1px solid var(--panel-line);border-radius:var(--radius);
  background:var(--field-bg);overflow:hidden;box-shadow:var(--shadow)}
.login-box h1{background:var(--blue);color:#fff;font-size:15px;margin:0;padding:14px 18px;font-weight:700}
.login-box .body{padding:18px}
.login-box input{width:100%;padding:10px;margin-bottom:10px;border:1px solid var(--field-border);border-radius:8px;
  font-size:14px;background:var(--field-bg);color:var(--field-text)}
.login-box input:focus{outline:none;border-color:var(--blue)}
.login-logo{text-align:center;font-size:26px;font-weight:800;letter-spacing:-1px;margin:0 0 4px}
.login-logo .b1{color:var(--blue)} .login-logo .b2{color:var(--navy)}

.muted{color:var(--muted);font-size:12px}
.pill{background:var(--orange);color:#fff;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700}
code{background:var(--code-bg);padding:1px 6px;border-radius:5px;font-size:12px}

/* ---------- MOBIL ---------- */
@media(max-width:720px){
  .g2,.g3,.g4{grid-template-columns:1fr}
  .brand{flex-direction:column;align-items:flex-start;gap:10px}
  .brand-right{width:100%;justify-content:space-between}
  .topnav{gap:14px}
  .statuscard{flex:1 1 100%}
  table{display:block;overflow-x:auto;white-space:nowrap}
  .btn{flex:1 1 auto;text-align:center}
}
@media(max-width:480px){
  .wrap{padding:0 10px 30px}
  .brand-left .logo{font-size:26px}
  .topnav a{font-size:12px}
}
