/* ─── Reset + Variables ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:      #f0f2f5;
  --white:   #ffffff;
  --bd:      #d8dce4;
  --bd2:     #b8beca;
  --tx:      #1a2540;
  --tx2:     #3d4f6e;
  --tx3:     #6b7a99;
  --tx4:     #9baabb;

  --blue:    #0052cc;
  --blue2:   #003d99;
  --blue-lt: #deeaff;
  --green:   #006644;
  --green-lt:#d4eddf;
  --red:     #c0392b;
  --red-lt:  #fce8e6;
  --ylw:     #7a5000;
  --ylw-lt:  #fff8e1;
  --ylw-bd:  #f5c842;
  --org:     #c05621;

  --sh1: 0 1px 3px rgba(0,0,0,.1);
  --sh2: 0 3px 12px rgba(0,0,0,.12);
  --sh3: 0 8px 28px rgba(0,0,0,.15);

  --r: 7px;
  --sans: 'IBM Plex Sans', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
}
html,body{height:100%;font-family:var(--sans);font-size:14px;color:var(--tx);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}

/* ─── App shell ──────────────────────────────────────────────── */
#app{display:grid;grid-template-columns:284px 1fr;grid-template-rows:52px 1fr;height:100vh;overflow:hidden}

/* ─── Topbar ─────────────────────────────────────────────────── */
#topbar{
  grid-column:1/-1;background:var(--blue);
  display:flex;align-items:center;padding:0 18px;gap:14px;
  box-shadow:0 2px 8px rgba(0,82,204,.35);z-index:200
}
.logo{font-size:16px;font-weight:700;color:#fff;display:flex;align-items:center;gap:9px}
.logo-v{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);
  border-radius:4px;padding:1px 7px;font-size:10.5px;font-weight:700;letter-spacing:.6px;color:#fff}
#top-firm{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);
  border-radius:16px;padding:4px 14px;font-size:12.5px;color:#fff;display:none;
  max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-indicators{margin-left:auto;display:flex;gap:18px}
.ind{display:flex;align-items:center;gap:6px;font-size:11.5px;color:rgba(255,255,255,.65)}
.dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);transition:background .3s;flex-shrink:0}
.dot.on{background:#4ade80;box-shadow:0 0 7px rgba(74,222,128,.7)}
.dot.blink{background:#fbbf24;animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── Sidebar ────────────────────────────────────────────────── */
#sidebar{background:var(--white);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden}
.s-sec{border-bottom:1px solid var(--bd);padding:13px 14px 15px}
.s-lbl{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--tx4);margin-bottom:10px}

.f{margin-bottom:8px}.f:last-child{margin-bottom:0}
.f label{display:block;font-size:11px;font-weight:600;color:var(--tx2);margin-bottom:3px}
.f input,.f select{
  width:100%;background:var(--bg);border:1.5px solid var(--bd);color:var(--tx);
  padding:6px 9px;border-radius:var(--r);font-family:var(--sans);font-size:12.5px;outline:none;transition:border .15s
}
.f input:focus,.f select:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,82,204,.1)}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:7px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:8px 16px;border-radius:var(--r);font-family:var(--sans);font-size:13px;
  font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;line-height:1}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:not(:disabled):hover{background:var(--blue2)}
.btn-ghost{background:transparent;border:1.5px solid var(--bd2);color:var(--tx2)}
.btn-ghost:not(:disabled):hover{border-color:var(--blue);color:var(--blue)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-full{width:100%;padding:10px}

/* Firm select */
#firm-sel{width:100%;background:var(--bg);border:1.5px solid var(--bd);color:var(--tx);
  padding:7px 9px;border-radius:var(--r);font-family:var(--sans);font-size:13px;
  outline:none;cursor:pointer;transition:border .15s}
#firm-sel:focus{border-color:var(--blue)}
#firm-info{margin-top:8px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);
  padding:8px 10px;font-size:11px;color:var(--tx3);line-height:1.85;display:none}

/* ─── Main area ──────────────────────────────────────────────── */
#main{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}

