:root{
  --bg:#06030d;
  --bg-2:#0b0617;
  --ink:#f5f1ff;
  --ink-dim:#b7a8d6;
  --ink-mute:#6e5f8c;
  --violet:#8a3bff;
  --violet-2:#b070ff;
  --violet-deep:#4a1a9e;
  --line: rgba(176,112,255,.22);
  --card: rgba(138,59,255,.09);
  --card-strong: rgba(138,59,255,.18);
  --glass: rgba(255,255,255,.03);
  --ok:#48e3a4;
  --warn:#ffb84d;
  --err:#ff6b8a;
  --sidebar-w: 72px;
  --sidebar-w-expanded: 260px;
  --topbar-h: 56px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;color:var(--ink);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
html{background:var(--bg)}
body{
  overflow-x:hidden;min-height:100vh;padding-left:var(--sidebar-w);
  transition:padding-left .25s ease;
  background:
    radial-gradient(1200px 700px at 50% 110%, rgba(160,90,255,.35), transparent 60%),
    radial-gradient(900px 500px at 85% 100%, rgba(255,120,220,.18), transparent 60%),
    linear-gradient(180deg,#06030d 0%, #0a0417 60%, #160a33 100%) fixed;
}
body.sb-expanded{padding-left:var(--sidebar-w-expanded)}
a{color:inherit}

/* Global decorative background — fixed, behind everything */
.app-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.app-bg .curves{position:absolute;inset:0;pointer-events:none}
.app-bg .curves svg{width:100%;height:100%;display:block}
.app-bg .noise{
  position:absolute;inset:0;pointer-events:none;opacity:.25;mix-blend-mode:overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.6  0 0 0 0 0.4  0 0 0 0 0.9  0 0 0 0.35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.app-bg .orb{position:absolute;width:240px;height:240px;border-radius:50%;filter:blur(50px);opacity:.45}
.app-bg .orb.l{left:-80px;bottom:-60px;background:radial-gradient(circle,#ff6fd8, transparent 60%)}
.app-bg .orb.r{right:-80px;top:30%;background:radial-gradient(circle,#7a2bff, transparent 60%)}

/* ===== Sidebar ===== */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:30;
  background:linear-gradient(180deg, rgba(14,6,34,.94), rgba(10,3,26,.97));
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:stretch;padding:18px 14px;gap:4px;
  backdrop-filter:blur(16px);
  transition:width .25s ease, left .25s ease;
}
.sidebar.expanded{width:var(--sidebar-w-expanded)}

/* Toggle pilulă pe marginea sidebar-ului (doar desktop) */
.sb-toggle{
  position:absolute;top:48px;right:-13px;z-index:40;
  width:26px;height:26px;border-radius:50%;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(40,18,80,.95),rgba(20,8,44,.98));
  color:var(--ink-dim);cursor:pointer;display:grid;place-items:center;
  box-shadow:0 6px 16px -6px rgba(0,0,0,.6);
  transition:background .15s, color .15s, transform .2s;
}
.sb-toggle:hover{background:rgba(138,59,255,.3);color:#fff}
.sb-toggle svg{transition:transform .25s ease}
.sidebar.expanded .sb-toggle svg{transform:rotate(180deg)}

.sidebar .sb-logo{
  width:44px;height:44px;border-radius:12px;display:grid;grid-template-columns:44px 1fr;place-items:center;
  background:linear-gradient(180deg,#9b4dff,#5c17c9);color:#fff;
  box-shadow:0 8px 20px -8px rgba(138,59,255,.7), 0 0 0 1px rgba(255,255,255,.08) inset;
  margin-bottom:14px;flex-shrink:0;overflow:hidden;text-decoration:none;
  transition:width .25s ease;
}
.sidebar.expanded .sb-logo{width:100%;justify-self:stretch}
.sidebar .sb-logo .brand-txt{
  display:none;font-weight:700;font-size:12.5px;letter-spacing:.02em;white-space:nowrap;
  text-align:left;padding:0 12px 0 4px;
  font-family:Tahoma,Geneva,Verdana,sans-serif;
  overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%;
}
.sidebar.expanded .sb-logo .brand-txt{display:block}

.sidebar .sb-nav{display:flex;flex-direction:column;gap:4px;flex:1;align-items:stretch;padding-top:6px;width:100%}
.sidebar .nav-item{
  width:44px;height:44px;border-radius:12px;display:grid;grid-template-columns:44px 1fr;place-items:center;
  color:var(--ink-dim);background:transparent;border:1px solid transparent;
  cursor:pointer;transition:background .15s, color .15s, border-color .15s, width .25s ease;
  position:relative;text-decoration:none;overflow:hidden;
}
.sidebar.expanded .nav-item{width:100%}
.sidebar .nav-item:hover{background:rgba(138,59,255,.15);color:#fff}
.sidebar .nav-item.active{
  background:rgba(138,59,255,.22);color:#fff;border-color:var(--line);
  box-shadow:0 0 0 1px rgba(255,255,255,.04) inset, 0 8px 20px -10px rgba(138,59,255,.55);
}
.sidebar .nav-item.active::before{
  content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);
  width:3px;height:22px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#b070ff,#6d20d8);
}
.sidebar .nav-item .label{
  display:none;font-size:13px;font-weight:600;letter-spacing:.01em;white-space:nowrap;
  text-align:left;padding-right:12px;color:inherit;
}
.sidebar.expanded .nav-item .label{display:block}
.sidebar .nav-item .tip{
  position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);
  white-space:nowrap;padding:6px 10px;border-radius:8px;
  background:rgba(20,8,44,.96);border:1px solid var(--line);
  font-size:12px;color:var(--ink);opacity:0;pointer-events:none;transition:opacity .12s;
  box-shadow:0 10px 24px -10px rgba(0,0,0,.6);z-index:50;
}
.sidebar:not(.expanded) .nav-item:hover .tip{opacity:1}

.sidebar .sb-foot{display:flex;flex-direction:column;gap:6px;padding-bottom:4px;align-items:stretch;width:100%}

/* User chip în sidebar — colapsat = avatar + flyout; expandat = avatar + nume + buton logout */
.sidebar .sb-user{
  position:relative;width:44px;height:44px;display:grid;grid-template-columns:44px 1fr;
  align-items:center;overflow:visible;cursor:pointer;
  border-radius:12px;padding:0;border:1px solid transparent;
  transition:width .25s ease, background .15s, border-color .15s;
}
.sidebar.expanded .sb-user{
  width:100%;padding:6px 8px;border-color:var(--line);
  background:linear-gradient(180deg, rgba(40,18,80,.35), rgba(20,8,44,.45));
}
.sidebar .sb-user:hover{background:rgba(138,59,255,.12)}
.sidebar .sb-user .sb-user-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,#6d20d8,#b070ff);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;
  border:2px solid rgba(255,255,255,.12);
  transition:transform .12s, box-shadow .15s;
}
.sidebar .sb-user:hover .sb-user-avatar{transform:scale(1.05);box-shadow:0 8px 24px -8px rgba(138,59,255,.7)}
.sidebar .sb-user .sb-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.sidebar .sb-user .sb-user-info{
  display:none;min-width:0;padding:0 8px;text-align:left;
}
.sidebar.expanded .sb-user .sb-user-info{display:block}
.sidebar .sb-user .sb-user-info .nm{
  font-size:13px;font-weight:700;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sidebar .sb-user .sb-user-info .role{
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--violet-2);font-weight:700;
}
.sidebar .sb-user .sb-user-info .role.supervisor{color:var(--ok)}
.sidebar .sb-user .sb-user-info .role.admin{color:var(--warn)}

/* Logout button (în sb-foot, vizibil doar când expanded) */
.sb-logout-btn{
  display:none;width:100%;padding:10px 12px;border-radius:10px;
  background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.05em;
  cursor:pointer;align-items:center;gap:10px;justify-content:flex-start;
  transition:all .15s;
}
.sidebar.expanded .sb-logout-btn{display:flex}
.sb-logout-btn:hover{background:rgba(255,107,138,.12);color:var(--err);border-color:rgba(255,107,138,.5)}

/* Flyout menu (apare la click pe avatar când sidebar e colapsat) */
.sb-user-menu{
  position:absolute;left:calc(100% + 14px);bottom:0;min-width:240px;z-index:60;
  border-radius:14px;padding:8px;
  background:linear-gradient(180deg,rgba(40,18,80,.97),rgba(20,8,44,.98));
  border:1px solid var(--line);
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
  display:none;
}
.sb-user-menu.open{display:block}
.sb-user-menu .info{padding:10px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.sb-user-menu .info .nm{font-weight:700;color:#fff;font-size:14px;margin-bottom:2px}
.sb-user-menu .info .email{font-size:12px;color:var(--ink-dim);word-break:break-all}
.sb-user-menu .info .role-badge{
  display:inline-block;margin-top:6px;padding:3px 8px;border-radius:999px;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  background:rgba(138,59,255,.2);color:var(--violet-2);border:1px solid var(--line);
}
.sb-user-menu .info .role-badge.supervisor{background:rgba(72,227,164,.2);color:var(--ok);border-color:rgba(72,227,164,.4)}
.sb-user-menu .info .role-badge.admin{background:rgba(255,184,77,.2);color:var(--warn);border-color:rgba(255,184,77,.4)}
.sb-user-menu button{
  width:100%;padding:10px 12px;background:transparent;border:none;color:var(--ink);
  font-size:13px;text-align:left;cursor:pointer;border-radius:8px;font-family:inherit;
  display:flex;align-items:center;gap:10px;
}
.sb-user-menu button:hover{background:rgba(138,59,255,.15)}
.sb-user-menu button.danger:hover{background:rgba(255,107,138,.15);color:var(--err)}
.sidebar.expanded .sb-user-menu{display:none !important} /* în expanded avem logout explicit */

/* Mobile top bar (hamburger + brand) — ascuns pe desktop */
.mobile-topbar{display:none}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:25;backdrop-filter:blur(2px)}
.mobile-overlay.show{display:block}

/* ===== SPA pages ===== */
.spa-page{display:none}
.spa-page.active{display:block}
.page-wip{
  position:relative;z-index:4;margin-top:80px;padding:80px 40px;text-align:center;
  border-radius:22px;border:1px dashed var(--line);
  background:linear-gradient(180deg, rgba(30,12,66,.4), rgba(14,6,34,.5));
  color:var(--ink-dim);
}
.page-wip h2{color:#fff;font-size:32px;font-weight:700;margin:0 0 10px;letter-spacing:-.02em}
.page-wip p{margin:0;font-size:14px}

/* ===== Page header (title + stats pills) ===== */
.page-header{
  position:relative;z-index:4;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-top:40px;flex-wrap:wrap;
}
.page-header .kicker{font-size:11px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:6px}
.page-header h1{font-weight:700;font-size:44px;margin:0;color:#fff;letter-spacing:-.02em;line-height:1.05}
.stats-pills{display:flex;gap:10px;flex-wrap:wrap}
.spill{
  min-width:120px;padding:10px 16px;border-radius:14px;
  background:linear-gradient(180deg, rgba(40,18,80,.55), rgba(20,8,44,.55));
  border:1px solid var(--line);backdrop-filter:blur(10px);
}
.spill .n{font-weight:700;font-size:22px;color:#fff;line-height:1.1;letter-spacing:-.02em}
.spill .l{font-size:11px;color:var(--ink-dim);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}

/* ===== Filter bar ===== */
.filter-bar{
  position:relative;z-index:4;margin-top:24px;
  padding:16px;border-radius:18px;
  background:linear-gradient(180deg, rgba(30,12,66,.5), rgba(14,6,34,.55));
  border:1px solid var(--line);backdrop-filter:blur(12px);
  display:flex;flex-direction:column;gap:12px;
}
.fb-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.period-chips{display:flex;gap:6px;flex-wrap:wrap}
.period-chip{
  padding:8px 14px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);color:var(--ink-dim);font-size:12px;font-weight:600;
  letter-spacing:.05em;cursor:pointer;font-family:inherit;transition:all .15s;
}
.period-chip:hover{background:rgba(138,59,255,.12);color:#fff}
.period-chip.active{background:rgba(138,59,255,.25);color:#fff;border-color:var(--violet-2)}
.date-range{
  display:inline-flex;align-items:center;gap:6px;padding:4px 8px;
  border-radius:10px;border:1px solid var(--line);background:rgba(10,3,34,.4);
}
.date-range input[type=date]{
  padding:6px 8px;border:none;background:transparent;color:var(--ink);
  font-family:inherit;font-size:12px;outline:none;min-width:120px;
  color-scheme:dark;
}
.date-range span{color:var(--ink-mute);font-size:12px}
.search-input{
  display:inline-flex;align-items:center;gap:8px;padding:8px 12px;flex:1;min-width:220px;
  border-radius:10px;border:1px solid var(--line);background:rgba(10,3,34,.4);
  transition:border .15s;
}
.search-input:focus-within{border-color:var(--violet-2)}
.search-input svg{flex-shrink:0;color:var(--ink-mute)}
.search-input input{
  flex:1;border:none;background:transparent;color:var(--ink);
  font-family:inherit;font-size:13px;outline:none;
}
.filter-select{
  padding:9px 32px 9px 12px;border-radius:10px;border:1px solid var(--line);
  background:rgba(10,3,34,.4);color:var(--ink);font-family:inherit;font-size:13px;
  outline:none;cursor:pointer;min-width:150px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1 L6 6 L11 1' stroke='%23b7a8d6' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;
  appearance:none;-webkit-appearance:none;
}
.filter-select:focus{border-color:var(--violet-2)}
.filter-select option{background:#1a0a3a;color:#fff}
.btn-ghost-sm{
  padding:9px 14px;border-radius:10px;border:1px solid var(--line);
  background:transparent;color:var(--ink-dim);font-family:inherit;font-size:12px;
  font-weight:600;cursor:pointer;letter-spacing:.05em;transition:all .15s;
}
.btn-ghost-sm:hover{background:rgba(255,107,138,.12);color:var(--err);border-color:rgba(255,107,138,.4)}

/* ===== ANPR grid ===== */
.anpr-grid{
  position:relative;z-index:4;margin-top:20px;display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:16px;
}
.anpr-card{
  border-radius:16px;border:1px solid var(--line);overflow:hidden;
  background:linear-gradient(180deg, rgba(30,12,66,.55), rgba(14,6,34,.6));
  backdrop-filter:blur(8px);
  display:flex;flex-direction:column;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.02) inset;
  cursor:pointer;transition:transform .15s, box-shadow .15s;
}
.anpr-card:hover{transform:translateY(-2px);box-shadow:0 30px 60px -20px rgba(138,59,255,.35), 0 0 0 1px rgba(176,112,255,.25) inset}
.anpr-card .img-wrap{aspect-ratio:16/9;background:#0a0322;overflow:hidden;position:relative}
.anpr-card .img-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.anpr-card .img-wrap .no-img{
  width:100%;height:100%;display:grid;place-items:center;
  color:var(--ink-mute);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
}
.anpr-card .country-badge{
  position:absolute;top:8px;left:8px;font-size:10px;font-weight:700;letter-spacing:.12em;
  padding:4px 8px;border-radius:6px;background:rgba(10,3,34,.85);
  border:1px solid var(--line);color:#e6d8ff;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;line-height:1;
}
.anpr-card .country-badge .fi{
  width:18px;height:13px;border-radius:2px;
  box-shadow:0 0 0 1px rgba(255,255,255,.15);
}
.anpr-card .country-badge .iso{font-size:10px;letter-spacing:.12em}
.anpr-card .conf-badge{
  position:absolute;top:8px;right:8px;font-size:10px;font-weight:700;
  padding:4px 8px;border-radius:999px;background:rgba(10,3,34,.85);
  border:1px solid var(--line);color:#fff;
}
.anpr-card .conf-badge.high{color:var(--ok);border-color:rgba(72,227,164,.5)}
.anpr-card .conf-badge.mid{color:var(--warn);border-color:rgba(255,184,77,.5)}
.anpr-card .conf-badge.low{color:var(--err);border-color:rgba(255,107,138,.5)}
.anpr-card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px}
.anpr-card .plate{
  font-family:ui-monospace,Menlo,monospace;font-size:20px;font-weight:700;letter-spacing:.08em;
  color:#fff;background:rgba(138,59,255,.22);
  padding:8px 12px;border-radius:8px;border:1px solid var(--line);
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
}
.anpr-card .meta-row{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--ink-dim)}
.anpr-card .meta-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 8px;border-radius:999px;border:1px solid var(--line);
  background:rgba(138,59,255,.08);
}
.anpr-card .meta-pill svg{opacity:.7;flex-shrink:0}
.anpr-card .footer{
  padding:8px 16px 12px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--ink-mute);gap:8px;
}
.anpr-card .footer .cam{
  display:inline-flex;align-items:center;gap:5px;overflow:hidden;
  white-space:nowrap;text-overflow:ellipsis;min-width:0;
}

.anpr-foot{
  position:relative;z-index:4;margin-top:24px;display:flex;justify-content:center;
}
.btn-load{
  padding:12px 24px;border-radius:999px;border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(40,18,80,.6), rgba(20,8,44,.6));
  color:#fff;font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.05em;
  cursor:pointer;transition:all .15s;
}
.btn-load:hover{background:rgba(138,59,255,.22);border-color:var(--violet-2)}
.btn-load:disabled{opacity:.5;cursor:not-allowed}

/* ===== Camere list ===== */
.cam-list{
  position:relative;z-index:4;margin-top:20px;display:grid;
  grid-template-columns:repeat(auto-fill, minmax(360px, 1fr));gap:14px;
}
.cam-row{
  padding:16px 18px;border-radius:16px;
  background:linear-gradient(180deg, rgba(30,12,66,.55), rgba(14,6,34,.6));
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .15s;
}
.cam-row:hover{border-color:var(--violet-2)}
.cam-row.unconfig{border-color:rgba(255,184,77,.45);background:linear-gradient(180deg, rgba(60,30,10,.4), rgba(20,8,40,.6))}
.cam-row.inactive{opacity:.65}
.cam-row .r-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cam-row .r-head-left{min-width:0;flex:1}
.cam-row .r-head h3{margin:0;font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis}
.cam-row .slug{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--ink-mute);margin-top:3px;word-break:break-all}
.cam-row .r-meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:12px;color:var(--ink-dim)}
.cam-row .r-meta span{display:inline-flex;align-items:center;gap:5px}
.cam-row .r-meta svg{opacity:.6;flex-shrink:0}
.cam-row .r-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:10px;border-top:1px solid var(--line);flex-wrap:wrap}
.cam-row .r-foot .lft{font-size:11px;color:var(--ink-mute);display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.cam-row .r-foot .btns{display:flex;gap:6px}
.btn-mini{
  padding:6px 12px;border-radius:999px;border:1px solid var(--line);
  background:transparent;color:var(--ink-dim);font-family:inherit;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;
}
.btn-mini:hover{background:rgba(138,59,255,.15);color:#fff;border-color:var(--violet-2)}
.btn-mini.danger:hover{background:rgba(255,107,138,.12);color:var(--err);border-color:rgba(255,107,138,.5)}
.btn-mini:disabled{opacity:.4;cursor:not-allowed}
.btn-mini:disabled:hover{background:transparent;color:var(--ink-dim);border-color:var(--line)}
.cam-row .tip-dot{
  font-size:10px;font-weight:700;letter-spacing:.12em;flex-shrink:0;
  padding:4px 9px;border-radius:999px;background:rgba(10,3,34,.5);
  border:1px solid var(--line);color:var(--ink-dim);text-transform:uppercase;
}
.cam-row .tip-dot.anpr{color:#ff9ed8;border-color:rgba(255,158,216,.45);background:rgba(255,158,216,.1)}
.cam-row .tip-dot.inteligenta{color:var(--violet-2);border-color:rgba(176,112,255,.45);background:rgba(138,59,255,.12)}
.cam-row .tip-dot.supraveghere{color:var(--ink-dim);background:rgba(255,255,255,.03)}
.cam-row .act-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--ok);box-shadow:0 0 8px rgba(72,227,164,.6);
}
.cam-row .act-dot.off{background:var(--ink-mute);box-shadow:none}

/* ===== Settings ===== */
.settings-card{
  position:relative;z-index:4;margin-top:24px;
  border-radius:18px;border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(30,12,66,.5), rgba(14,6,34,.55));
  backdrop-filter:blur(12px);overflow:hidden;
}
.settings-card .sc-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 20px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(40,18,80,.4), rgba(20,8,44,.3));
}
.settings-card .sc-head h2{margin:0;font-size:18px;font-weight:700;color:#fff;letter-spacing:-.01em}
.settings-card .sc-status{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--ink-dim);
}
.settings-card .sc-status.ok{color:var(--ok);border-color:rgba(72,227,164,.45);background:rgba(72,227,164,.12)}
.settings-card .sc-status.err{color:var(--err);border-color:rgba(255,107,138,.45);background:rgba(255,107,138,.1)}
.settings-card .sc-status.warn{color:var(--warn);border-color:rgba(255,184,77,.45);background:rgba(255,184,77,.1)}
.settings-card .sc-body{padding:20px;display:flex;flex-direction:column;gap:20px}
.sc-info-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));gap:10px 18px;
  font-size:13px;
}
.sc-info-grid .k{color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:600;margin-right:6px}
.sc-info-grid .v{color:var(--ink);font-family:ui-monospace,Menlo,monospace;word-break:break-all}
.sc-test{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid var(--line)}
.sc-test h3{margin:0;font-size:14px;font-weight:700;color:#fff;letter-spacing:.01em}
.sc-test .sc-help{font-size:12px;color:var(--ink-dim);margin:0;line-height:1.5}
.sc-test-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:6px}
.sc-test-result{
  margin-top:10px;padding:14px 16px;border-radius:12px;border:1px solid var(--line);
  background:rgba(10,3,34,.5);
}
.sc-test-result .row{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:13px;margin-bottom:6px}
.sc-test-result .row .k{color:var(--ink-mute);letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:700;margin-right:4px}
.sc-test-result .row .v{color:var(--ink);font-weight:600}
.sc-test-result pre{
  margin:8px 0 0;padding:12px;border-radius:8px;background:rgba(0,0,0,.4);
  font-family:ui-monospace,Menlo,monospace;font-size:12px;color:#e6d8ff;overflow-x:auto;
  border:1px solid var(--line);max-height:300px;
}
.sc-test-result.err{border-color:rgba(255,107,138,.45)}
.sc-test-result.err .v{color:var(--err)}

