:root{
  --bg:#070b14; --bg2:#0b1120; --panel:rgba(18,27,45,.62); --panel-brd:rgba(90,130,200,.18);
  --cyan:#22d3ee; --cyan-d:#0891b2; --mag:#f472b6; --violet:#7c5cff; --green:#34d399;
  --orange:#fb923c; --red:#f43f5e; --txt:#dbe7ff; --muted:#7f93b8; --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--txt); font-family:"Inter",system-ui,Segoe UI,Roboto,sans-serif;
  font-size:14px; line-height:1.5; overflow-x:hidden;
}
a{color:var(--cyan); text-decoration:none}
h1{font-size:22px;letter-spacing:.4px;margin:0}
h2{font-size:15px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin:0 0 14px}

/* ---- pozadí ---- */
.bg-grid{position:fixed;inset:0;z-index:-2;
  background:
    linear-gradient(transparent 0,transparent 39px,rgba(80,130,210,.045) 40px) 0 0/40px 40px,
    linear-gradient(90deg,transparent 0,transparent 39px,rgba(80,130,210,.045) 40px) 0 0/40px 40px,
    radial-gradient(circle at 50% 0,#0c1530,var(--bg) 60%);}
.bg-glow{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(600px 300px at 12% -5%,rgba(124,92,255,.18),transparent 70%),
    radial-gradient(600px 320px at 95% 8%,rgba(34,211,238,.14),transparent 70%);}

/* ---- shell ---- */
.shell{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  padding:22px 16px;border-right:1px solid var(--panel-brd);
  background:linear-gradient(180deg,rgba(13,20,38,.8),rgba(7,11,20,.6));backdrop-filter:blur(8px)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:19px;letter-spacing:1px;margin-bottom:26px}
.brand-mark{color:var(--cyan);filter:drop-shadow(0 0 8px var(--cyan));font-size:22px}
.brand-name small,.login-brand small{display:block;font-size:10px;letter-spacing:3px;color:var(--muted);font-weight:500}
.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar nav a{padding:11px 14px;border-radius:10px;color:var(--muted);font-weight:500;transition:.18s;border:1px solid transparent}
.sidebar nav a:hover{color:var(--txt);background:rgba(124,92,255,.08)}
.sidebar nav a.active{color:#fff;background:linear-gradient(90deg,rgba(34,211,238,.16),rgba(124,92,255,.12));
  border-color:rgba(34,211,238,.3);box-shadow:0 0 18px rgba(34,211,238,.12) inset}
.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;font-size:12px}
.sidebar-foot .user{color:var(--muted)}
.logout{color:var(--muted)} .logout:hover{color:var(--red)}

.content{padding:30px 34px;max-width:1180px}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}

/* ---- glass / karty ---- */
.glass{background:var(--panel);border:1px solid var(--panel-brd);border-radius:16px;
  backdrop-filter:blur(14px);box-shadow:0 10px 40px rgba(0,0,0,.35)}
.card{padding:22px 24px;margin-bottom:22px}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px}
.cert-filter{flex:1;max-width:340px;margin:0;padding:8px 12px;font-size:13px}

/* ---- statistiky ---- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}
.stat{padding:20px;position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,211,238,.18),transparent 70%)}
.stat-num{font-size:34px;font-weight:700;font-family:var(--mono);background:linear-gradient(90deg,#fff,var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-lbl{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.stat.danger .stat-num{background:linear-gradient(90deg,#fff,var(--red));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---- tabulky ---- */
table.grid{width:100%;border-collapse:collapse}
table.grid th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);
  padding:8px 12px;border-bottom:1px solid var(--panel-brd)}
table.grid td{padding:8px 12px;border-bottom:1px solid rgba(90,130,200,.07);vertical-align:middle}
table.grid tbody tr:hover{background:rgba(124,92,255,.05)}
.cn{font-weight:600}.san{font-size:11px;color:var(--muted);margin-top:2px;cursor:help}
.nowrap{white-space:nowrap}
.row-actions{display:flex;gap:6px;flex-wrap:nowrap;align-items:center;justify-content:flex-end}
.row-actions form{margin:0}
.btn-icon{padding:6px 9px}
.cust-tag{font-size:10px;color:var(--violet);background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.25);
  border-radius:20px;padding:1px 8px;font-weight:500;margin-left:6px;vertical-align:middle}
.mono{font-family:var(--mono);font-size:12px}
.muted{color:var(--muted)}
.row-warn{box-shadow:inset 3px 0 0 var(--orange)}
.row-danger{box-shadow:inset 3px 0 0 var(--red)}
.empty{text-align:center;color:var(--muted);padding:26px}
.days{font-family:var(--mono);font-weight:600;padding:2px 8px;border-radius:20px;font-size:12px;white-space:nowrap}
.d-green{color:var(--green);background:rgba(52,211,153,.1)}
.d-orange{color:var(--orange);background:rgba(251,146,60,.12)}
.d-red{color:var(--red);background:rgba(244,63,94,.14)}

/* ---- pills ---- */
.pill{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.4px;
  border:1px solid transparent}
