body {
    margin: 0;
    font-family: sans-serif;
    background: #f8f9fa;
}

#layout {
    display: flex;
}

#sidebar {
    width: 220px;
    background: #eaecf0;
    padding: 15px;
    height: 100vh;
    box-sizing: border-box;
}

#sidebar h3 {
    font-size: 14px;
    margin-top: 20px;
}

#sidebar a {
    display: block;
    color: #0645ad;
    text-decoration: none;
    margin: 4px 0;
}

#content {
    flex: 1;
    background: white;
    padding: 20px;
}

h1 {
    border-bottom: 1px solid #a2a9b1;
    font-weight: normal;
}

.infobox {
    float: right;
    width: 300px;
    margin: 0 0 20px 20px;
    border: 1px solid #a2a9b1;
    background: #f8f9fa;
    font-size: 88%;
}

.infobox caption {
    border-top: 1px solid #a2a9b1;
    background: #eaecf0;
    font-weight: bold;
    padding: 5px;
}

.infobox td, .infobox th {
    border-top: 1px solid #a2a9b1;
    padding: 5px;
}

.infobox img {
    width: 100%;
}

a { color: #0645ad; }

.tree ul {
  list-style: none;
  padding-left: 15px;
  margin: 0;
  position: relative;
}

/* Linha vertical */
.tree ul::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 5px;
  border-left: 1px solid #aaa;
}

.tree li {
  position: relative;
  margin: 0;
  padding: 2px 15px;
}

/* Linha horizontal */
.tree li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 5px;
  width: 8px;
  border-top: 1px solid #aaa;
}

/* Esconde o excesso da linha vertical no último item */
.tree li:last-child::before {
  background: white; 
  height: auto;
  top: 12px;
  bottom: 0;
}

table {
    width: 100%;
    border-collapse: collapse;
    font-family: sans-serif;
}

/* Contentor principal da Infobox */
.infobox battle  {
    float: right;
    width: 300px;
    margin: 0 0 20px 20px;
    border: 1px solid #a2a9b1;
    background: #f8f9fa;
    font-size: 88%;
    font-family: sans-serif;
    border-collapse: collapse;
}

/* Título principal no topo */
.infobox caption {
    background: #d6e1f0;
    font-weight: bold;
    padding: 8px;
    font-size: 110%;
    border: 1px solid #a2a9b1;
    border-bottom: none;
}

/* Sub-cabeçalhos (ex: Parte da Guerra...) */
.infobox .header-sub {
    background: #eaecf0;
    text-align: center;
    padding: 5px;
    border-top: 1px solid #a2a9b1;
}

/* Títulos de secção (ex: Beligerantes) */
.infobox .header-section {
    background: #d6e1f0;
    text-align: center;
    font-weight: bold;
    padding: 3px;
    border-top: 1px solid #a2a9b1;
}

/* Células de dados e rótulos */
.infobox td, .infobox th {
    border-top: 1px solid #a2a9b1;
    padding: 6px;
    vertical-align: top;
}

.infobox th {
    text-align: left;
    width: 35%;
}

/* Imagem e legenda */
.infobox img {
    width: 100%;
    display: block;
}

.image-caption {
    font-size: 90%;
    padding: 5px;
    text-align: center;
    line-height: 1.4;
}

/* Tabela interna para colunas duplas (Beligerantes/Líderes) */
.belligerents-table {
    width: 100%;
    border-collapse: collapse;
}

.belligerents-table td {
    width: 50%;
    border-top: none;
    padding: 5px;
}

/* Links em azul estilo Wiki */
.blue-link {
    color: #0645ad;
    text-decoration: none;
}