/* ===== Users list ===== */
.user-list{
  position:relative;z-index:4;margin-top:20px;display:grid;
  grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));gap:14px;
}
.user-card{
  padding:16px 18px;border-radius:16px;
  background:linear-gradient(180deg, rgba(30,12,66,.55), rgba(14,6,34,.6));
  border:1px solid var(--line);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .15s;
}
.user-card:hover{border-color:var(--violet-2)}
.user-card.inactive{opacity:.55}
.user-card.is-me{border-color:rgba(72,227,164,.45);background:linear-gradient(180deg, rgba(20,50,40,.4), rgba(14,6,34,.6))}
.user-card .u-head{display:flex;gap:12px;align-items:center}
.user-card .u-avatar{
  width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:linear-gradient(135deg,#6d20d8,#b070ff);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;
  border:2px solid rgba(255,255,255,.08);
}
.user-card .u-avatar img{width:100%;height:100%;object-fit:cover}
.user-card .u-head-info{min-width:0;flex:1}
.user-card .u-head-info h3{margin:0;font-size:15px;font-weight:700;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-card .u-head-info .email{font-size:12px;color:var(--ink-dim);word-break:break-all;margin-top:2px}
.user-card .u-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11px}
.role-pill{
  padding:4px 10px;border-radius:999px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(138,59,255,.2);color:var(--violet-2);border:1px solid var(--line);font-size:10px;
}
.role-pill.supervisor{background:rgba(72,227,164,.2);color:var(--ok);border-color:rgba(72,227,164,.4)}
.role-pill.admin{background:rgba(255,184,77,.2);color:var(--warn);border-color:rgba(255,184,77,.4)}
.provider-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:.08em;
  background:rgba(255,255,255,.03);color:var(--ink-dim);border:1px solid var(--line);text-transform:uppercase;
}
.me-pill{
  padding:4px 10px;border-radius:999px;font-weight:700;font-size:10px;letter-spacing:.1em;
  background:rgba(72,227,164,.15);color:var(--ok);border:1px solid rgba(72,227,164,.4);text-transform:uppercase;
}
.user-card .u-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--line);flex-wrap:wrap}
.user-card .u-foot .lft{font-size:11px;color:var(--ink-mute);display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.user-card .u-foot .btns{display:flex;gap:6px}

/* Dialog checkbox row */
.dialog .form-row.check{flex-direction:row;align-items:center;gap:10px;cursor:pointer}
.dialog .form-row.check input[type=checkbox]{
  width:18px;height:18px;accent-color:var(--violet-2);margin:0;cursor:pointer;
}
.dialog .form-row.check label{
  font-size:13px;color:var(--ink);letter-spacing:0;text-transform:none;
  margin:0;cursor:pointer;
}

/* ANPR modal (reuse existing modal, plus ANPR-specific overrides) */
.anpr-modal .anpr-details{display:grid;grid-template-columns:repeat(2, 1fr);gap:12px;margin-top:6px}
.anpr-modal .anpr-details .cell{
  padding:10px 12px;border-radius:10px;border:1px solid var(--line);
  background:rgba(10,3,34,.4);
}
.anpr-modal .anpr-details .cell .k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px}
.anpr-modal .anpr-details .cell .v{font-size:14px;color:var(--ink);font-weight:600;word-break:break-word}