.pill-warn{color:var(--orange);background:rgba(251,146,60,.12);border-color:rgba(251,146,60,.3)}
.pill-demo{color:var(--violet);background:rgba(124,92,255,.14);border-color:rgba(124,92,255,.35)}
.phase-draft{color:var(--muted);background:rgba(127,147,184,.12)}
.phase-ordered{color:var(--cyan);background:rgba(34,211,238,.12)}
.phase-awaiting_dcv{color:var(--orange);background:rgba(251,146,60,.14);border-color:rgba(251,146,60,.3);animation:pulse 2s infinite}
.phase-validating{color:var(--violet);background:rgba(124,92,255,.14)}
.phase-issued{color:var(--green);background:rgba(52,211,153,.14)}
.phase-downloaded{color:var(--green);background:rgba(52,211,153,.2);border-color:rgba(52,211,153,.4)}
.phase-failed,.phase-cancelled{color:var(--red);background:rgba(244,63,94,.14)}
.renew-detected{color:var(--cyan);background:rgba(34,211,238,.12)}
.renew-notified{color:var(--orange);background:rgba(251,146,60,.14);border-color:rgba(251,146,60,.3);animation:pulse 2s infinite}
.renew-approved{color:var(--violet);background:rgba(124,92,255,.14)}
.renew-ordered{color:var(--violet);background:rgba(124,92,255,.18)}
.renew-done{color:var(--green);background:rgba(52,211,153,.2);border-color:rgba(52,211,153,.4)}
.renew-rejected,.renew-failed{color:var(--red);background:rgba(244,63,94,.14)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(251,146,60,.4)}50%{box-shadow:0 0 0 5px rgba(251,146,60,0)}}

/* ---- phase track ---- */
.phase-track{display:flex;gap:6px;margin-bottom:24px;flex-wrap:wrap}
.phase-step{flex:1;min-width:90px;text-align:center;padding:12px 6px;border-radius:12px;font-size:12px;color:var(--muted);
  border:1px solid var(--panel-brd);background:rgba(18,27,45,.4);position:relative}
