/* ============================================================
   NODE CMS — IDENTIDADE BRUTALISTA
   Preto #0A0A0A · Vermelho #E10600 · Paper #F4F1EA
   Anton / Archivo Black / Space Mono
   ============================================================ */

:root{
  --red:#E10600;
  --red-dim:#9c0a06;
  --black:#0A0A0A;
  --surface:#111111;
  --surface-2:#161616;
  --border:#242424;
  --border-2:#2e2e2e;
  --paper:#F4F1EA;
  --dim:#8a8a8a;
  --dim-2:#5a5a5a;
  --green:#2ecc71;
  --orange:#E67E22;
  --blue:#4A90D9;
  --gold:#C9A84C;
}

*{box-sizing:border-box;margin:0;padding:0}

body{
  background:var(--black);
  color:var(--paper);
  font-family:'Space Mono',monospace;
  font-size:13px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

/* textura grain sutil de fundo */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

a{color:inherit;text-decoration:none}

.mono{font-family:'Space Mono',monospace}
.display{font-family:'Anton',sans-serif;text-transform:uppercase;letter-spacing:.01em}
.heavy{font-family:'Archivo Black',sans-serif;text-transform:uppercase}

h1,h2,h3{font-family:'Archivo Black',sans-serif;text-transform:uppercase;letter-spacing:-.01em;line-height:1.05}
h1{font-size:30px}
h2{font-size:20px}
h3{font-size:15px}

.kicker{
  font-family:'Space Mono',monospace;font-weight:700;font-size:10px;
  letter-spacing:.24em;text-transform:uppercase;color:var(--dim);
}
.kicker.red{color:var(--red)}
.dim{color:var(--dim)}
.red{color:var(--red)}

/* ============================================================
   TOP STATUS BAR
   ============================================================ */
.statusbar{
  position:relative;z-index:2;
  background:var(--red);color:#fff;
  font-family:'Space Mono',monospace;font-weight:700;font-size:10px;
  letter-spacing:.22em;text-transform:uppercase;
  padding:7px 18px;display:flex;justify-content:space-between;align-items:center;
}
.statusbar .blink{animation:blink 1.6s steps(1) infinite}
@keyframes blink{50%{opacity:.25}}

/* ============================================================
   LAYOUT  (sidebar + conteúdo)
   ============================================================ */
.shell{position:relative;z-index:1;display:flex;min-height:calc(100vh - 30px)}

.sidebar{
  width:230px;flex-shrink:0;background:var(--surface);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:calc(100vh - 30px);
}
.brand{padding:22px 20px 18px;border-bottom:1px solid var(--border)}
.brand .wordmark{display:flex;align-items:center;gap:8px}
.wordmark svg{width:30px;height:30px;display:block}
.wordmark .txt{font-family:'Archivo Black',sans-serif;font-size:22px;letter-spacing:.02em;position:relative}
.wordmark .txt .slash{color:var(--red)}
.brand .sub{font-size:9px;letter-spacing:.28em;color:var(--dim);margin-top:6px}

.nav{padding:14px 0;flex:1;overflow-y:auto}
.nav .sec{font-size:9px;letter-spacing:.24em;color:var(--dim-2);padding:14px 20px 6px;text-transform:uppercase}
.nav a{
  display:flex;align-items:center;gap:11px;padding:10px 20px;
  font-size:12px;letter-spacing:.04em;color:var(--paper);
  border-left:3px solid transparent;transition:.12s;text-transform:uppercase;
}
.nav a .ic{width:16px;text-align:center;color:var(--dim);font-size:13px}
.nav a:hover{background:var(--surface-2);border-left-color:var(--red-dim)}
.nav a.active{background:#1b0202;border-left-color:var(--red);color:#fff}
.nav a.active .ic{color:var(--red)}

.userbox{border-top:1px solid var(--border);padding:14px 20px}
.userbox .nm{font-size:12px;font-family:'Archivo Black',sans-serif;text-transform:uppercase}
.userbox .rl{font-size:9px;letter-spacing:.2em;color:var(--red);margin-top:2px}
.userbox a{display:inline-block;margin-top:10px;font-size:10px;letter-spacing:.18em;color:var(--dim);border-bottom:1px solid var(--border-2);padding-bottom:2px}
.userbox a:hover{color:var(--red)}

.main{flex:1;min-width:0;padding:30px 36px 60px}
.pagehead{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:26px;border-bottom:1px solid var(--border);padding-bottom:18px}
.pagehead .ttl{display:flex;flex-direction:column;gap:8px}

/* ============================================================
   CARDS / GRID
   ============================================================ */
.grid{display:grid;gap:14px}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--surface);border:1px solid var(--border);padding:20px}
.card.empty{text-align:center;padding:50px 30px}
.card.empty h2{margin:14px 0 8px}

