:root{
  --bg-body:#0f0f0f; --bg-header:linear-gradient(180deg,#1a1a1a 0%,#0f0f0f 100%);
  --bg-card:#1a1a1a; --bg-input:#252525; --text-primary:#e0e0e0; --text-muted:#888;
  --text-green:#82b541; --border-color:#282828; --table-hover:rgba(130,181,65,.05);
  --monitor-bg:rgba(20,20,20,.95); --breaking-red:#ffc107; --alert-orange:#ff7a18;
  /* design tokens — miscare, umbre, raze */
  --ease:cubic-bezier(.4,0,.2,1); --t-fast:120ms; --t-base:180ms;
  --r-sm:6px; --r-md:8px; --r-lg:12px;
  --sh-sm:0 1px 3px rgba(0,0,0,.25); --sh-md:0 4px 14px rgba(0,0,0,.3); --sh-lg:0 10px 30px rgba(0,0,0,.4);
  --ring-green:0 0 0 3px rgba(130,181,65,.25);
}
.light-mode{
  --bg-body:#f0f2f5; --bg-header:linear-gradient(180deg,#fff 0%,#e4e6e9 100%);
  --bg-card:#fff; --bg-input:#f0f2f5; --text-primary:#1c1e21; --text-muted:#65676b;
  --text-green:#5a8d2a; --border-color:#dddfe2; --table-hover:rgba(0,0,0,.05);
  --monitor-bg:rgba(255,255,255,.95); --breaking-red:#dc3545; --alert-orange:#e8590c;
}
body{background-color:var(--bg-body);color:var(--text-primary);font-family:'Segoe UI',Roboto,sans-serif;padding-bottom:50px;transition:all .3s ease;}
#status-monitor{position:fixed;top:10px;left:10px;z-index:9999;background:var(--monitor-bg);padding:12px;border-left:4px solid var(--text-green);border-radius:0 8px 8px 0;box-shadow:var(--sh-md);min-width:220px;border:1px solid var(--border-color);}
.header-section{padding:30px 0;background:var(--bg-header);border-bottom:1px solid var(--border-color);margin-bottom:30px;position:relative;}
.header-right{position:absolute;right:25px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:12px;}
.user-badge{font-size:.8rem;color:var(--text-muted);border:1px solid var(--border-color);border-radius:20px;padding:5px 12px;white-space:nowrap;}
.user-badge b{color:var(--text-green);}
.icon-btn{background:none;border:1px solid var(--border-color);padding:5px 12px;border-radius:20px;color:var(--text-primary);cursor:pointer;}
.icon-btn:hover{border-color:var(--text-green);color:var(--text-green);}
.file-row{background-color:var(--bg-card);margin-bottom:12px;padding:18px;border-radius:var(--r-md);border:1px solid var(--border-color);}
.file-row.breaking-row{border:1px solid var(--breaking-red);box-shadow:0 0 0 1px rgba(220,53,69,.15);}
.file-row.alert-row{border:1px solid var(--alert-orange);box-shadow:0 0 0 1px rgba(255,122,24,.15);}
.form-control{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);height:50px;}
.form-control:focus{background-color:var(--bg-card);border-color:var(--text-green);color:var(--text-primary);}
.breaking-input{border-color:var(--breaking-red)!important;}
.alert-input{border-color:var(--alert-orange)!important;}
.btn-save{height:50px;font-weight:bold;background-color:var(--text-green);border:none;color:#fff;cursor:pointer;}
.btn-breaking{height:50px;font-weight:bold;background-color:var(--breaking-red);border:none;color:#fff;cursor:pointer;}
.btn-alert{height:50px;font-weight:bold;background-color:var(--alert-orange);border:none;color:#fff;cursor:pointer;}
.elastic-card{display:flex;flex-direction:column;height:480px;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--r-md);}
.table-responsive-elastic{flex-grow:1;overflow-y:auto;}
.video-container{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r-md);background:#000;}
.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;}
.text-green{color:var(--text-green)!important;}
.text-breaking{color:var(--breaking-red)!important;}
.text-alert{color:var(--alert-orange)!important;}
.toast-container{position:fixed;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:10001;pointer-events:none;}
#hulubToast{min-width:550px;border:3px solid var(--text-green);background-color:rgba(20,20,20,.98);border-radius:25px;box-shadow:0 0 60px rgba(0,0,0,.9),0 0 20px rgba(130,181,65,.3);pointer-events:auto;}
#hulubToast .toast-body{padding:50px!important;}
#hulubToast strong{font-size:2.5rem;letter-spacing:3px;text-transform:uppercase;color:#fff;}
#toastDetails{font-size:1.2rem;font-family:'Courier New',monospace;color:var(--text-green)!important;margin-top:15px;display:block;}
.hulub-icon i{font-size:5rem!important;}
@keyframes hulubFlight{0%{transform:translate(0,0) scale(1) rotate(0);opacity:1;}100%{transform:translate(400px,-300px) scale(.2) rotate(-20deg);opacity:0;}}
@keyframes wingBeat{0%,100%{transform:rotate(0);}50%{transform:rotate(-20deg);}}
.toast.show .hulub-icon i{display:inline-block;animation:hulubFlight 2.5s forwards ease-in-out,wingBeat .3s infinite ease-in-out;}
.modal-content{background-color:var(--bg-card);border:1px solid var(--text-green);color:var(--text-primary);border-radius:var(--r-lg);}
.modal-header{border-bottom:1px solid var(--border-color);}
.changelog-item{border-bottom:1px dashed var(--border-color);padding-bottom:15px;margin-bottom:15px;}
.changelog-item:last-child{border-bottom:none;}
.footer-section{padding:20px 0;margin-top:50px;}
.footer-logo{transition:filter .3s ease;vertical-align:middle;}
/* --- login / setup --- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--r-lg);padding:40px;width:100%;max-width:400px;box-shadow:var(--sh-lg);}
.auth-card h3{font-weight:bold;margin-bottom:6px;}
.auth-card .sub{color:var(--text-muted);font-size:.85rem;margin-bottom:26px;}
.auth-card label{font-size:.8rem;color:var(--text-muted);margin-bottom:4px;display:block;}
.auth-card input{width:100%;margin-bottom:16px;}
.btn-auth{width:100%;height:48px;font-weight:bold;background:var(--text-green);border:none;color:#fff;border-radius:var(--r-md);cursor:pointer;}
.auth-err{background:rgba(220,53,69,.12);border:1px solid rgba(220,53,69,.4);color:#ff6b6b;border-radius:var(--r-md);padding:10px 14px;font-size:.85rem;margin-bottom:18px;}
.auth-logo{text-align:center;margin-top:24px;}
/* --- admin --- */
.admin-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--r-lg);padding:24px;margin-bottom:24px;}
.admin-table{width:100%;}
.admin-table th{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border-color);padding:8px;}
.admin-table td{padding:8px;border-bottom:1px solid var(--border-color);font-size:.88rem;}
.role-pill{font-size:.7rem;padding:2px 10px;border-radius:20px;font-weight:bold;}
.role-admin{background:rgba(130,181,65,.18);color:var(--text-green);}
.role-operator{background:rgba(136,136,136,.18);color:var(--text-muted);}
.tabbtn{background:none;border:none;color:var(--text-muted);padding:10px 18px;border-bottom:2px solid transparent;cursor:pointer;font-weight:bold;}
.tabbtn.active{color:var(--text-green);border-bottom-color:var(--text-green);}
.log-action{font-size:.72rem;padding:2px 8px;border-radius:var(--r-sm);font-weight:bold;}
.la-send{background:rgba(74,158,221,.18);color:#4a9edd;}
.la-login{background:rgba(130,181,65,.18);color:var(--text-green);}
.la-login_failed{background:rgba(220,53,69,.18);color:#ff6b6b;}
.la-logout{background:rgba(136,136,136,.18);color:var(--text-muted);}
.la-user{background:rgba(255,122,24,.18);color:var(--alert-orange);}

.header-section{position:relative;z-index:1050;}
.header-right .dropdown-menu{z-index:1060;}
.file-row{position:relative;z-index:1;}
.table{color:var(--text-primary)!important;}
.table td,.table th{border-color:var(--border-color);}
.table thead th{border-bottom:1px solid var(--border-color);}
.table-hover tbody tr:hover{background-color:var(--table-hover);color:var(--text-primary);}

/* Indicator stare conexiune (MCR + Forward) */
.conn-status{display:inline-flex;flex-direction:column;align-items:flex-start;gap:6px;padding:6px 14px;border-radius:var(--r-md);background:rgba(0,0,0,.18);font-size:13px;vertical-align:middle}
.conn-item{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.conn-dot{width:10px;height:10px;border-radius:50%;background:#888;box-shadow:0 0 0 0 rgba(0,0,0,0);transition:background .3s}
.conn-dot.on{background:#28a05a;box-shadow:0 0 8px rgba(40,160,90,.7)}
.conn-dot.off{background:#d24646;box-shadow:0 0 8px rgba(210,70,70,.6)}
.conn-dot.wait{background:#dca028}
.conn-label{opacity:.85}
.conn-detail{opacity:.55;font-size:11px}
.light-mode .conn-status{background:rgba(0,0,0,.06)}

/* Butoane ON/OFF obiect Forward + indicator stare per canal */
.obj-ctrl{display:flex;align-items:center;gap:6px;margin-top:6px;justify-content:flex-end}
.obj-state{display:inline-flex;align-items:center;gap:5px;font-size:11px;margin-right:auto;padding-left:4px}
.obj-state-dot{width:9px;height:9px;border-radius:50%;background:#666;transition:background .25s}
.obj-state-dot.on{background:#28a05a;box-shadow:0 0 7px rgba(40,160,90,.7)}
.obj-state-dot.off{background:#555}
.obj-state-label{opacity:.7}
.btn-obj{font-size:11px;font-weight:bold;padding:2px 12px;border-radius:var(--r-sm);border:1px solid transparent;cursor:pointer;letter-spacing:.5px}
.btn-obj-on{background:rgba(40,160,90,.15);border-color:#28a05a;color:#3ad17e}
.btn-obj-on:hover{background:#28a05a;color:#fff}
.btn-obj-off{background:rgba(210,70,70,.12);border-color:#b5484a;color:#e2706f}
.btn-obj-off:hover{background:#c0392b;color:#fff}
.btn-obj:disabled{opacity:.45;cursor:default}
.obj-dry{font-size:10px;opacity:.5;font-style:italic;margin-left:4px}

/* ON-AIR tally + send-row + alert rosu (consolidat) */
.onair-ind{display:flex;flex-direction:column;align-items:center;justify-content:center;width:64px;height:64px;flex-shrink:0;border-radius:var(--r-md);font-weight:bold;font-size:.72rem;letter-spacing:.5px;text-align:center}
.onair-ind .onair-dot{display:none}
.onair-ind.off{background:#3a3a3a;color:#999}
.onair-ind.on{background:#e23b3b;color:#fff;animation:onairPulse 1.2s ease-in-out infinite}
@keyframes onairPulse{0%,100%{background:#e23b3b}50%{background:#b02a2a}}
.col-md-2.text-center{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:20px;padding-left:14px}
.col-md-2.text-center h5{margin:0}
.send-row{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.btn-send-sm{flex:1;font-size:.8rem;padding:6px 8px;font-weight:bold;white-space:nowrap}
.send-row .btn-obj{padding:6px 10px;font-size:11px}
.text-alert{color:#e23b3b !important}
.btn-alert{background:#c0392b !important;border-color:#c0392b !important;color:#fff !important}
.btn-alert:hover{background:#a93226 !important}
.alert-row{border-left:3px solid #e23b3b !important}
/* Etapa 2: rafinare randuri canal (hover + tranzitii) */
.file-row{transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease);}
.file-row:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:#3a3a3a;}
.file-row.breaking-row:hover{border-color:var(--breaking-red);box-shadow:var(--sh-md),0 0 0 1px rgba(220,53,69,.25);}
.file-row.alert-row:hover{border-color:var(--alert-orange);box-shadow:var(--sh-md),0 0 0 1px rgba(226,59,59,.3);}
/* Etapa 3: feedback la apasare pe butoane */
.btn-save,.btn-breaking,.btn-alert,.btn-send-sm,.btn-obj,.icon-btn{transition:transform var(--t-fast) var(--ease),background var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease);}
.btn-save:hover,.btn-breaking:hover,.btn-alert:hover,.btn-send-sm:hover{transform:translateY(-1px);box-shadow:var(--sh-sm);}
.btn-save:active,.btn-breaking:active,.btn-alert:active,.btn-send-sm:active,.btn-obj:active{transform:translateY(1px) scale(.98);}
.btn-obj:hover{transform:translateY(-1px);}
/* Etapa 4: rafinare ON-AIR (glow care respira + tranzitie stare) */
.onair-ind{transition:background var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease);}
.onair-ind.on{animation:onairGlow 1.6s var(--ease) infinite;}
@keyframes onairGlow{
  0%,100%{background:#e23b3b;box-shadow:0 0 0 0 rgba(226,59,59,.5),0 0 12px rgba(226,59,59,.4);}
  50%{background:#c0302f;box-shadow:0 0 0 5px rgba(226,59,59,0),0 0 18px rgba(226,59,59,.6);}
}
.conn-dot,.obj-state-dot{transition:background var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease);}
/* Etapa 5: focus states pe inputuri */
.char-field,.form-control{transition:border-color var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),background var(--t-base) var(--ease);}
.char-field:focus,.form-control:focus{border-color:var(--text-green);box-shadow:var(--ring-green);outline:none;}
.breaking-input:focus{border-color:var(--breaking-red);box-shadow:0 0 0 3px rgba(220,53,69,.22);}
.alert-input:focus{border-color:#e23b3b;box-shadow:0 0 0 3px rgba(226,59,59,.22);}