.phase-step .dot{display:block;width:10px;height:10px;border-radius:50%;margin:0 auto 8px;background:#26324d}
.phase-step.done{color:var(--cyan)} .phase-step.done .dot{background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.phase-step.current{color:#fff;border-color:var(--cyan);box-shadow:0 0 22px rgba(34,211,238,.18)}
.phase-step.current .dot{background:var(--mag);box-shadow:0 0 12px var(--mag);animation:pulse 1.6s infinite}

/* ---- formulář ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
fieldset{border:1px solid var(--panel-brd);border-radius:12px;padding:16px 18px;margin:0}
legend{padding:0 8px;color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:1px}
label{display:block;margin:10px 0;font-size:12px;color:var(--muted)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{width:100%;margin-top:5px;padding:10px 12px;border-radius:10px;background:rgba(7,11,20,.7);
  border:1px solid var(--panel-brd);color:var(--txt);font-family:inherit;font-size:13px;transition:.16s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.12)}
.hint{font-size:11px;color:var(--muted);margin:8px 0 0}
.form-actions{display:flex;align-items:center;justify-content:space-between;margin-top:22px;gap:18px;flex-wrap:wrap}
.check{display:flex;align-items:center;gap:10px;color:var(--txt)}
.check input{width:auto;margin:0}

/* ---- tlačítka ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;cursor:pointer;
  font-weight:600;font-size:13px;color:var(--txt);background:rgba(124,92,255,.1);
  border:1px solid var(--panel-brd);transition:.16s}
.btn:hover{border-color:var(--cyan);background:rgba(34,211,238,.12)}
.btn-sm{padding:6px 11px;font-size:12px}
.btn-primary{background:linear-gradient(90deg,var(--cyan-d),var(--violet));border:none;color:#fff;
  box-shadow:0 6px 20px rgba(34,211,238,.25)}
.btn-primary:hover{filter:brightness(1.12)}

/* ---- detail / kv ---- */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.detail-grid .card:first-child{grid-row:span 2}
table.kv td{padding:7px 4px;border-bottom:1px solid rgba(90,130,200,.07)}
table.kv td:first-child{color:var(--muted);width:38%;font-size:12px}
.code{background:#05080f;border:1px solid var(--panel-brd);border-radius:10px;padding:14px;overflow:auto;
  font-family:var(--mono);font-size:11.5px;color:#9fe9ff;white-space:pre-wrap;word-break:break-all}
.files{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
details summary{cursor:pointer;color:var(--cyan);font-size:12px;margin-top:8px}

/* ---- flash ---- */
.flashes{margin-bottom:14px}
.flash{padding:11px 16px;border-radius:10px;margin-bottom:8px;font-size:13px;border:1px solid}
.flash-ok{color:var(--green);background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.3)}
.flash-error{color:var(--red);background:rgba(244,63,94,.1);border-color:rgba(244,63,94,.3)}
.flash-warn{color:var(--orange);background:rgba(251,146,60,.1);border-color:rgba(251,146,60,.3)}

/* ---- logy ---- */
.logfilter{display:flex;gap:12px;padding:16px 18px}
.logfilter select{width:auto}
table.log td{font-size:12.5px}
.pill.lvl{font-family:var(--mono)}
.lvl-INFO{color:var(--cyan);background:rgba(34,211,238,.1)}
.lvl-DEBUG{color:var(--muted);background:rgba(127,147,184,.1)}
.lvl-WARN{color:var(--orange);background:rgba(251,146,60,.12)}
.lvl-ERROR{color:var(--red);background:rgba(244,63,94,.14)}
tr.lvl-ERROR td{background:rgba(244,63,94,.05)}

/* ---- live ticker ---- */
.ticker{position:fixed;right:18px;bottom:18px;width:330px;max-height:42vh;display:flex;flex-direction:column;
  background:rgba(8,12,22,.86);border:1px solid var(--panel-brd);border-radius:14px;backdrop-filter:blur(12px);
  box-shadow:0 12px 40px rgba(0,0,0,.5);overflow:hidden;z-index:50;font-size:11.5px}
.ticker-head{padding:8px 14px;color:var(--mag);font-family:var(--mono);font-weight:700;letter-spacing:1px;
  border-bottom:1px solid var(--panel-brd)}
.ticker-body{overflow-y:auto;padding:6px 0}
.ticker-row{padding:4px 14px;display:flex;gap:8px;border-bottom:1px solid rgba(90,130,200,.05)}
.ticker-row .t{color:var(--muted);font-family:var(--mono)}
.ticker-row.l-ERROR{color:var(--red)} .ticker-row.l-WARN{color:var(--orange)}

/* ---- login ---- */
.login-body{display:flex} .login-wrap{margin:auto;width:100%;display:flex;justify-content:center;padding:40px}
.login-card{width:360px;padding:34px 30px;display:flex;flex-direction:column}
.login-brand{font-size:24px;font-weight:700;letter-spacing:2px;text-align:center}
.login-sub{text-align:center;color:var(--muted);font-size:12px;margin:6px 0 20px}
.login-card label{color:var(--muted)}
.login-card .btn{margin-top:16px;justify-content:center}
.login-foot{text-align:center;color:var(--muted);font-size:11px;margin-top:18px;font-family:var(--mono)}

/* ---- kontextová nápověda (tooltip, CSS-only) ---- */
.help-tip{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;
  border-radius:50%;border:1px solid var(--panel-brd);color:var(--muted);font-size:10px;font-weight:700;
  margin-left:6px;cursor:help;vertical-align:middle}
.help-tip:hover{color:var(--cyan);border-color:var(--cyan)}
legend .help-tip{margin-left:8px}
/* generický tooltip pro JAKOUKOLI položku s atributem data-tip (tlačítka, pilulky, dlaždice…) */
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%);background:#05080f;border:1px solid var(--cyan);border-radius:8px;
  padding:8px 11px;width:max-content;max-width:260px;font-size:11.5px;font-weight:400;color:var(--txt);
  line-height:1.45;opacity:0;visibility:hidden;pointer-events:none;transition:.15s;z-index:90;
  box-shadow:0 10px 30px rgba(0,0,0,.6);white-space:normal;text-align:left;letter-spacing:0;text-transform:none}
[data-tip]:hover::after{opacity:1;visibility:visible}

/* ---- nápověda ---- */
.help-wrap{display:grid;grid-template-columns:230px 1fr;gap:22px;align-items:start}
.help-toc{padding:16px 18px;position:sticky;top:20px;display:flex;flex-direction:column;gap:2px}
.help-toc strong{color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.help-toc a{color:var(--muted);padding:5px 8px;border-radius:8px;font-size:13px}
.help-toc a:hover{color:var(--txt);background:rgba(124,92,255,.1)}
.help-body section{scroll-margin-top:20px}
.help-body h2{color:var(--txt);font-size:16px;text-transform:none;letter-spacing:.3px;margin-bottom:12px}
.help-body ul,.help-body ol{margin:8px 0;padding-left:22px}
.help-body li{margin:5px 0}
.help-body code{background:#05080f;border:1px solid var(--panel-brd);border-radius:6px;
  padding:1px 6px;font-family:var(--mono);font-size:12px;color:#9fe9ff}
.help-flow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:6px 0 14px;line-height:2}
.help-body table.kv td:first-child{width:42%;color:var(--txt);font-weight:500}

/* ---- admin ---- */
.head-actions{font-size:12px;color:var(--muted)}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.adm-group{margin-bottom:18px}
.adm-rows{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-top:6px}
.adm-row{display:flex;flex-direction:column;margin:6px 0}
.adm-row .adm-label{font-size:12px;color:var(--muted);margin-bottom:4px}
.adm-row.adm-bool{flex-direction:row;align-items:center;gap:10px}
.adm-row.adm-bool .adm-label{margin:0;order:2;color:var(--txt)}
.adm-row.adm-bool input{width:auto;margin:0;order:1}
.admin-grid .card h2{margin-bottom:8px}

@media(max-width:900px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap}
  .admin-grid,.adm-rows{grid-template-columns:1fr}
  .form-grid,.detail-grid,.stats{grid-template-columns:1fr}.ticker{display:none}}
