/* ===================================
   CONFIGURAÇÕES GERAIS E DESKTOP
   =================================== */

   :root{
    --bg-cor: #2c3e50;
    --caixa-cor: #34495e;
}

body {
    font-family: Arial, sans-serif;
    background-color: var(--bg-cor);
    color: white;
    padding: 150px 40px 40px 40px; /* topo grande, laterais menores */
    margin: 0;
}

.painel {
    max-width: 800px;
    margin: auto;
}

h1 {
    text-align: center;
    color: #3090cf;
}

.dados {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 20px;
}

.indicadores {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 20px;
}

.caixa,
.indicador {
    background-color: var(--caixa-cor);
    padding: 20px;
    border-radius: 10px;
    text-align: center;
}

.titulo {
    color: #fff;
    font-size: 14px;
    margin-bottom: 10px;
}

.valor {
    font-size: 40px;
    font-weight: bold;
    color: #3498db;
}

.unidade {
    color: #fff;
    font-size: 16px;
}

.icone {
    font-size: 40px;
    margin-bottom: 10px;
    transition: 0.3s;
}

/* ÍCONE DO CLIMA FIXO NO CANTO SUPERIOR DIREITO DA TELA */
.icone-clima{
    position: fixed;
    top: 15px;
    right: 15px;
    font-size: 55px;
    z-index: 999;
    transition: opacity 0.5s ease;
}

/* FAROL LIGADO */
.indicador.farol.ligado .icone {
    color: yellow;
    filter: drop-shadow(0 0 10px yellow) drop-shadow(0 0 20px yellow);
}

/* BUZINA LIGADA */
.indicador.buzina.ligado .icone {
    color: #ff4d4d;
    filter: drop-shadow(0 0 10px #ff4d4d) drop-shadow(0 0 25px #ff0000);
}

/* ALERTA */
.alerta {
    background-color: #e74c3c;
    padding: 20px;
    border-radius: 10px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    display: none;
}

.alerta.mostrar {
    display: block;
}

/* ===================================
   ADAPTAÇÕES PARA CELULAR E TABLET
   =================================== */

@media (max-width: 899px) {

    body {
        padding: 20px;
    }

    h1 {
        font-size: 26px;
        margin-bottom: 25px;
    }

    .dados,
    .indicadores {
        grid-template-columns: 1fr;
    }

    .valor {
        font-size: 42px;
    }

    .icone {
        font-size: 50px;
    }

    .icone-clima {
        font-size: 50px;
        top: 10px;
        right: 10px;
    }
}

@media (max-width: 599px) {

    body {
        padding: 15px;
    }

    h1 {
        font-size: 24px;
    }

    .caixa,
    .indicador {
        padding: 18px;
    }

    .valor {
        font-size: 38px;
    }

    .titulo {
        font-size: 13px;
    }
}

/* Tablets 600px–899px mantém 2 colunas */
@media (min-width: 600px) and (max-width: 899px) {
    .dados,
    .indicadores {
        grid-template-columns: 1fr 1fr;
    }
}
