:root {
    --azul: #0b5fa5;
    --azul-escuro: #084277;
    --verde: #1f9d55;
    --vermelho: #c5341d;
    --cinza: #f4f6f8;
    --borda: #d9dee3;
    --texto: #243240;
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background: var(--cinza);
    color: var(--texto);
    line-height: 1.45;
}

/* Topbar */
.topbar {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    background: var(--azul);
    color: #fff;
    padding: 0 1.25rem;
    height: 56px;
    flex-wrap: wrap;
}
.brand { font-weight: 700; color: #fff; text-decoration: none; font-size: 1.05rem; }
.brand span { font-weight: 300; opacity: .85; }
.topbar nav { display: flex; gap: .25rem; flex: 1; }
.topbar nav a {
    color: #eaf2fb; text-decoration: none; padding: .4rem .7rem;
    border-radius: 6px; font-size: .92rem;
}
.topbar nav a:hover { background: rgba(255,255,255,.15); }
.topbar .user { display: flex; align-items: center; gap: .75rem; font-size: .88rem; }
.topbar .user small { opacity: .75; }
.btn-logout {
    background: rgba(0,0,0,.18); color: #fff; text-decoration: none;
    padding: .35rem .7rem; border-radius: 6px;
}
.btn-logout:hover { background: rgba(0,0,0,.3); }

/* Layout */
.container { max-width: 1000px; margin: 1.5rem auto; padding: 0 1rem; }
.page-title { font-size: 1.4rem; margin: 0 0 1rem; }
.foot { text-align: center; color: #8a97a3; font-size: .8rem; padding: 2rem 0; }

/* Cards / panels */
.card {
    background: #fff; border: 1px solid var(--borda); border-radius: 10px;
    padding: 1.25rem; margin-bottom: 1.25rem;
}
.cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.stat { background:#fff; border:1px solid var(--borda); border-radius:10px; padding:1rem 1.25rem; }
.stat .n { font-size: 2rem; font-weight: 700; color: var(--azul); }
.stat .l { color:#6b7884; font-size:.85rem; }

/* Tables */
table { width: 100%; border-collapse: collapse; background:#fff; }
.card table { background: transparent; }
th, td { text-align: left; padding: .6rem .7rem; border-bottom: 1px solid var(--borda); }
th { font-size: .8rem; text-transform: uppercase; letter-spacing: .03em; color:#6b7884; }
tbody tr:hover { background: #f8fafc; }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
.rank-pos { font-weight: 700; color: var(--azul); width: 2.5rem; }
tr.top1 td { background: #fff8e1; }
tr.top1 .rank-pos::before { content: "🥇 "; }
tr.top2 .rank-pos::before { content: "🥈 "; }
tr.top3 .rank-pos::before { content: "🥉 "; }

/* Forms */
.form-row { margin-bottom: 1rem; }
label { display:block; font-weight: 600; font-size: .9rem; margin-bottom: .3rem; }
input[type=text], input[type=password], input[type=number], input[type=date], select {
    width: 100%; padding: .55rem .65rem; border: 1px solid var(--borda);
    border-radius: 7px; font-size: .95rem; background:#fff;
}
input:focus, select:focus { outline: 2px solid #bcd6f0; border-color: var(--azul); }
.check { display: flex; align-items: center; gap: .5rem; }
.check input { width: auto; }
.check label { margin: 0; font-weight: 500; }

/* Buttons */
.btn {
    display: inline-block; border: 0; cursor: pointer; text-decoration: none;
    background: var(--azul); color: #fff; padding: .55rem 1rem; border-radius: 7px;
    font-size: .92rem; font-weight: 600;
}
.btn:hover { background: var(--azul-escuro); }
.btn-sec { background: #e4e9ee; color: var(--texto); }
.btn-sec:hover { background: #d4dbe2; }
.btn-danger { background: var(--vermelho); }
.btn-danger:hover { background: #a32a16; }
.btn-sm { padding: .3rem .6rem; font-size: .82rem; }
.actions { display:flex; gap:.5rem; align-items:center; }
.toolbar { display:flex; justify-content: space-between; align-items:center; gap:1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.toolbar form { display:flex; gap:.5rem; align-items:flex-end; flex-wrap: wrap; }
.toolbar .form-row { margin: 0; }

/* Badges */
.badge { font-size:.75rem; padding:.15rem .5rem; border-radius: 20px; font-weight:600; }
.badge-on { background:#e3f5ea; color: var(--verde); }
.badge-off { background:#f2e3e0; color: var(--vermelho); }
.badge-admin { background:#e7eefb; color: var(--azul); }
.badge-oper { background:#eef1f4; color:#566069; }
.badge-bonus { background:#fff3d6; color:#9a6700; margin-left:.4rem; }

/* Flash */
.flash { padding:.7rem 1rem; border-radius:8px; margin-bottom:1rem; font-size:.92rem; }
.flash-ok { background:#e3f5ea; color:#15693a; border:1px solid #b7e3c7; }
.flash-erro { background:#fdeae6; color:#992414; border:1px solid #f3c0b5; }

/* Login */
.login-wrap { max-width: 360px; margin: 8vh auto; }
.login-wrap .card { padding: 1.75rem; }
.login-wrap h1 { text-align:center; color: var(--azul); margin-top:0; }
.muted { color:#8a97a3; font-size:.82rem; }

/* Card de clima */
.clima-card { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.clima-info { display:flex; align-items:center; gap:.9rem; }
.clima-emoji { font-size:2.2rem; line-height:1; }
.clima-temp { background:#eef1f4; border-radius:20px; padding:.1rem .55rem; font-size:.82rem; font-weight:600; margin-left:.4rem; }

/* Lançamento dinâmico */
.lanc-row { display:grid; grid-template-columns: 1fr 1fr 90px 36px; gap:.5rem; margin-bottom:.5rem; align-items:center; }
.lanc-row .rm { background:#f2e3e0; color:var(--vermelho); border:0; border-radius:6px; cursor:pointer; height:38px; font-size:1.1rem; }
.lanc-head { display:grid; grid-template-columns: 1fr 1fr 90px 36px; gap:.5rem; font-size:.78rem; text-transform:uppercase; color:#6b7884; margin-bottom:.3rem; }
@media (max-width: 640px) {
    .lanc-row, .lanc-head { grid-template-columns: 1fr 1fr 70px 32px; }
}

/* Bloco por técnico: linha = tipo + qtd + remover (3 colunas) */
.tecnico-bloco { border-left: 3px solid var(--azul); }
.tecnico-bloco > summary {
    cursor: pointer; display: flex; justify-content: space-between; align-items: center;
    gap: 1rem; font-size: 1.05rem; font-weight: 600;
}
.tecnico-bloco > summary::-webkit-details-marker { color: var(--azul); }
.tecnico-bloco[open] > summary {
    margin-bottom: .75rem; padding-bottom: .6rem; border-bottom: 1px solid var(--borda);
}
.tecnico-bloco .lanc-head,
.tecnico-bloco .lanc-row { grid-template-columns: minmax(120px,1.2fr) 60px 90px minmax(110px,1.3fr) 32px; }
@media (max-width: 640px) {
    .tecnico-bloco .lanc-head, .tecnico-bloco .lanc-row { grid-template-columns: 1fr 50px 70px 1fr 28px; }
}
.mod-geral {
    display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
    margin-top: .9rem; padding: .7rem .85rem; background: #f4f6f8;
    border: 1px dashed var(--borda); border-radius: 8px;
}
.mod-geral strong { font-size: .9rem; }
.mod-geral input[type=number] { max-width: 130px; }
.mod-geral input[type=text] { flex: 1; min-width: 160px; }
tr.linha-ajuste td { background: #fbf7ec; }
