:root{
  --brand:#280850;       /* roxo Legun (marca) */
  --paper:#160a2b;        /* fundo profundo, sóbrio */
  --panel:#1e1140;        /* cartões */
  --panel2:#241551;
  --line:#392459;         /* bordas */
  --blue:#6890c8;         /* acento — ações primárias */
  --green:#80b800;        /* acento — gerar/confirmar */
  --text:#ece9f2;
  --muted:#9b8fc0;
}
*{ box-sizing:border-box; }
html,body{ margin:0; height:100%; font-family:"Segoe UI",system-ui,Arial,sans-serif;
  background:var(--paper); color:var(--text); }
a{ color:var(--blue); }
.app{ display:grid; grid-template-columns:1.4fr 1fr; height:100vh; }
@media(max-width:900px){ .app{ grid-template-columns:1fr; height:auto; } }

header{ grid-column:1/-1; display:flex; align-items:center; gap:14px;
  padding:10px 18px; background:var(--brand); border-bottom:2px solid var(--green); }
header img.logo{ height:30px; display:block; }
header .tag{ font-size:10px; letter-spacing:3px; color:#b9a8e6;
  text-transform:uppercase; border-left:1px solid #4a2f7a; padding-left:14px; }
header .right{ margin-left:auto; font-size:12px; color:#b9a8e6; }

#map{ height:100%; min-height:420px; }
.side{ overflow-y:auto; padding:16px; background:var(--paper); border-left:1px solid var(--line); }

.card{ background:var(--panel); border:1px solid var(--line); border-radius:12px;
  padding:14px; margin-bottom:14px; }
.card h2{ margin:0 0 10px; font-size:14px; color:#fff; display:flex; align-items:center; gap:8px; }
.card h2 small{ color:var(--muted); font-weight:400; font-size:11px; }
.card h2 .dot{ width:8px; height:8px; border-radius:50%; background:var(--green); }

label{ display:block; font-size:11px; color:var(--muted); margin:8px 0 3px;
  text-transform:uppercase; letter-spacing:.5px; }
input,select,textarea{ width:100%; background:var(--paper); border:1px solid var(--line);
  color:var(--text); border-radius:8px; padding:8px 10px; font-size:13px; }
input:focus,select:focus,textarea:focus{ outline:none; border-color:var(--blue); }
.row{ display:flex; gap:8px; } .row>*{ flex:1; }

.types{ display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-top:4px; }
.type{ border:1px solid var(--line); border-radius:8px; padding:8px; cursor:pointer;
  font-size:12px; text-align:center; background:var(--paper); transition:.15s; }
.type:hover{ border-color:var(--blue); }
.type.sel{ border-color:var(--green); background:#1c2b0a; color:#d4ef9a; }
.type small{ display:block; color:var(--muted); font-size:10px; }
.type.sel small{ color:#a7cf6a; }

.btn{ border:0; border-radius:9px; padding:10px 14px; font-weight:700; cursor:pointer;
  font-size:13px; transition:.15s; }
.btn.primary{ background:var(--blue); color:#08152b; }
.btn.primary:hover{ filter:brightness(1.08); }
.btn.green{ background:var(--green); color:#16240a; }
.btn.green:hover{ filter:brightness(1.08); }
.btn.ghost{ background:transparent; border:1px solid var(--line); color:var(--text); }
.btn.ghost:hover{ border-color:var(--blue); }
.btn:disabled{ opacity:.45; cursor:not-allowed; filter:none; }
.toolbar{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }

.preflight{ font-size:12px; background:var(--paper); border:1px dashed var(--line);
  border-radius:8px; padding:10px; margin-top:8px; }
.preflight .big{ font-size:18px; font-weight:800; color:#fff; }
.warn{ color:#ffb454; }

.sections{ display:grid; grid-template-columns:1fr 1fr; gap:6px 12px; margin-top:6px; }
.chk{ display:flex; align-items:flex-start; gap:8px; font-size:12.5px;
  padding:5px 7px; border-radius:7px; cursor:pointer; user-select:none; }
.chk:hover{ background:var(--panel2); }
.chk input{ width:16px; height:16px; margin-top:1px; accent-color:var(--green); flex:0 0 auto; }
.chk .t{ line-height:1.25; } .chk .t small{ display:block; color:var(--muted); font-size:10.5px; }
.chk.locked{ opacity:.7; cursor:not-allowed; }
.presets{ display:flex; gap:6px; margin:2px 0 6px; }
.preset{ font-size:11px; padding:4px 10px; border-radius:14px; cursor:pointer;
  border:1px solid var(--line); background:var(--paper); color:var(--muted); }
.preset:hover{ border-color:var(--blue); color:var(--text); }
.proposed{ border-left:3px solid var(--blue); }

.list .item{ display:flex; align-items:center; gap:10px; padding:9px 0;
  border-bottom:1px solid var(--line); font-size:13px; }
.item .meta{ flex:1; } .item .meta small{ display:block; color:var(--muted); font-size:11px; }
.pill{ font-size:10px; padding:2px 8px; border-radius:10px; background:#1c2b0a;
  color:#d4ef9a; text-transform:uppercase; letter-spacing:.5px; }
.pill.mensal{ background:#142440; color:#9cc4ec; }
.pill.processando{ background:#3a2e10; color:#e9c46a; }
.pill.erro{ background:#3a1414; color:#f08a8a; }

.progress{ height:6px; background:var(--line); border-radius:4px; overflow:hidden; margin-top:6px; }
.progress > i{ display:block; height:100%; background:var(--green); width:0; transition:.3s; }
.muted{ color:var(--muted); font-size:12px; }
.hint{ font-size:11px; color:var(--muted); margin-top:6px; }
.toast{ position:fixed; bottom:18px; left:50%; transform:translateX(-50%);
  background:var(--brand); color:#fff; padding:10px 16px; border-radius:9px;
  border:1px solid var(--green); font-size:13px; opacity:0; transition:.3s; z-index:9999; }
.toast.show{ opacity:1; }
.preset.sel{ border-color:var(--green); background:#1c2b0a; color:#d4ef9a; }
