* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --laranja: #ff7a00; --laranja2: #ff9d3c;
  --bg: #0f1115; --card: #1a1d24; --card2: #232733;
  --txt: #f2f4f8; --mut: #9aa3b2; --verde: #25d366; --vermelho: #ff4757;
}
body { font-family: -apple-system, "Segoe UI", Roboto, sans-serif; background: var(--bg); color: var(--txt); height: 100vh; overflow: hidden; }

/* ---- Login ---- */
.login-wrap { display: flex; height: 100vh; align-items: center; justify-content: center; }
.login-box { background: var(--card); padding: 36px; border-radius: 18px; width: 340px; text-align: center; box-shadow: 0 10px 40px rgba(0,0,0,.5); }
.login-box h1 { font-size: 22px; margin-bottom: 4px; }
.login-box p { color: var(--mut); font-size: 14px; margin-bottom: 22px; }
.login-box input { width: 100%; padding: 14px; margin-bottom: 12px; border-radius: 10px; border: 1px solid #333; background: #11141a; color: var(--txt); font-size: 16px; }
.btn { background: linear-gradient(135deg, var(--laranja), var(--laranja2)); color: #fff; border: none; padding: 14px; border-radius: 10px; font-size: 16px; font-weight: 700; cursor: pointer; width: 100%; }
.btn:hover { filter: brightness(1.08); }
.erro { color: var(--vermelho); font-size: 13px; min-height: 18px; }

/* ---- Topbar ---- */
.top { height: 56px; background: var(--card); display: flex; align-items: center; padding: 0 18px; gap: 12px; border-bottom: 1px solid #262a33; }
.top .logo { font-weight: 800; color: var(--laranja); font-size: 18px; }
.top .sp { flex: 1; }
.top .quem { color: var(--mut); font-size: 13px; }
.top a.sair { color: var(--mut); text-decoration: none; font-size: 13px; }

/* ---- Produtor: 3 colunas ---- */
.produtor { display: grid; grid-template-columns: 300px 1fr; height: calc(100vh - 56px); }
.lista { border-right: 1px solid #262a33; overflow-y: auto; }
.conv { padding: 12px 14px; border-bottom: 1px solid #20242d; cursor: pointer; }
.conv:hover, .conv.ativa { background: var(--card2); }
.conv .n { font-weight: 600; font-size: 15px; }
.conv .u { color: var(--mut); font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat { display: flex; flex-direction: column; height: 100%; }
.msgs { flex: 1; overflow-y: auto; padding: 18px; display: flex; flex-direction: column; gap: 8px; }
.bolha { max-width: 70%; padding: 10px 14px; border-radius: 14px; font-size: 15px; line-height: 1.35; }
.bolha.in { background: var(--card2); align-self: flex-start; }
.bolha.out { background: #14532d; align-self: flex-end; }
.bolha audio { width: 260px; margin-top: 6px; display: block; }
.bolha .aprovar { margin-top: 8px; background: var(--laranja); color: #fff; border: none; padding: 6px 12px; border-radius: 8px; font-size: 13px; cursor: pointer; font-weight: 700; }
.bolha .aprovar.ok { background: var(--verde); }

/* respostas prontas */
.respostas { padding: 10px 14px; border-top: 1px solid #262a33; display: flex; flex-wrap: wrap; gap: 8px; background: var(--card); }
.chip { background: var(--card2); border: 1px solid #333; color: var(--txt); padding: 8px 12px; border-radius: 20px; font-size: 14px; cursor: pointer; }
.chip:hover { background: var(--laranja); border-color: var(--laranja); }
.envio { display: flex; gap: 8px; padding: 10px 14px; border-top: 1px solid #262a33; }
.envio input { flex: 1; padding: 12px; border-radius: 10px; border: 1px solid #333; background: #11141a; color: var(--txt); font-size: 15px; }
.envio button { width: 90px; }
.vazio { color: var(--mut); text-align: center; margin-top: 40px; }

/* ---- Locutor: soundboard ---- */
.locutor { display: grid; grid-template-columns: 280px 1fr; height: calc(100vh - 56px); }
.banco { border-right: 1px solid #262a33; overflow-y: auto; padding: 12px; }
.banco h3 { font-size: 13px; color: var(--mut); text-transform: uppercase; margin-bottom: 10px; letter-spacing: .5px; }
.clipe { background: var(--card2); border: 1px solid #333; border-radius: 10px; padding: 10px; margin-bottom: 8px; cursor: grab; }
.clipe:active { cursor: grabbing; }
.clipe .cn { font-weight: 600; font-size: 14px; }
.clipe .cc { color: var(--mut); font-size: 12px; }
.clipe .ct { font-size: 12px; color: var(--laranja2); margin-top: 4px; }
.mesa { padding: 18px; overflow-y: auto; }
.mesa h2 { margin-bottom: 14px; font-size: 18px; }
.pads { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
.pad { background: var(--card); border: 2px dashed #3a3f4b; border-radius: 14px; min-height: 120px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 12px; text-align: center; cursor: pointer; transition: .12s; position: relative; }
.pad.cheio { border-style: solid; border-color: var(--laranja); background: linear-gradient(160deg, #2a1d10, var(--card)); }
.pad.tocando { box-shadow: 0 0 0 3px var(--verde), 0 0 24px var(--verde); }
.pad.drag { border-color: var(--verde); background: #14532d; }
.pad .num { position: absolute; top: 6px; left: 10px; color: var(--mut); font-size: 12px; }
.pad .nome { font-weight: 700; font-size: 15px; }
.pad .cidade { color: var(--mut); font-size: 12px; }
.pad .dur { color: var(--laranja2); font-size: 13px; margin-top: 6px; }
.pad .x { position: absolute; top: 4px; right: 8px; color: var(--mut); cursor: pointer; font-size: 16px; }
.pad .editar { position: absolute; bottom: 6px; right: 8px; color: var(--mut); font-size: 12px; cursor: pointer; }
.pad .vazio-lbl { color: var(--mut); font-size: 13px; }

/* editor de corte (modal) */
.modal-bg { position: fixed; inset: 0; background: rgba(0,0,0,.6); display: none; align-items: center; justify-content: center; z-index: 50; }
.modal-bg.on { display: flex; }
.modal { background: var(--card); padding: 24px; border-radius: 16px; width: 460px; }
.modal h3 { margin-bottom: 14px; }
.modal label { display: block; font-size: 13px; color: var(--mut); margin: 10px 0 4px; }
.modal input[type=range] { width: 100%; }
.modal .linha { display: flex; gap: 10px; margin-top: 16px; }
.modal .linha button { flex: 1; }
.btn-sec { background: var(--card2); border: 1px solid #333; color: var(--txt); padding: 12px; border-radius: 10px; cursor: pointer; font-weight: 600; }