.stat{background:var(--surface);border:1px solid var(--border);padding:18px 20px;position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;top:0;right:0;width:40px;height:40px;
  background:linear-gradient(135deg,transparent 50%,var(--border) 50%)}
.stat .lbl{font-size:9px;letter-spacing:.22em;color:var(--dim);text-transform:uppercase}
.stat .val{font-family:'Anton',sans-serif;font-size:34px;line-height:1;margin-top:10px;letter-spacing:.01em}
.stat .val.red{color:var(--red)}
.stat .val.green{color:var(--green)}
.stat .sub{font-size:10px;color:var(--dim);margin-top:6px;letter-spacing:.05em}

/* ============================================================
   TABELAS
   ============================================================ */
.tablewrap{border:1px solid var(--border);overflow-x:auto;background:var(--surface)}
table{width:100%;border-collapse:collapse;font-size:12px}
thead th{
  background:var(--surface-2);color:var(--red);
  font-family:'Space Mono',monospace;font-weight:700;font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;text-align:left;padding:12px 14px;border-bottom:1px solid var(--border-2);
  white-space:nowrap;
}
tbody td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:hover{background:var(--surface-2)}
tbody tr:last-child td{border-bottom:none}
td.num{text-align:right;font-variant-numeric:tabular-nums}
.row-link{cursor:pointer}

/* ============================================================
   BADGES / STATUS
   ============================================================ */
.badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.12em;
  padding:4px 9px;text-transform:uppercase;border:1px solid;white-space:nowrap}