/* Period bar */
#pbar{background:var(--white);border-bottom:1px solid var(--bd);padding:10px 18px;
  display:flex;align-items:center;gap:12px;flex-shrink:0;box-shadow:var(--sh1)}
.pb-lbl{font-size:13px;font-weight:600;color:var(--tx2);white-space:nowrap}
.date-box{display:flex;align-items:center;gap:9px;background:var(--bg);
  border:2px solid var(--blue);border-radius:var(--r);padding:5px 12px}
.date-box span{font-size:12px;color:var(--tx3)}
.date-box input[type=date]{background:transparent;border:none;color:var(--tx);
  font-family:var(--sans);font-size:14px;font-weight:700;outline:none;cursor:pointer;min-width:128px}
.date-arrow{color:var(--tx3);font-size:16px}
#period-chip{flex:1;background:var(--ylw-lt);border:1.5px solid var(--ylw-bd);
  border-radius:var(--r);padding:6px 16px;text-align:center;
  font-size:13px;font-weight:500;color:var(--ylw);white-space:nowrap}
#period-chip b{font-size:14px;font-weight:800}

/* Content */
#content{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:14px 18px 0}

/* Tabs */
.tabs{display:flex;border-bottom:2px solid var(--bd);flex-shrink:0;margin-bottom:14px}
.tab{padding:9px 24px;font-size:13.5px;font-weight:600;cursor:pointer;color:var(--tx3);
  border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.tab:hover{color:var(--tx)}
.tab.on{color:var(--blue);border-bottom-color:var(--blue)}
.tab-panel{display:none;flex:1;flex-direction:column;overflow:hidden}
.tab-panel.on{display:flex}

/* Module grid – 2×4 or 2×4 */
.mgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;
  overflow-y:auto;flex:1;padding-bottom:14px;align-content:start}
.mgrid::-webkit-scrollbar{width:4px}
.mgrid::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}

/* Module card */
.mcard{background:var(--white);border:1.5px solid var(--bd);border-radius:10px;
  padding:14px;display:flex;flex-direction:column;gap:8px;
  box-shadow:var(--sh1);transition:box-shadow .2s,border-color .2s,transform .15s;position:relative;overflow:hidden}
.mcard::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--blue);border-radius:10px 10px 0 0;opacity:0;transition:opacity .2s}
.mcard:hover{box-shadow:var(--sh2);border-color:var(--blue);transform:translateY(-1px)}
.mcard:hover::after{opacity:1}

.mcard-top{display:flex;align-items:center;justify-content:space-between}
.mcard-icon{font-size:22px;line-height:1}
.mcard-tag{font-size:9px;font-weight:700;letter-spacing:.4px;padding:2px 7px;border-radius:3px;
  background:var(--blue-lt);color:var(--blue);border:1px solid rgba(0,82,204,.18)}
.mcard-cfg{background:var(--bg);border:1.5px solid var(--bd);border-radius:5px;
  width:26px;height:26px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12px;color:var(--tx3);transition:all .15s}
.mcard-cfg:hover{border-color:var(--blue);color:var(--blue)}

.mcard-title{font-size:14.5px;font-weight:700;color:var(--tx);line-height:1.2}
.mcard-sub{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);font-weight:500}

/* Date col selector */
.dcsel label{font-size:10px;font-weight:600;color:var(--tx3);letter-spacing:.5px;
  text-transform:uppercase;display:block;margin-bottom:3px}
.dcsel select{width:100%;font-size:11.5px;padding:4px 8px;border-radius:5px;
  border:1.5px solid var(--bd);background:var(--bg);font-family:var(--mono);outline:none;cursor:pointer}
.dcsel select:focus{border-color:var(--blue)}

/* Filter display */
.fdisp{background:var(--bg);border:1px solid var(--bd);border-radius:5px;
  padding:5px 8px;font-size:10.5px;min-height:27px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}
.fdisp.empty{color:var(--tx4);font-style:italic}
.ftag{background:var(--blue-lt);color:var(--blue);border-radius:3px;padding:1px 7px;font-size:10px;font-weight:600}

/* Module action button */
.mcard-btn{width:100%;padding:9px;border-radius:7px;font-size:12.5px;font-weight:700;
  border:none;cursor:pointer;font-family:var(--sans);letter-spacing:.1px;transition:all .15s}