.page{
  position:relative;z-index:1;
  max-width:1280px;
  margin:0 auto;
  padding:28px 56px 60px;
  min-height:100vh;
  isolation:isolate;
}

/* Nav (stil aplicație: brand stânga, acțiuni dreapta) */
nav.top{
  position:relative;z-index:5;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:6px 14px;border-radius:16px;
  background:rgba(20,8,44,.55);
  border:1px solid var(--line);
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 30px -18px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.02) inset;
}
.brand{
  font-family: Tahoma, Geneva, Verdana, sans-serif;
  font-weight:600;letter-spacing:.02em;font-size:16px;
  color:var(--ink);display:inline-flex;align-items:center;gap:12px;white-space:nowrap;
  padding:8px 4px 8px 6px;
}
.brand .logo{
  width:32px;height:32px;border-radius:9px;display:grid;place-items:center;
  background:linear-gradient(180deg,#9b4dff,#5c17c9);
  box-shadow:0 8px 20px -8px rgba(138,59,255,.7), 0 0 0 1px rgba(255,255,255,.08) inset;
  color:#fff;
}
.brand .meta{display:flex;flex-direction:column;line-height:1.05}
.brand .meta small{
  font-family: Tahoma, Geneva, Verdana, sans-serif;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#fff;font-weight:600;margin-top:2px;opacity:.85;
}

.right{display:flex;gap:10px;justify-content:flex-end;align-items:center}
.icon-btn{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  border:1px solid var(--line);background:rgba(255,255,255,.03);
  color:var(--ink);cursor:pointer;transition:background .15s, color .15s;
}
.icon-btn:hover{background:rgba(138,59,255,.15);color:#fff}

/* User chip în nav */
.user-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 14px 6px 6px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);color:var(--ink);font-size:13px;cursor:pointer;
  position:relative;
}
.user-chip:hover{background:rgba(138,59,255,.12)}
.user-chip .avatar{
  width:30px;height:30px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:linear-gradient(135deg,#6d20d8,#b070ff);
  display:grid;place-items:center;font-weight:700;color:#fff;font-size:13px;
}
.user-chip .avatar img{width:100%;height:100%;object-fit:cover}
.user-chip .u-name{font-weight:600;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}
.user-chip .caret{font-size:10px;opacity:.6}
.user-menu{
  position:absolute;top:calc(100% + 8px);right:0;min-width:220px;
  border-radius:14px;padding:8px;z-index:50;
  background: linear-gradient(180deg,rgba(40,18,80,.95),rgba(20,8,44,.98));
  border:1px solid var(--line);
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
  display:none;
}
.user-menu.open{display:block}
.user-menu .info{padding:10px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.user-menu .info .email{font-size:12px;color:var(--ink-dim);word-break:break-all}
.user-menu .info .role-badge{
  display:inline-block;margin-top:6px;padding:3px 8px;border-radius:999px;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  background:rgba(138,59,255,.2);color:var(--violet-2);border:1px solid var(--line);
}
.user-menu .info .role-badge.supervisor{background:rgba(72,227,164,.2);color:var(--ok);border-color:rgba(72,227,164,.4)}
.user-menu .info .role-badge.admin{background:rgba(255,184,77,.2);color:var(--warn);border-color:rgba(255,184,77,.4)}
.user-menu button{
  width:100%;padding:10px 12px;background:transparent;border:none;color:var(--ink);
  font-size:13px;text-align:left;cursor:pointer;border-radius:8px;font-family:inherit;
  display:flex;align-items:center;gap:10px;
}
.user-menu button:hover{background:rgba(138,59,255,.15)}
.user-menu button.danger:hover{background:rgba(255,107,138,.15);color:var(--err)}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px 11px 20px;border-radius:999px;color:#fff;font-weight:600;font-size:14px;
  background:linear-gradient(180deg,#9b4dff 0%, #6d20d8 100%);
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 8px 24px -8px rgba(138,59,255,.8), 0 1px 0 rgba(255,255,255,.15) inset;
  border:none;cursor:pointer;text-decoration:none;
}
.btn-primary .ico{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.15);display:grid;place-items:center}

/* Hero */
.hero{position:relative;z-index:4;margin-top:60px;display:grid;grid-template-columns:220px 1fr 240px;gap:28px;align-items:start}
.tags{display:flex;flex-direction:column;gap:14px;padding-top:10px}
.tag{
  align-self:flex-start;padding:10px 18px;border-radius:999px;border:1px solid rgba(176,112,255,.45);
  background:rgba(138,59,255,.12);color:#e6d8ff;font-size:13.5px;letter-spacing:.01em;
  backdrop-filter: blur(8px);
  box-shadow: 0 0 0 1px rgba(255,255,255,.02) inset, 0 10px 30px -12px rgba(138,59,255,.55);
}
.tag:nth-child(1){margin-left:6px}
.tag:nth-child(2){margin-left:40px}
.tag:nth-child(3){margin-left:16px}

.headline{
  text-align:center;font-family:'Manrope', sans-serif;font-weight:700;font-size:64px;
  line-height:1.05;letter-spacing:-.03em;margin:0;color:#fff;
  text-shadow: 0 4px 40px rgba(138,59,255,.25);
}
.headline em{font-style:normal;font-weight:700;color:#efe4ff}

/* Detect grid (înlocuiește headline-ul cu iconițele categoriilor detectate) */
.detect-grid{
  position:relative;z-index:4;
  display:grid;grid-template-columns:repeat(4, 1fr);gap:12px;
  margin:0 auto;width:100%;max-width:520px;
  align-self:start;
}
.detect-grid .dt-title{
  grid-column:1/-1;text-align:center;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:18px;
  letter-spacing:.04em;color:#fff;margin-bottom:4px;
}
.detect-grid .dt-title small{
  display:block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);font-weight:600;margin-top:6px;
}
.dt-cell{
  aspect-ratio:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  padding:8px 4px;border-radius:14px;
  background:linear-gradient(180deg, rgba(40,18,80,.5), rgba(20,8,44,.4));
  border:1px solid var(--line);backdrop-filter:blur(8px);
  transition:transform .15s, border-color .15s, background .15s, box-shadow .15s;
  cursor:default;
  box-shadow:0 12px 30px -16px rgba(138,59,255,.25), 0 0 0 1px rgba(255,255,255,.02) inset;
}
.dt-cell:hover{
  transform:translateY(-2px);
  border-color:var(--violet-2);
  background:linear-gradient(180deg, rgba(60,28,120,.6), rgba(30,12,60,.5));
  box-shadow:0 18px 40px -14px rgba(138,59,255,.55), 0 0 0 1px rgba(255,255,255,.04) inset;
}
.dt-cell svg{color:var(--violet-2);width:28px;height:28px;flex-shrink:0;transition:color .15s}
.dt-cell:hover svg{color:#fff}
.dt-cell .lbl{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-dim);font-weight:700;text-align:center;line-height:1.1;
}
.dt-cell:hover .lbl{color:#fff}

@media (max-width: 600px){
  .detect-grid{grid-template-columns:repeat(2, 1fr);max-width:280px}
  .dt-cell{aspect-ratio:1.2}
}

.chart-card{
  margin-top:8px;padding:14px 14px 10px;border-radius:18px;
  background: linear-gradient(180deg, rgba(40,18,80,.65), rgba(20,8,44,.55));
  border:1px solid var(--line);
  box-shadow: 0 20px 60px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.02) inset;
  backdrop-filter: blur(10px);
}
.chart-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.chart-head .lbl{font-size:11px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase}
.chart-head .val{font-weight:600;font-size:26px;color:#fff}
.spark{width:100%;height:76px;display:block}

/* CTA row */
.actionrow{position:relative;z-index:4;margin-top:36px;display:grid;grid-template-columns:1fr auto 1fr;gap:40px;align-items:center}
.cta-wrap{display:flex;align-items:center;gap:14px;justify-content:center}
.btn-lg{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 24px;border-radius:999px;font-weight:700;font-size:16px;color:#fff;
  background:linear-gradient(180deg,#9b4dff 0%, #5c17c9 100%);
  border:none;cursor:pointer;
  box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, 0 18px 40px -14px rgba(138,59,255,.8);
}
.btn-lg .ico{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center}
.play{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;
  background:linear-gradient(180deg,#6d20d8,#3d0e84);
  border:1px solid rgba(255,255,255,.12);cursor:pointer;
}

.stats{display:flex;align-items:center;gap:26px;justify-content:center}
.stat .num{font-weight:600;font-size:38px;line-height:1;color:#fff;letter-spacing:-.02em}
.stat .lbl{font-size:13px;color:var(--ink-dim);letter-spacing:.02em;margin-top:4px}
.stats .sep{width:1px;height:44px;background:linear-gradient(180deg,transparent, var(--line), transparent)}

.explore{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-self:start;padding-left:8px}
.explore .kicker{font-size:11px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase}
.explore a{display:inline-flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-size:15px;cursor:pointer}
.explore a .dot{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center}

/* 3-card grid */
.grid-bottom{position:relative;z-index:4;margin-top:60px;display:grid;grid-template-columns:1.05fr 1.2fr 1.4fr;gap:22px;align-items:stretch}
.card{
  position:relative;border-radius:22px;border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(30,12,66,.55), rgba(14,6,34,.6));
  backdrop-filter: blur(12px);overflow:hidden;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.02) inset;
}
.card.pad{padding:22px}

/* Left card: Categorii */
.c-left{min-height:300px;display:flex;flex-direction:column;justify-content:space-between;gap:18px}
.c-left .head{display:flex;justify-content:space-between;align-items:center}
.icn{width:36px;height:36px;border-radius:10px;background:linear-gradient(180deg,#9b4dff,#5c17c9);display:grid;place-items:center;color:#fff}
.badge{font-size:11px;color:var(--ink-dim);letter-spacing:.16em;text-transform:uppercase}
.c-left h3{font-weight:600;font-size:24px;line-height:1.15;margin:6px 0 0;color:#fff;letter-spacing:-.02em}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}
.pill{
  padding:7px 14px;border-radius:999px;border:1px solid var(--line);
  font-size:12px;color:var(--ink-dim);background:rgba(255,255,255,.02);
  display:inline-flex;align-items:center;gap:8px;
}
.pill b{color:#fff;font-weight:700}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;align-self:flex-start;
  padding:12px 18px;border-radius:999px;background:#fff;color:#2a1158;font-weight:700;font-size:14px;
  text-decoration:none;border:none;cursor:pointer;
}
.btn-ghost .ico{width:22px;height:22px;border-radius:50%;background:#2a1158;color:#fff;display:grid;place-items:center}

/* Middle card: drag-drop UPLOAD */
.c-mid{min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;padding:0}
.drop{
  position:relative;flex:1;cursor:pointer;
  background:
    radial-gradient(220px 150px at 50% 38%, rgba(176,112,255,.45), transparent 60%),
    repeating-linear-gradient(45deg, rgba(176,112,255,.06) 0 12px, transparent 12px 24px),
    linear-gradient(180deg, #170836 0%, #0a0322 100%);
  display:grid;place-items:center;text-align:center;transition:background .2s;
}
.drop.dragover{background:
    radial-gradient(220px 150px at 50% 38%, rgba(176,112,255,.7), transparent 60%),
    repeating-linear-gradient(45deg, rgba(176,112,255,.12) 0 12px, transparent 12px 24px),
    linear-gradient(180deg, #200a48 0%, #100434 100%);}
.drop .ph{
  border:1px dashed rgba(176,112,255,.45);border-radius:14px;padding:16px 20px;
  color:#e6d8ff;font-size:13px;letter-spacing:.04em;display:flex;flex-direction:column;align-items:center;gap:8px;
  background:rgba(10,3,34,.4);
}
.drop .ph .ico-up{
  width:42px;height:42px;border-radius:12px;background:linear-gradient(180deg,#9b4dff,#5c17c9);
  display:grid;place-items:center;margin-bottom:4px;
  box-shadow:0 12px 30px -10px rgba(138,59,255,.7);
}
.drop .ph small{color:var(--ink-mute);font-size:11px;letter-spacing:.08em}
.drop input[type=file]{display:none}
.drop .preview{max-width:80%;max-height:80%;border-radius:12px;box-shadow:0 12px 40px -8px rgba(0,0,0,.5)}
.mid-foot{
  padding:18px 22px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:linear-gradient(180deg, rgba(20,8,44,.2), rgba(20,8,44,.85));
}
.mid-foot h3{font-weight:600;font-size:22px;margin:0;color:#fff;line-height:1.18;letter-spacing:-.02em}
.arrow-btn{min-width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.04);cursor:pointer}

/* Right card */
.c-right{
  min-height:340px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
}
.c-right .r-content{padding:22px;display:flex;flex-direction:column}
.c-right .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.c-right .num{font-weight:600;font-size:52px;line-height:1;color:#fff;letter-spacing:-.03em}
.c-right .sub{font-size:13px;color:var(--ink-dim);margin-top:4px}
.round{
  width:44px;height:44px;border-radius:50%;background:#fff;color:#2a1158;display:grid;place-items:center;
  box-shadow: 0 8px 24px -8px rgba(138,59,255,.6);
}
.c-right .chart{margin-top:14px;height:100px;width:100%;display:block}
.c-right .row{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-dim);margin-top:6px}
.c-right .r-foot{
  padding:18px 22px 22px;
  background:linear-gradient(180deg, rgba(20,8,44,.2), rgba(20,8,44,.85));
}
.c-right h3{font-weight:600;font-size:22px;margin:0;color:#fff;line-height:1.18;letter-spacing:-.02em}

/* Detections section */
.section-head{
  position:relative;z-index:4;display:flex;align-items:end;justify-content:space-between;margin:64px 0 22px;
}
.section-head h2{font-weight:600;font-size:38px;margin:0;color:#fff;letter-spacing:-.02em}
.section-head .kicker{font-size:11px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:8px}
.section-head .right-link{font-size:13px;color:var(--ink-dim);display:inline-flex;align-items:center;gap:8px;cursor:pointer}

.grid-detections{
  position:relative;z-index:4;display:grid;
  grid-template-columns:repeat(4,1fr);gap:18px;
}
.det{
  border-radius:18px;border:1px solid var(--line);overflow:hidden;
  background:linear-gradient(180deg, rgba(30,12,66,.55), rgba(14,6,34,.6));
  backdrop-filter: blur(8px);
  display:flex;flex-direction:column;
  box-shadow: 0 20px 50px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.02) inset;
}
.det .img-wrap{aspect-ratio:4/3;background:#0a0322;overflow:hidden;position:relative}
.det img{width:100%;height:100%;object-fit:cover;display:block}
.det .src-badge{
  position:absolute;top:10px;left:10px;font-size:10px;letter-spacing:.18em;
  padding:5px 9px;border-radius:999px;background:rgba(10,3,34,.7);
  border:1px solid var(--line);color:var(--ink-dim);text-transform:uppercase;
}
.det .conf-badge{
  position:absolute;top:10px;right:10px;font-size:11px;font-weight:700;
  padding:5px 9px;border-radius:999px;background:rgba(10,3,34,.75);
  border:1px solid var(--line);color:#fff;
}
.det .conf-badge.low{color:var(--err);border-color:rgba(255,107,138,.5)}
.det .conf-badge.mid{color:var(--warn);border-color:rgba(255,184,77,.5)}
.det .conf-badge.high{color:var(--ok);border-color:rgba(72,227,164,.5)}
.det .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}
.det .cat{font-weight:700;font-size:14px;color:#fff;letter-spacing:.02em}
.det .det-detail{font-size:12px;color:var(--ink-dim);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.det .meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;color:var(--ink-mute)}
.det .plate{font-family:ui-monospace,Menlo,monospace;color:#e6d8ff;background:rgba(138,59,255,.15);padding:3px 7px;border-radius:6px;border:1px solid var(--line)}
.det .loc-chip{
  display:inline-flex;align-items:center;gap:6px;margin:4px 0 2px;
  font-size:11px;color:var(--ink-dim);
  padding:4px 9px;border-radius:999px;border:1px solid var(--line);
  background:rgba(138,59,255,.08);width:fit-content;max-width:100%;
  cursor:pointer;transition:background .15s, border-color .15s;
}
.det .loc-chip:hover{background:rgba(138,59,255,.25);border-color:var(--violet-2);color:#fff}
.det .loc-chip svg{flex-shrink:0;opacity:.7}
.det .loc-chip .loc-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.det .loc-chip.unconfig{border-color:rgba(255,184,77,.45);background:rgba(255,184,77,.08);color:var(--warn)}
.det .loc-chip.unconfig:hover{background:rgba(255,184,77,.22);color:#fff}
.src-badge.src-alarm{background:rgba(72,227,164,.2);color:var(--ok);border:1px solid rgba(72,227,164,.4)}
.src-badge.src-upload{background:rgba(176,112,255,.2);color:#e6d8ff;border:1px solid var(--line)}
.src-badge.src-ftp{background:rgba(10,3,34,.75);color:var(--ink-dim);border:1px solid var(--line)}

/* Dialog cameră (secondary modal) */
.dialog-backdrop{
  position:fixed;inset:0;z-index:110;display:none;align-items:center;justify-content:center;
  background:rgba(4,2,10,.75);backdrop-filter: blur(6px);
}
.dialog-backdrop.open{display:flex}
/* Static-backdrop feedback: shake la click pe overlay */
.dialog.shake, .modal.shake{ animation: dlg-shake .35s cubic-bezier(.36,.07,.19,.97) }
@keyframes dlg-shake{
  10%,90%{ transform: translateX(-2px) }
  20%,80%{ transform: translateX(4px) }
  30%,50%,70%{ transform: translateX(-6px) }
  40%,60%{ transform: translateX(6px) }
}
.dialog{
  width:min(480px, 92vw);border-radius:20px;overflow:hidden;
  background: linear-gradient(180deg, rgba(30,12,66,.95), rgba(14,6,34,.98));
  border:1px solid var(--line);padding:28px;
  box-shadow: 0 40px 100px -20px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.04) inset;
}
.dialog h2{margin:0 0 6px;font-size:22px;font-weight:700;color:#fff;letter-spacing:-.02em}
.dialog .sub{font-size:12px;color:var(--ink-dim);margin-bottom:18px}
.dialog .form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.dialog .form-row label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);font-weight:700}
.dialog .form-row input{
  padding:11px 14px;border-radius:10px;border:1px solid var(--line);background:rgba(10,3,34,.6);
  color:#fff;font-family:inherit;font-size:14px;outline:none;transition:border .15s;
}
.dialog .form-row input:focus,
.dialog .form-row .cam-select:focus{border-color:var(--violet-2)}
.dialog .form-row .cam-select{
  padding:11px 14px;border-radius:10px;border:1px solid var(--line);background:rgba(10,3,34,.6);
  color:#fff;font-family:inherit;font-size:14px;outline:none;cursor:pointer;
}
.dialog .form-row .cam-select option{background:#1a0a3a;color:#fff}
.det .tip-badge{
  position:absolute;bottom:10px;left:10px;font-size:10px;letter-spacing:.14em;font-weight:700;
  padding:4px 8px;border-radius:999px;background:rgba(10,3,34,.75);
  border:1px solid var(--line);color:var(--ink-dim);text-transform:uppercase;
}
.det .tip-badge.anpr{color:#ff9ed8;border-color:rgba(255,158,216,.45);background:rgba(255,158,216,.1)}
.det .tip-badge.inteligenta{color:var(--violet-2);border-color:rgba(176,112,255,.45);background:rgba(138,59,255,.12)}
.det .tip-badge.supraveghere{color:var(--ink-mute);border-color:var(--line)}
.dialog .form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dialog .form-row.two > div{display:flex;flex-direction:column;gap:6px}
.dialog .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
.dialog .btn-save{
  padding:11px 20px;border-radius:999px;border:none;cursor:pointer;font-weight:700;font-size:14px;
  background:linear-gradient(180deg,#9b4dff,#5c17c9);color:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset, 0 10px 25px -10px rgba(138,59,255,.7);
}
.dialog .btn-cancel{
  padding:11px 20px;border-radius:999px;border:1px solid var(--line);cursor:pointer;
  background:transparent;color:var(--ink);font-weight:600;font-size:14px;
}

/* Buton "Configurează" în modal când camera e neconfigurată */
.modal-body .config-cam-btn{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  padding:8px 14px;border-radius:999px;border:1px solid rgba(255,184,77,.5);
  background:rgba(255,184,77,.12);color:var(--warn);font-size:12px;font-weight:600;
  cursor:pointer;text-transform:uppercase;letter-spacing:.08em;
}
.modal-body .config-cam-btn:hover{background:rgba(255,184,77,.2)}

.empty{
  grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--ink-mute);
  border:1px dashed var(--line);border-radius:18px;font-size:14px;
}

/* Modal */
.modal-backdrop{
  position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;
  background:radial-gradient(1000px 600px at 50% 40%, rgba(138,59,255,.25), rgba(4,2,10,.85) 60%);
  backdrop-filter: blur(8px);
  animation: fadeBg .2s ease;
}
.modal-backdrop.open{display:flex}
@keyframes fadeBg{from{opacity:0}to{opacity:1}}
.modal{
  position:relative;display:grid;grid-template-columns:1.3fr 1fr;
  width:min(1100px, 92vw);max-height:86vh;
  border-radius:22px;overflow:hidden;
  background: linear-gradient(180deg, rgba(30,12,66,.85), rgba(14,6,34,.92));
  border:1px solid var(--line);
  box-shadow: 0 40px 100px -20px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.04) inset;
  animation: popIn .22s cubic-bezier(.2,.9,.3,1.1);
}
@keyframes popIn{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.modal-img{
  background:#0a0322;display:grid;place-items:center;overflow:hidden;position:relative;min-height:300px;
}
.modal-img img{max-width:100%;max-height:86vh;object-fit:contain;display:block}
.modal-img .src-badge{
  position:absolute;top:14px;left:14px;font-size:10px;letter-spacing:.18em;
  padding:6px 10px;border-radius:999px;background:rgba(10,3,34,.75);
  border:1px solid var(--line);color:var(--ink-dim);text-transform:uppercase;
}
.modal-body{
  display:flex;flex-direction:column;padding:28px 28px 24px;overflow-y:auto;gap:18px;
}
.modal-body .cat-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}
.modal-body h3.mt-cat{font-size:30px;font-weight:700;margin:0;color:#fff;letter-spacing:-.02em;line-height:1.15}
.modal-body .conf-big{
  display:flex;align-items:baseline;gap:8px;margin-top:-6px;
}
.modal-body .conf-big .pct{font-size:42px;font-weight:700;letter-spacing:-.03em}
.modal-body .conf-big .pct.high{color:var(--ok)}
.modal-body .conf-big .pct.mid{color:var(--warn)}
.modal-body .conf-big .pct.low{color:var(--err)}
.modal-body .conf-big .lbl{font-size:12px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase}
.modal-body .section{border-top:1px solid var(--line);padding-top:16px;display:flex;flex-direction:column;gap:6px}
.modal-body .section .label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);font-weight:600}
.modal-body .section .value{font-size:14px;color:var(--ink);line-height:1.55;word-wrap:break-word}
.modal-body .section .value.mono{font-family:ui-monospace,Menlo,monospace;font-size:13px}
.modal-body .plate-chip{
  display:inline-flex;align-items:center;gap:8px;
  font-family:ui-monospace,Menlo,monospace;color:#fff;background:rgba(138,59,255,.2);
  padding:6px 12px;border-radius:8px;border:1px solid var(--line);font-size:14px;font-weight:700;letter-spacing:.06em;
  align-self:flex-start;
}
.modal-close{
  position:absolute;top:14px;right:14px;z-index:5;
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:rgba(10,3,34,.75);color:#fff;display:grid;place-items:center;cursor:pointer;
  transition:background .15s;
}
.modal-close:hover{background:rgba(138,59,255,.4)}
.det{cursor:pointer;transition:transform .15s, box-shadow .15s}
.det:hover{transform:translateY(-2px);box-shadow: 0 30px 60px -20px rgba(138,59,255,.35), 0 0 0 1px rgba(176,112,255,.25) inset}

@media (max-width: 760px){
  .modal{grid-template-columns:1fr;max-height:92vh}
  .modal-img{max-height:50vh}
}

/* Toast */
.toast-wrap{position:fixed;top:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:100}
.toast{
  padding:14px 18px;border-radius:14px;background:linear-gradient(180deg,rgba(40,18,80,.95),rgba(20,8,44,.95));
  border:1px solid var(--line);color:#fff;font-size:13px;min-width:260px;max-width:380px;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.6);
  animation:slideIn .25s ease;
}
.toast.ok{border-color:rgba(72,227,164,.45)}
.toast.err{border-color:rgba(255,107,138,.5)}
.toast b{display:block;margin-bottom:4px;font-weight:700}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Loading spinner inside drop card */
.spinner{
  width:36px;height:36px;border-radius:50%;
  border:3px solid rgba(176,112,255,.2);border-top-color:#b070ff;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width: 1100px){
  .page{padding:24px 28px 60px}
  .hero{grid-template-columns:1fr;gap:18px}
  .tags{flex-direction:row;flex-wrap:wrap}
  .tag{margin:0!important}
  .headline{font-size:48px}
  .actionrow{grid-template-columns:1fr;gap:24px}
  .grid-bottom{grid-template-columns:1fr}
  .grid-detections{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  :root{--sidebar-w: 0px}
  body{padding-left:0 !important;padding-top:var(--topbar-h)}
  body.sb-expanded{padding-left:0 !important}

  /* Top bar cu hamburger */
  .mobile-topbar{
    display:flex;align-items:center;gap:10px;
    position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:28;
    padding:8px 14px;
    background:linear-gradient(180deg, rgba(14,6,34,.95), rgba(10,3,26,.95));
    backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
  }
  .mobile-topbar .hamburger{
    width:40px;height:40px;border-radius:10px;border:1px solid var(--line);
    background:rgba(138,59,255,.12);color:var(--ink);cursor:pointer;
    display:grid;place-items:center;flex-shrink:0;
  }
  .mobile-topbar .hamburger:hover{background:rgba(138,59,255,.25)}
  .mobile-topbar .mt-brand{
    display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:600;font-size:14px;
    font-family:Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;
  }
  .mobile-topbar .mt-brand .mt-logo{
    width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
    background:linear-gradient(180deg,#9b4dff,#5c17c9);color:#fff;
  }
  .mobile-topbar .mt-brand .mt-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mobile-topbar .mt-user{
    margin-left:auto;width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;
    background:linear-gradient(135deg,#6d20d8,#b070ff);color:#fff;
    display:grid;place-items:center;font-weight:700;font-size:13px;cursor:pointer;
    border:2px solid rgba(255,255,255,.12);
  }
  .mobile-topbar .mt-user img{width:100%;height:100%;object-fit:cover}

  /* Sidebar ca drawer (slide-in din stânga) */
  .sidebar{
    left:-100%;width:var(--sidebar-w-expanded);height:100vh;
    border-right:1px solid var(--line);padding:18px 14px;
  }
  .sidebar.open{left:0;box-shadow:0 20px 60px rgba(0,0,0,.6)}
  .sidebar .sb-logo{width:100%;margin-bottom:14px}
  .sidebar .sb-logo .brand-txt{display:block}
  .sidebar .nav-item{width:100%}
  .sidebar .nav-item .label{display:block}
  .sidebar .nav-item .tip{display:none}
  .sidebar .sb-user{
    width:100%;padding:6px 8px;border:1px solid var(--line);
    background:linear-gradient(180deg, rgba(40,18,80,.35), rgba(20,8,44,.45));
  }
  .sidebar .sb-user .sb-user-info{display:block}
  .sb-logout-btn{display:flex !important}
  .sb-user-menu{display:none !important}
  .sb-toggle{display:none}

  .grid-detections{grid-template-columns:1fr}
  .headline{font-size:36px}
  .brand .meta small{display:none}
  .btn-primary{padding:9px 14px;font-size:13px}
}
