/* ═══════════════════════════════════════════════════════════
   TimerSpeak — design tokens
   ═══════════════════════════════════════════════════════════ */
:root {
  --bg:#07090d; --surface:#0d1117; --surface2:#161b22;
  --border:#21262d; --border-hi:#30363d;
  --blue:#58a6ff; --blue-soft:#7cb8ff;
  --green:#3fb950; --green-glow:rgba(63,185,80,.15);
  --yellow:#d29922; --yellow-glow:rgba(210,153,34,.15);
  --red:#f85149; --red-glow:rgba(248,81,73,.15);
  --text:#e6edf3; --muted:#8b949e;
  --mono:'Courier New',Courier,monospace;
  --sans:'Segoe UI','Helvetica Neue',Helvetica,Arial,sans-serif;

  /* Escalas e cores do projetor (controladas via JS) */
  --proj-name-s: 1;
  --proj-time-s: 1;
  --proj-name-c: #ffffff;
  --proj-time-c: #3fb950;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{width:100%;height:100%;}
body{font-family:var(--sans);background:var(--bg);color:var(--text);}
.bg-base{display:flex;flex-direction:column;overflow:hidden;}

@keyframes blink  {50%{opacity:.35;}}
@keyframes pulse  {0%,100%{opacity:1;}50%{opacity:.4;}}
@keyframes fadein {from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes glow-green  {0%,100%{box-shadow:0 0 0 0 var(--green-glow);}50%{box-shadow:0 0 28px 6px var(--green-glow);}}
@keyframes glow-yellow {0%,100%{box-shadow:0 0 0 0 var(--yellow-glow);}50%{box-shadow:0 0 28px 6px var(--yellow-glow);}}
@keyframes glow-red    {0%,100%{box-shadow:0 0 0 0 var(--red-glow);}50%{box-shadow:0 0 40px 10px var(--red-glow);}}

.hidden{display:none!important;}

/* ─── BOTÕES ─────────────────────────────────────────── */
.btn{font-family:var(--sans);font-weight:700;font-size:.8rem;letter-spacing:1px;text-transform:uppercase;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;gap:6px;}
.btn:hover{opacity:.82;transform:translateY(-1px);}
.btn:active{transform:translateY(0);}
.btn-sm{padding:5px 11px;font-size:.7rem;}
.btn-blue{background:var(--blue);color:#000;}
.btn-green{background:var(--green);color:#000;}
.btn-red{background:var(--red);color:#fff;}
.btn-ghost{background:var(--surface2);color:#fff;border:1px solid var(--border);}
.btn-ghost.active{border-color:var(--blue);color:var(--blue);}
.btn-block{display:block;width:100%;padding:14px;font-size:1rem;margin-top:4px;text-align:center;justify-content:center;}

/* ─── FORM FIELDS ────────────────────────────────────── */
.fg{margin-bottom:14px;}
.fg label{display:block;font-family:var(--mono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:6px;}
.fg input,.fg textarea,.fg select{width:100%;padding:9px 12px;background:var(--bg);color:#fff;border:1px solid var(--border);border-radius:4px;font-family:var(--mono);font-size:.92rem;transition:border-color .15s;resize:vertical;}
.fg input:focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--blue);}
.fg textarea{min-height:110px;font-size:.92rem;}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg label.cb{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:.5px;font-size:.82rem;cursor:pointer;}
.fg label.cb input{width:auto;}
.muted{color:var(--muted);font-weight:normal;text-transform:none;letter-spacing:0;font-size:.72rem;}

/* ═══════════════════════════════════════════════════════════
   AUTH (login, register, forgot, reset)
   ═══════════════════════════════════════════════════════════ */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;}
.auth-wrap{width:100%;max-width:420px;}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:42px 36px 28px;}

.brand{
  text-align:center;
  font-family:var(--sans);
  font-weight:900;
  font-size:2.6rem;
  letter-spacing:4px;
  line-height:1;
  user-select:none;
  margin-bottom:6px;
}
.brand-timer{color:#fff;}
.brand-speak{color:var(--blue);}

.auth-sub{text-align:center;color:var(--muted);font-family:var(--mono);font-size:.72rem;letter-spacing:3px;text-transform:uppercase;margin:14px 0 24px;}
.auth-form{margin-top:8px;}
.auth-error{background:rgba(248,81,73,.12);border:1px solid rgba(248,81,73,.4);color:var(--red);padding:11px 14px;border-radius:4px;font-size:.85rem;margin-bottom:16px;text-align:center;}
.auth-ok{background:rgba(63,185,80,.1);border:1px solid rgba(63,185,80,.4);color:var(--green);padding:11px 14px;border-radius:4px;font-size:.85rem;margin-bottom:16px;text-align:center;}
.auth-links{text-align:center;margin-top:18px;font-size:.82rem;}
.auth-links a{color:var(--blue);text-decoration:none;}
.auth-links a:hover{text-decoration:underline;}
.auth-sep{color:var(--muted);margin:0 6px;}
.auth-foot{text-align:center;margin-top:18px;font-family:var(--mono);font-size:.6rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase;}

/* ═══════════════════════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════════════════════ */
.dash-top{background:var(--surface);border-bottom:1px solid var(--border);height:54px;padding:0 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.dash-top-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1;}
.dash-sep{width:1px;height:20px;background:var(--border-hi);flex-shrink:0;}
.dash-ev-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:3px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.dash-ev-name{font-size:1.05rem;font-weight:700;color:var(--blue);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
.dash-top-right{display:flex;gap:8px;align-items:center;flex-shrink:0;}
.dash-back{color:var(--muted);text-decoration:none;font-size:1.3rem;padding:4px 10px;border-radius:3px;flex-shrink:0;}
.dash-back:hover{background:var(--surface2);color:#fff;}

.user-chip{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);font-family:var(--mono);}
.role-tag{padding:2px 8px;border-radius:3px;font-size:.62rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.role-tag.role-admin{background:rgba(248,81,73,.15);color:var(--red);}
.role-tag.role-premium{background:rgba(210,153,34,.18);color:var(--yellow);}
.role-tag.role-user,.role-tag.role-operator{background:rgba(88,166,255,.15);color:var(--blue);}

/* Pílula de acesso na topbar (dias restantes) */
.access-pill{
  font-family:var(--mono);
  font-size:.66rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:3px 10px;
  border-radius:11px;
  border:1px solid transparent;
  white-space:nowrap;
  font-weight:700;
  margin-left:6px;
}
.access-pill-unlimited{color:var(--muted);border-color:var(--border-hi);background:transparent;}
.access-pill-ok      {color:var(--green); background:rgba(63,185,80,.12); border-color:rgba(63,185,80,.25);}
.access-pill-warn    {color:var(--yellow);background:rgba(210,153,34,.15);border-color:rgba(210,153,34,.3);}
.access-pill-danger  {color:var(--red);   background:rgba(248,81,73,.13); border-color:rgba(248,81,73,.3); animation:pulse 2s ease-in-out infinite;}
.access-pill-expired {color:#fff;         background:var(--red);          border-color:var(--red);}

.conn-indicator{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.conn-dot{width:7px;height:7px;border-radius:50%;background:var(--yellow);animation:pulse 1.2s infinite;}
.conn-indicator.ok .conn-dot{background:var(--green);animation:none;}
.conn-indicator.err .conn-dot{background:var(--red);animation:pulse .6s infinite;}

/* ═══════════════════════════════════════════════════════════
   ADMIN / EVENTS WRAPPER
   ═══════════════════════════════════════════════════════════ */
.admin-wrap{padding:26px 22px;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:18px;overflow:auto;height:calc(100vh - 54px);}
.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:22px 24px;}
.admin-h{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.admin-h h2{font-size:1.1rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);}
.admin-help{font-size:.82rem;color:var(--muted);margin-bottom:12px;line-height:1.5;}
.admin-help code{background:var(--surface2);padding:2px 6px;border-radius:3px;font-family:var(--mono);font-size:.82rem;color:#fff;}

/* Tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);padding-bottom:0;margin:0;}
.tab{background:none;border:none;color:var(--muted);padding:11px 20px;cursor:pointer;font-family:var(--mono);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;border-bottom:2px solid transparent;transition:all .15s;}
.tab:hover{color:#fff;}
.tab.active{color:var(--blue);border-bottom-color:var(--blue);}

/* Tabela */
.admin-table-wrap{overflow-x:auto;}
.admin-table{width:100%;border-collapse:collapse;font-size:.88rem;}
.admin-table th{text-align:left;padding:11px 13px;font-family:var(--mono);font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);font-weight:normal;}
.admin-table td{padding:12px 13px;border-bottom:1px solid var(--border);vertical-align:middle;}
.admin-table tbody tr:hover{background:rgba(255,255,255,.02);}
.admin-table .empty{text-align:center;color:var(--muted);padding:30px;font-style:italic;}
.admin-table .row-actions{display:flex;gap:6px;justify-content:flex-end;}
.btn-icon{background:var(--surface2);border:1px solid var(--border);color:#fff;width:32px;height:32px;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;}
.btn-icon:hover{border-color:var(--border-hi);}
.btn-icon.danger:hover{background:rgba(248,81,73,.15);border-color:var(--red);color:var(--red);}

.badge{display:inline-block;padding:3px 9px;border-radius:3px;font-size:.66rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.badge.b-active{background:rgba(63,185,80,.15);color:var(--green);}
.badge.b-inactive{background:rgba(248,81,73,.12);color:var(--red);}
.badge.b-admin{background:rgba(248,81,73,.15);color:var(--red);}
.badge.b-premium{background:rgba(210,153,34,.18);color:var(--yellow);}
.badge.b-user,.badge.b-operator{background:rgba(88,166,255,.15);color:var(--blue);}

/* Página /profile.php — layout compacto sem scroll */
.profile-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  height:auto;
  overflow:visible;
  padding:18px 22px;
}
/* O 3º card (Logo) ocupa toda a largura abaixo */
.profile-wrap > section:nth-child(3){
  grid-column:1 / -1;
}
.profile-wrap .admin-card{padding:14px 18px;}
.profile-wrap .admin-h{margin-bottom:8px;padding-bottom:8px;}
.profile-wrap .admin-h h2{font-size:.95rem;letter-spacing:2px;}
.profile-wrap .admin-help{font-size:.74rem;margin-bottom:10px;line-height:1.45;}
.profile-wrap .fg{margin-bottom:8px;}
.profile-wrap .fg label{margin-bottom:3px;font-size:.66rem;}
.profile-wrap .fg input{padding:7px 9px;font-size:.85rem;}
.profile-wrap .settings-form{max-width:none;}

@media (max-width: 820px){
  .profile-wrap{grid-template-columns:1fr;}
  .profile-wrap > section:nth-child(3){grid-column:1;}
}

.profile-grid{display:grid;grid-template-columns:160px 1fr;gap:20px;align-items:start;}
@media (max-width: 700px) {
  .profile-grid{grid-template-columns:1fr;}
}
.profile-preview{display:flex;flex-direction:column;align-items:center;gap:8px;}
.profile-preview-label{font-family:var(--mono);font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
.profile-preview-box{
  width:140px;height:140px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.03) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.03) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(255,255,255,.03) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(255,255,255,.03) 75%);
  background-size:16px 16px;
  background-position:0 0, 0 8px, 8px -8px, -8px 0px;
}
.profile-preview-box img{max-width:80%;max-height:80%;object-fit:contain;}
.profile-preview-state{font-size:.78rem;}
.profile-actions input[type="file"]{
  width:100%;padding:7px;background:var(--bg);color:#fff;
  border:1px solid var(--border);border-radius:4px;
  font-family:var(--mono);font-size:.78rem;
  cursor:pointer;
}
.profile-actions input[type="file"]::file-selector-button{
  background:var(--surface2);border:1px solid var(--border-hi);color:#fff;
  padding:5px 10px;border-radius:3px;font-family:var(--mono);
  font-size:.72rem;cursor:pointer;margin-right:8px;
}

/* Badges de acesso (data + dias restantes) */
.badge.b-access-unlimited{background:transparent;color:var(--muted);border:1px dashed var(--border-hi);text-transform:none;letter-spacing:.5px;font-weight:600;}
.badge.b-access-ok{background:rgba(63,185,80,.13);color:var(--green);text-transform:none;letter-spacing:.3px;}
.badge.b-access-warn{background:rgba(210,153,34,.15);color:var(--yellow);text-transform:none;letter-spacing:.3px;}
.badge.b-access-danger{background:rgba(248,81,73,.13);color:var(--red);text-transform:none;letter-spacing:.3px;animation:pulse 2s ease-in-out infinite;}
.badge.b-access-expired{background:rgba(248,81,73,.2);color:var(--red);border:1px solid rgba(248,81,73,.5);}

.settings-form{max-width:580px;}
.empty-state{padding:40px;text-align:center;color:var(--muted);font-style:italic;}

/* Caixa informativa de presets SMTP */
.smtp-presets{
  background:rgba(88,166,255,.07);
  border:1px solid rgba(88,166,255,.25);
  border-left:3px solid var(--blue);
  border-radius:4px;
  padding:12px 16px;
  margin-bottom:16px;
  font-size:.85rem;
  line-height:1.6;
  color:var(--text);
}
.smtp-presets code{
  background:var(--bg);
  padding:2px 7px;
  border-radius:3px;
  font-family:var(--mono);
  font-size:.85rem;
  color:var(--blue);
}
.smtp-presets em{font-style:italic;color:var(--yellow);}
.smtp-presets a{color:var(--blue);}

/* Caixa de log SMS — terminal-style */
.sms-log{
  margin-top:16px;
  background:#000;
  color:#9be39b;
  border:1px solid var(--border-hi);
  border-radius:4px;
  padding:14px;
  font-family:var(--mono);
  font-size:.72rem;
  line-height:1.45;
  max-height:380px;
  overflow:auto;
  white-space:pre-wrap;
  word-break:break-all;
}

/* Toggle Basic/OAuth2 */
.auth-toggle{display:flex;gap:8px;flex-wrap:wrap;}
.auth-toggle-opt{
  flex:1; min-width:220px;
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:5px;
  cursor:pointer;
  transition:border-color .15s,background .15s;
  font-size:.85rem;
}
.auth-toggle-opt:hover{border-color:var(--blue);}
.auth-toggle-opt input[type=radio]{accent-color:var(--blue);}
.auth-toggle-opt:has(input:checked){
  border-color:var(--blue);
  background:rgba(88,166,255,.08);
}

/* ─── EVENTS LIST (cards) ──────────────────────────── */
.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px;}
.ev-card{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:18px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s;}
.ev-card:hover{border-color:var(--border-hi);}
.ev-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
.ev-name{font-size:1.05rem;font-weight:700;color:#fff;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ev-actions{display:flex;gap:4px;}
.ev-meta{display:flex;flex-direction:column;gap:2px;font-size:.74rem;color:var(--muted);font-family:var(--mono);}
.ev-enter{margin-top:6px;justify-content:center;text-align:center;}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadein .15s ease;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;width:100%;max-width:480px;display:flex;flex-direction:column;}
.modal header{padding:18px 24px;border-bottom:1px solid var(--border);}
.modal header h3{font-size:1rem;letter-spacing:2px;text-transform:uppercase;color:var(--blue);font-weight:700;}
.modal-body{padding:20px 24px;}
.modal footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid var(--border);}

/* ═══════════════════════════════════════════════════════════
   EVENT (dashboard de controlo)
   ═══════════════════════════════════════════════════════════ */
#dash-setup{flex:1;display:flex;align-items:center;justify-content:center;padding:26px 22px;overflow:auto;}
.setup-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:30px 30px 24px;width:100%;max-width:580px;}
.setup-box h2{font-size:1.1rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border);}

.setup-event-name{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;margin-bottom:24px;}
.setup-event-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:3px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.setup-event-val{font-size:1rem;font-weight:700;color:#fff;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.setup-event-edit{color:var(--muted);text-decoration:none;flex-shrink:0;font-size:1rem;padding:4px 8px;border-radius:3px;}
.setup-event-edit:hover{background:var(--bg);color:var(--blue);}

.s-section{font-family:var(--mono);font-size:.62rem;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);}

.pos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;width:100%;}
.pos-btn{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:9px 4px;cursor:pointer;font-size:.7rem;color:var(--muted);text-align:center;transition:all .15s;letter-spacing:1px;}
.pos-btn:hover{border-color:var(--border-hi);color:#fff;}
.pos-btn.sel{background:rgba(88,166,255,.15);border-color:var(--blue);color:var(--blue);font-weight:700;}

#dash-main{display:none;flex:1;flex-direction:column;overflow:hidden;}
.dash-toolbar{padding:12px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0;}
.add-inp{padding:9px 13px;background:var(--surface2);color:#fff;border:1px solid var(--border);border-radius:4px;font-family:var(--mono);font-size:.92rem;width:240px;transition:border-color .15s;}
.add-inp:focus{outline:none;border-color:var(--green);}

#gs-panel,#proj-panel,#links-panel{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 22px;display:none;align-items:center;gap:18px;flex-shrink:0;flex-wrap:wrap;}
.gs-panel-label{font-family:var(--mono);font-size:.66rem;letter-spacing:3px;text-transform:uppercase;color:var(--muted);white-space:nowrap;}
.gs-sep{width:1px;height:26px;background:var(--border-hi);flex-shrink:0;}

#links-panel .lp-section{display:flex;align-items:center;gap:8px;flex:1;min-width:320px;}
.lp-label{font-family:var(--mono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);white-space:nowrap;}
.lp-url{flex:1;background:var(--bg);color:#fff;border:1px solid var(--border);padding:6px 10px;border-radius:3px;font-family:var(--mono);font-size:.78rem;min-width:0;}

.color-toggle{display:flex;gap:5px;}
.color-btn{padding:6px 15px;border-radius:3px;border:1px solid var(--border);background:var(--surface2);color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .15s;letter-spacing:1px;}
.color-btn.sel-black{background:#111;border-color:#555;}
.color-btn.sel-white{background:#fff;color:#000;border-color:#ccc;}

.pos-mini{display:grid;grid-template-columns:repeat(3,24px);grid-template-rows:repeat(3,24px);gap:3px;}
.pos-mini-btn{background:var(--surface2);border:1px solid var(--border);border-radius:3px;cursor:pointer;transition:all .15s;font-size:.7rem;}
.pos-mini-btn:hover{background:var(--border-hi);}
.pos-mini-btn.sel{background:rgba(88,166,255,.25);border-color:var(--blue);}

/* ─── Sliders ─────────────────────────────────────────── */
.slider-group{display:flex;align-items:center;gap:10px;}
.slider-group label{font-family:var(--mono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);min-width:50px;}
.slider-group input[type=range]{width:160px;height:24px;-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer;}
.slider-group input[type=range]::-webkit-slider-runnable-track{height:5px;background:var(--surface2);border:1px solid var(--border);border-radius:3px;}
.slider-group input[type=range]::-moz-range-track{height:5px;background:var(--surface2);border:1px solid var(--border);border-radius:3px;}
.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--blue);border:2px solid var(--bg);margin-top:-7px;transition:transform .1s;}
.slider-group input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--blue);border:2px solid var(--bg);transition:transform .1s;cursor:pointer;}
.slider-group input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.15);}
.slider-group input[type=range]:hover::-moz-range-thumb{transform:scale(1.15);}
.slider-val{font-family:var(--mono);font-size:.85rem;color:#fff;min-width:50px;text-align:right;font-weight:700;}

#dash-grid{flex:1;overflow-y:auto;padding:18px 22px 22px;display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:15px;align-content:start;}

/* ─── Timer card (FONTES MAIORES) ─────────────────────── */
.t-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:20px 18px 16px;display:flex;flex-direction:column;gap:11px;position:relative;transition:border-color .25s,box-shadow .25s;}
.t-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:6px 6px 0 0;background:var(--border-hi);transition:background .25s;}
.t-card.s-run {border-color:rgba(63,185,80,.4); box-shadow:0 0 18px var(--green-glow);}  .t-card.s-run::before {background:var(--green);}
.t-card.s-warn{border-color:rgba(210,153,34,.4);box-shadow:0 0 18px var(--yellow-glow);} .t-card.s-warn::before{background:var(--yellow);}
.t-card.s-dead{border-color:rgba(248,81,73,.4); box-shadow:0 0 18px var(--red-glow);}   .t-card.s-dead::before{background:var(--red);}
.tc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.tc-name{font-size:1.15rem;font-weight:700;color:#fff;flex:1;min-width:0;letter-spacing:.3px;line-height:1.25;white-space:normal;overflow-wrap:break-word;word-break:break-word;}
.tc-del{background:transparent;border:1px solid var(--border);color:#fff;width:24px;height:24px;border-radius:3px;cursor:pointer;font-size:.78rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s,color .15s;}
.tc-del:hover{background:rgba(248,81,73,.15);border-color:var(--red);color:var(--red);}
.tc-adj{display:flex;gap:5px;justify-content:center;}
.tc-adj button{background:var(--surface2);border:1px solid var(--border);color:#fff;padding:4px 10px;border-radius:3px;font-family:var(--mono);font-size:.78rem;cursor:pointer;transition:background .1s;}
.tc-adj button:hover{background:var(--border-hi);}
.tc-time{font-family:var(--mono);font-size:3.1rem;font-weight:bold;letter-spacing:3px;text-align:center;color:#fff;line-height:1;padding:4px 0;transition:color .25s;}
.t-card.s-run  .tc-time{color:var(--green);}
.t-card.s-warn .tc-time{color:var(--yellow);}
.t-card.s-dead .tc-time{color:var(--red);animation:blink .8s ease-in-out infinite;}
.tc-ctrl{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;}
.tc-ctrl button{border:none;border-radius:4px;cursor:pointer;font-size:1.1rem;padding:11px;transition:opacity .15s,transform .1s;}
.tc-ctrl button:hover{opacity:.78;transform:scale(1.04);}
.tc-ctrl button:active{transform:scale(.98);}
.b-play {background:rgba(63,185,80,.15); border:1px solid rgba(63,185,80,.4)!important; color:var(--green);}
.b-pause{background:rgba(210,153,34,.12);border:1px solid rgba(210,153,34,.4)!important;color:var(--yellow);}
.b-reset{background:rgba(248,81,73,.1);  border:1px solid rgba(248,81,73,.4)!important; color:var(--red);}
.tc-status{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;color:#fff;}
.tc-dot{width:7px;height:7px;border-radius:50%;background:var(--border-hi);flex-shrink:0;}
.t-card.s-run  .tc-dot{background:var(--green);animation:pulse 1.5s infinite;}
.t-card.s-warn .tc-dot{background:var(--yellow);animation:pulse 1s infinite;}
.t-card.s-dead .tc-dot{background:var(--red);}

/* ═══════════════════════════════════════════════════════════
   PROJECTOR
   ═══════════════════════════════════════════════════════════ */
.proj-body{overflow:hidden;display:flex;flex-direction:column;}
#proj-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:0;transition:background .5s;}
#proj-main.pg-run  {background:radial-gradient(ellipse at 50% 55%,rgba(63,185,80,.07) 0%,transparent 65%);}
#proj-main.pg-warn {background:radial-gradient(ellipse at 50% 55%,rgba(210,153,34,.09) 0%,transparent 65%);}
#proj-main.pg-dead {background:radial-gradient(ellipse at 50% 55%,rgba(248,81,73,.11) 0%,transparent 65%);}

#proj-grid{display:grid;width:100%;height:100%;padding:14px;gap:10px;}
.pg-card{background:var(--surface);border:2px solid var(--border);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5em;overflow:hidden;position:relative;transition:border-color .3s;padding:8px;}
.pg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--border-hi);transition:background .3s;}
.pg-card.s-run {border-color:var(--green); animation:glow-green  2.5s ease-in-out infinite;}.pg-card.s-run::before {background:var(--green);}
.pg-card.s-warn{border-color:var(--yellow);animation:glow-yellow 2s ease-in-out infinite;} .pg-card.s-warn::before{background:var(--yellow);}
.pg-card.s-dead{border-color:var(--red);   animation:glow-red    1.5s ease-in-out infinite;}.pg-card.s-dead::before{background:var(--red);}

/* Modo grid: usa CSS vars dinâmicas + min() para nome ≤ tempo (cap a 85% do tempo) */
.pg-name{
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  color: var(--proj-name-c);
  text-align:center;
  line-height:1.15;
  max-width:96%;
  white-space:normal;
  overflow-wrap:break-word;
  word-break:break-word;
  font-size: min(
    calc(var(--pg-name-base, 2vw) * var(--proj-name-s)),
    calc(var(--pg-time-base, 4vw) * var(--proj-time-s) * 0.95)
  );
  transition: font-size .2s, color .3s;
}
.pg-time{
  font-family:var(--mono);
  font-weight:bold;
  letter-spacing:3px;
  line-height:1;
  text-align:center;
  color:#fff;
  font-size: calc(var(--pg-time-base, 4vw) * var(--proj-time-s));
  transition: font-size .2s, color .3s;
}
.pg-card.s-run  .pg-time{color: var(--proj-time-c);}
.pg-card.s-warn .pg-time{color:var(--yellow);}
.pg-card.s-dead .pg-time{color:var(--red);animation:blink .8s ease-in-out infinite;}

#proj-spot{display:none;flex-direction:column;align-items:center;justify-content:center;gap:2.2vh;animation:fadein .3s ease;padding:20px;text-align:center;width:100%;}
#ps-label{font-family:var(--mono);font-size:clamp(.6rem,1vw,.95rem);letter-spacing:5px;text-transform:uppercase;color:var(--green);transition:color .3s;}
#ps-label.lw{color:var(--yellow);}#ps-label.ld{color:var(--red);}

#ps-name{
  font-size: min(
    calc(clamp(1.8rem, 8vw, 9vw) * var(--proj-name-s)),
    calc(clamp(3rem, 18vw, 21vw) * var(--proj-time-s) * 0.95)
  );
  font-weight:900;
  letter-spacing:2px;
  text-transform:uppercase;
  color: var(--proj-name-c);
  line-height:1.05;
  max-width:96vw;
  white-space:normal;
  overflow-wrap:break-word;
  word-break:break-word;
  text-align:center;
  transition:font-size .2s, color .3s;
}
#ps-bar{width:72px;height:3px;background:var(--green);border-radius:2px;transition:background .3s,width .3s;}
#ps-bar.bw{background:var(--yellow);}#ps-bar.bd{background:var(--red);width:110px;}

#ps-time{
  font-family:var(--mono);
  font-size: calc(clamp(3rem, 18vw, 21vw) * var(--proj-time-s));
  font-weight:bold;
  letter-spacing:4px;
  line-height:1;
  color: var(--proj-time-c);
  transition:font-size .2s, color .3s;
}
#ps-time.tw{color:var(--yellow);}#ps-time.td{color:var(--red);animation:blink .7s ease-in-out infinite;}

#proj-idle{display:flex;flex-direction:column;align-items:center;gap:16px;opacity:.22;}
.idle-icon{font-size:5vw;}.idle-txt{font-family:var(--mono);font-size:1.3vw;letter-spacing:5px;text-transform:uppercase;color:#fff;}

#proj-bar{background:var(--surface);border-top:1px solid var(--border);height:78px;display:flex;align-items:stretch;flex-shrink:0;}
#proj-queue-wrap{flex:1;min-width:0;position:relative;overflow:hidden;}
#proj-queue-wrap::before,#proj-queue-wrap::after{content:'';position:absolute;top:0;bottom:0;width:28px;pointer-events:none;z-index:2;}
#proj-queue-wrap::before{left:0; background:linear-gradient(to right,var(--surface),transparent);}
#proj-queue-wrap::after {right:0;background:linear-gradient(to left, var(--surface),transparent);}
#proj-queue{display:flex;align-items:center;gap:8px;height:100%;padding:10px 14px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;}
#proj-queue::-webkit-scrollbar{display:none;}
.pq-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:5px 14px;height:100%;min-width:110px;max-width:200px;flex-shrink:0;position:relative;transition:border-color .3s;}
.pq-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--border-hi);transition:background .3s;}
.pq-card.s-run {border-color:rgba(63,185,80,.5);} .pq-card.s-run::before {background:var(--green);}
.pq-card.s-warn{border-color:rgba(210,153,34,.5);}.pq-card.s-warn::before{background:var(--yellow);}
.pq-card.s-dead{border-color:rgba(248,81,73,.5);} .pq-card.s-dead::before{background:var(--red);}
.pq-name{font-size:.68rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff;white-space:normal;overflow-wrap:break-word;word-break:break-word;line-height:1.2;max-width:100%;text-align:center;}
.pq-time{font-family:var(--mono);font-size:1.1rem;font-weight:bold;color:#fff;letter-spacing:2px;line-height:1.3;}
.pq-card.s-warn .pq-time{color:var(--yellow);}
.pq-card.s-dead .pq-time{color:var(--red);}
.bar-sep{width:1px;background:var(--border);flex-shrink:0;margin:10px 0;}

#proj-info{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;padding:8px 20px;gap:3px;flex-shrink:0;max-width:40%;}
#pi-event{font-size:.78rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#fff;white-space:normal;overflow-wrap:break-word;word-break:break-word;line-height:1.15;text-align:right;}
#pi-date {font-family:var(--mono);font-size:.6rem;color:var(--muted);letter-spacing:.5px;}
#pi-clock{font-family:var(--mono);font-size:1.35rem;font-weight:bold;color:#fff;letter-spacing:3px;}

/* ═══════════════════════════════════════════════════════════
   GREENSCREEN
   ═══════════════════════════════════════════════════════════ */
.gs-body{background:#00ff00;font-family:var(--sans);overflow:hidden;}
#gs-box{position:fixed;width:250px;display:flex;flex-direction:column;gap:0;overflow:hidden;border-radius:6px;text-align:center;transition:opacity .25s;}
body.box-black #gs-box{background:#000000;}
body.box-white #gs-box{background:#ffffff;}
#gs-event-row{padding:10px 20px 8px;display:flex;align-items:center;gap:8px;text-align:center;}
body.box-black #gs-event-row{border-bottom:1px solid rgba(255,255,255,.12);}
body.box-white #gs-event-row{border-bottom:1px solid rgba(0,0,0,.12);}
#gs-event-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
body.box-black #gs-event-dot{background:rgba(255,255,255,.4);}
body.box-white #gs-event-dot{background:rgba(0,0,0,.35);}
#gs-event-name{font-size:.75rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
body.box-black #gs-event-name{color:rgba(255,255,255,.55);}
body.box-white #gs-event-name{color:rgba(0,0,0,.5);}
#gs-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px;}
#gs-label{font-family:var(--mono);font-size:.65rem;letter-spacing:5px;text-transform:uppercase;line-height:1;}
body.box-black #gs-label{color:rgba(255,255,255,.5);}
body.box-white #gs-label{color:rgba(0,0,0,.45);}
#gs-label.l-run{color:#00c853!important;}
#gs-label.l-warn{color:#ff9800!important;}
#gs-label.l-dead{color:#f44336!important;}
#gs-name{font-size:2rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;line-height:1.05;word-break:break-word;}
body.box-black #gs-name{color:#ffffff;}
body.box-white #gs-name{color:#000000;}
#gs-bottom{display:flex;align-items:center;margin-top:4px;text-align:center;}
#gs-time{font-family:var(--mono);font-size:1.8rem;font-weight:bold;letter-spacing:4px;line-height:1;color:#00c853;white-space:nowrap;transition:color .3s;text-align:center;width:100%;}
#gs-time.t-warn{color:#ff9800;}
#gs-time.t-dead{color:#f44336;}
#gs-idle-body{padding:20px 20px 22px;display:none;}
#gs-idle-text{font-size:1.4rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;line-height:1.1;}
body.box-black #gs-idle-text{color:rgba(255,255,255,.5);}
body.box-white #gs-idle-text{color:rgba(0,0,0,.4);}

.pos-tl{top:32px;left:32px;}
.pos-tc{top:32px;left:50%;transform:translateX(-50%);}
.pos-tr{top:32px;right:32px;}
.pos-cl{top:50%;left:32px;transform:translateY(-50%);}
.pos-cc{top:50%;left:50%;transform:translate(-50%,-50%);}
.pos-cr{top:50%;right:32px;transform:translateY(-50%);}
.pos-bl{bottom:32px;left:32px;}
.pos-bc{bottom:32px;left:50%;transform:translateX(-50%);}
.pos-br{bottom:32px;right:32px;}

/* ═══════════════════════════════════════════════════════════
   WATERMARK (logo de fundo em todas as páginas internas)
   ═══════════════════════════════════════════════════════════ */
.watermark{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}
.watermark img{
  width:min(45vw,500px);
  opacity:.05;
  filter:grayscale(100%);
  user-select:none;
}
/* Elementos por cima do watermark */
.dash-top,#dash-setup,#dash-main,
#gs-panel,#proj-panel,#links-panel,
.admin-wrap{position:relative;z-index:1;}

/* ═══════════════════════════════════════════════════════════
   COLOR PICKER (painel projetor)
   ═══════════════════════════════════════════════════════════ */
.color-group{display:flex;align-items:center;gap:10px;}
.color-group label{font-family:var(--mono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);min-width:50px;}
.color-group input[type=color]{
  -webkit-appearance:none;
  appearance:none;
  width:42px;
  height:28px;
  border:1px solid var(--border);
  border-radius:4px;
  background:var(--surface2);
  cursor:pointer;
  padding:2px;
  transition:border-color .15s;
}
.color-group input[type=color]:hover{border-color:var(--blue);}
.color-group input[type=color]::-webkit-color-swatch-wrapper{padding:0;}
.color-group input[type=color]::-webkit-color-swatch{border:none;border-radius:3px;}
.color-group input[type=color]::-moz-color-swatch{border:none;border-radius:3px;}
.color-val{font-family:var(--mono);font-size:.78rem;color:#fff;text-transform:uppercase;}