.mcard-btn:disabled{opacity:.5;cursor:not-allowed}
.mcard-btn.exp{background:var(--blue);color:#fff}.mcard-btn.exp:hover:not(:disabled){background:var(--blue2)}
.mcard-btn.imp{background:var(--green-lt);color:var(--green);border:1.5px solid #57d9a3}
.mcard-btn.imp:hover:not(:disabled){background:#b8f0d0}

/* Status line under button */
.mcard-info{font-size:11px;text-align:center;min-height:15px;color:var(--tx3);transition:color .2s}
.mcard-info.ok{color:var(--green);font-weight:600}
.mcard-info.err{color:var(--red);font-weight:600}
.mcard-info.warn{color:var(--org);font-weight:600}

/* ─── Result panel ───────────────────────────────────────────── */
#result{background:var(--white);border:1.5px solid var(--bd);border-radius:10px;
  display:none;flex-direction:column;margin-top:11px;flex-shrink:0;max-height:300px;box-shadow:var(--sh1)}
#result.on{display:flex}
#res-bar{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;
  gap:9px;flex-shrink:0;background:var(--bg);border-radius:10px 10px 0 0}
#res-title{font-weight:700;font-size:13px}
.rbadge{padding:3px 10px;border-radius:4px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:5px}
.rbadge.ok{background:var(--green-lt);color:var(--green);border:1px solid #57d9a3}
.rbadge.info{background:var(--blue-lt);color:var(--blue);border:1px solid #7ab4ff}
#res-actions{margin-left:auto;display:flex;gap:6px}
#res-body{overflow:auto;flex:1}
#res-body::-webkit-scrollbar{width:5px;height:5px}
#res-body::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}

/* Data table */
table.dt{border-collapse:collapse;min-width:100%;font-size:12px}
.dt thead th{position:sticky;top:0;background:var(--bg);border-bottom:1px solid var(--bd);
  border-right:1px solid var(--bd);padding:6px 11px;text-align:left;font-size:10.5px;
  font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.dt tbody tr:hover{background:#f0f5ff}
.dt tbody td{padding:6px 11px;border-bottom:1px solid var(--bd);border-right:1px solid var(--bd);
  max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cv-null{color:var(--tx4);font-style:italic}.cv-num{color:var(--blue);text-align:right;font-family:var(--mono)}
.cv-date{color:#6d28d9;font-family:var(--mono);font-size:11px}
.master-row{cursor:pointer;background:#f8faff!important}.master-row:hover{background:#ebf0ff!important}
.tog{text-align:center;color:var(--blue);font-size:11px;font-weight:700;width:26px}
.det-wrap{background:#edf5ff}.det-inner{font-size:11px}
.det-inner td{padding:4px 11px;border-bottom:1px solid #d4e4ff}
.det-hdr th{padding:4px 11px;font-size:10px;font-weight:700;color:#1e40af;text-align:left;
  background:#dbeafe;white-space:nowrap;letter-spacing:.4px}

/* ─── Progress ───────────────────────────────────────────────── */
#progbar{background:var(--white);border-top:1px solid var(--bd);padding:8px 18px;
  display:flex;align-items:center;gap:11px;flex-shrink:0}
.prog-l{font-size:12px;font-weight:600;color:var(--tx2);min-width:52px}
.prog-t{flex:1;height:7px;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--bd)}
.prog-f{height:100%;background:var(--blue);border-radius:4px;transition:width .3s}
.prog-p{font-size:12px;color:var(--tx3);min-width:34px;text-align:right}

/* ─── Filter modal ───────────────────────────────────────────── */
#fmodal{position:fixed;inset:0;background:rgba(9,30,66,.38);z-index:500;
  display:none;align-items:center;justify-content:center}
#fmodal.on{display:flex}
.modal{background:#fff;border-radius:10px;padding:22px;width:380px;
  box-shadow:var(--sh3);animation:pop .15s ease}
@keyframes pop{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-title{font-size:15px;font-weight:700;margin-bottom:3px}
.modal-sub{font-size:12px;color:var(--tx3);margin-bottom:14px}
.modal-f{margin-bottom:10px}
.modal-f label{display:block;font-size:11px;font-weight:600;color:var(--tx2);margin-bottom:4px}
.modal-f input{width:100%;background:var(--bg);border:1.5px solid var(--bd2);color:var(--tx);
  padding:7px 9px;border-radius:var(--r);font-family:var(--mono);font-size:13px;outline:none}
.modal-f input:focus{border-color:var(--blue)}
.modal-cats{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;max-height:100px;overflow-y:auto}
.ccat{background:var(--blue-lt);color:var(--blue);border:1px solid rgba(0,82,204,.2);
  border-radius:3px;padding:2px 8px;font-size:10.5px;font-weight:600;cursor:pointer;transition:background .12s}
.ccat:hover{background:#c4d8ff}
.modal-acts{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}

/* ─── Toasts ─────────────────────────────────────────────────── */
#toasts{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:6px;z-index:999}
.toast{background:#fff;border:1px solid var(--bd);border-radius:var(--r);padding:10px 15px;
  font-size:13px;box-shadow:var(--sh2);display:flex;align-items:center;gap:9px;
  animation:tin .2s ease;min-width:220px;max-width:360px}
.toast.ok{border-left:3px solid #16a34a}.toast.err{border-left:3px solid var(--red)}
.toast.info{border-left:3px solid var(--blue)}.toast.warn{border-left:3px solid #d97706}
@keyframes tin{from{transform:translateX(12px);opacity:0}to{transform:none;opacity:1}}

/* ─── Spinner ────────────────────────────────────────────────── */
.spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;animation:rot .6s linear infinite;flex-shrink:0}
.spin.dk{border-color:rgba(0,82,204,.15);border-top-color:var(--blue)}
@keyframes rot{to{transform:rotate(360deg)}}

/* ─── Empty state ────────────────────────────────────────────── */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:36px;gap:10px;color:var(--tx3);height:100%;text-align:center}
.empty-i{font-size:38px;opacity:.25}.empty-t{font-size:15px;font-weight:700;color:var(--tx3)}
.empty-s{font-size:12px;color:var(--tx4);max-width:260px}
.disc-btn {
  width: 100%;
  padding: 8px 0;
  background: #ef4444;
  border: none;
  border-radius: 4px;
  color: white;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}

.disc-btn:hover:not([disabled]) {
  background: #dc2626;
}

.disc-btn:disabled {
  background: #e5e7eb;
  color: #9ca3af;
  cursor: not-allowed;
}
.btn-red {
  background: #ef4444;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 8px 0;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}

.btn-red:hover:not([disabled]) {
  background: #dc2626;
}

.btn-red:disabled {
  background: #e5e7eb;
  color: #9ca3af;
  cursor: not-allowed;
}

.lic-card {
  background:rgb(255, 255, 255);
  border-radius:10px;
  padding:16px;
  box-shadow:0 2px 8px rgba(0,0,0,0.06);
  border-left:4px solid #0b44a0;
  margin-bottom:20px;
}

/* Culori dinamice pentru cardul de licență */
.lic-card.active  { border-left: 4px solid #16a34a !important; }
.lic-card.expired { border-left: 4px solid #dc2626 !important; }
.lic-card.revoked { border-left: 4px solid #b91c1c !important; }
.lic-card.trial   { border-left: 4px solid #3b82f6 !important; }

.lic-header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:12px;
}

.lic-title {
  font-size:18px;
  font-weight:600;
  color:#1b4bbd;
}

.lic-status {
  font-size:14px;
  font-weight:500;
  color:#318a59;
}

.lic-body { font-size:14px; }

.lic-row {
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
}

.lic-row label {
  width:90px;
  color:#93bd31;
}

.lic-copy {
  background:none;
  border:none;
  cursor:pointer;
  font-size:16px;
}
/* Banner pentru cardul de licență */
.lic-warning {
  background: #fef3c7;
  color: #b45309;
  border-left: 4px solid #f97316;
  padding: 8px 12px;
  border-radius: 6px;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 500;
}