.st-green{color:var(--green);border-color:#1d5e36;background:#0c1f14}
.st-orange{color:var(--orange);border-color:#7a4715;background:#1f1408}
.st-blue{color:var(--blue);border-color:#1f4368;background:#0a1521}
.st-gold{color:var(--gold);border-color:#6b5a22;background:#1a1607}
.st-red{color:var(--red);border-color:var(--red-dim);background:#1b0202}
.st-dim{color:var(--dim);border-color:var(--border-2);background:var(--surface-2)}

.tag{display:inline-block;font-size:9px;letter-spacing:.1em;color:var(--dim);
  border:1px solid var(--border-2);padding:2px 7px;margin:2px 2px 0 0;text-transform:uppercase}

.accent-dot{display:inline-block;width:9px;height:9px;margin-right:7px;vertical-align:middle}

/* ============================================================
   BOTÕES / FORMS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--red);color:#fff;border:none;
  font-family:'Space Mono',monospace;font-weight:700;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;padding:11px 20px;transition:.12s;
}
.btn:hover{background:#ff1408}
.btn.ghost{background:transparent;border:1px solid var(--border-2);color:var(--paper)}
.btn.ghost:hover{border-color:var(--red);color:var(--red)}
.btn.sm{padding:7px 13px;font-size:10px}
.btn.danger{background:transparent;border:1px solid var(--red-dim);color:var(--red)}
.btn.danger:hover{background:var(--red);color:#fff}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.toolbar .spacer{flex:1}

label.fld{display:block;margin-bottom:14px}
label.fld .lab{display:block;font-size:9px;letter-spacing:.2em;color:var(--dim);text-transform:uppercase;margin-bottom:6px}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{
  width:100%;background:var(--black);border:1px solid var(--border-2);color:var(--paper);
  font-family:'Space Mono',monospace;font-size:13px;padding:10px 12px;transition:.12s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--red)}
textarea{resize:vertical;min-height:80px;line-height:1.6}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M0 2l5 5 5-5' stroke='%23E10600' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 12px center}

.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.formgrid .full{grid-column:1 / -1}

/* ============================================================
   MODAL
   ============================================================ */
.modal{display:none;position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.82);
  align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal.open{display:flex}
.modal .box{background:var(--surface);border:1px solid var(--border-2);max-width:760px;width:100%;
  position:relative;animation:pop .14s ease-out}
@keyframes pop{from{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}
.modal .box .head{display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.modal .box .body{padding:22px}
.modal .box .foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
.modal .x{cursor:pointer;color:var(--dim);font-size:20px;line-height:1}
.modal .x:hover{color:var(--red)}

/* ============================================================
   ALERTAS / FLASH
   ============================================================ */
.alert{border-left:3px solid var(--red);background:#1b0202;padding:13px 16px;margin-bottom:14px;font-size:12px}
.alert.warn{border-left-color:var(--orange);background:#1f1408;color:#f0c089}
.alert.ok{border-left-color:var(--green);background:#0c1f14;color:#9be3b8}
.alert .k{font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:10px;display:block;margin-bottom:3px}

/* corner mark decorativo */
.cmark{position:relative}
.cmark::before{content:"◢";position:absolute;top:10px;right:12px;color:var(--border-2);font-size:11px}

/* ============================================================
   LOGIN
   ============================================================ */
.login-wrap{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border-2);position:relative}
.login-card .top{background:var(--red);height:6px}
.login-card .inner{padding:38px 34px}
.login-card .lg{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.login-card .lg svg{width:38px;height:38px}
.login-card .lg .txt{font-family:'Archivo Black',sans-serif;font-size:30px;letter-spacing:.02em}
.login-card .lg .txt .slash{color:var(--red)}
.login-card .tagline{font-size:9px;letter-spacing:.28em;color:var(--dim);margin-bottom:30px}
.login-card form{margin-top:8px}
.login-card .btn{width:100%;justify-content:center;margin-top:8px}
.login-card .err{border-left:3px solid var(--red);background:#1b0202;padding:10px 13px;font-size:11px;margin-bottom:18px;color:#ff8b85}
.login-card .hint{margin-top:22px;font-size:10px;color:var(--dim-2);letter-spacing:.05em;line-height:1.7;border-top:1px solid var(--border);padding-top:16px}

/* itinerário / pré-produção */
.prod-section{border:1px solid var(--border);margin-bottom:14px}
.prod-section .ph{background:var(--surface-2);padding:11px 16px;display:flex;justify-content:space-between;align-items:center}
.prod-section .ph .t{font-family:'Archivo Black',sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.prod-section .pb{padding:8px 16px}
.kv{display:flex;border-bottom:1px solid var(--border);padding:9px 0;font-size:12px}
.kv:last-child{border-bottom:none}
.kv .k{width:180px;flex-shrink:0;color:var(--dim);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding-top:1px}
.kv .v{flex:1}

/* thread de mensagens */
.msg{border:1px solid var(--border);padding:12px 14px;margin-bottom:10px;background:var(--surface)}
.msg .mh{display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:.08em;margin-bottom:6px}
.msg .mh .au{color:var(--red);font-weight:700;text-transform:uppercase}
.msg .vis{font-size:8px;letter-spacing:.14em;color:var(--green);border:1px solid #1d5e36;padding:1px 5px;text-transform:uppercase}

/* calendário */
.cal{width:100%;border-collapse:collapse;table-layout:fixed}
.cal th{background:var(--surface-2);color:var(--dim);font-size:9px;letter-spacing:.16em;padding:9px;text-align:center;border:1px solid var(--border)}
.cal td{border:1px solid var(--border);height:96px;vertical-align:top;padding:6px;background:var(--surface);position:relative}
.cal td.out{background:var(--black);opacity:.4}
.cal td .dn{font-family:'Archivo Black',sans-serif;font-size:13px;color:var(--dim)}
.cal td.today .dn{color:var(--red)}
.cal .ev{display:block;font-size:9px;padding:3px 5px;margin-top:4px;border-left:3px solid var(--red);
  background:var(--surface-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.04em}

.pill{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);
  border:1px solid var(--border-2);padding:6px 12px;cursor:pointer}
.pill.on{color:#fff;background:var(--red);border-color:var(--red)}

@media(max-width:860px){
  .sidebar{display:none}
  .main{padding:20px}
  .grid.c4,.grid.c3,.grid.c2{grid-template-columns:1fr}
  .formgrid{grid-template-columns:1fr}
}
