/* Reset básico */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Tipografía y layout base */
html, body {
  height: 100%;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

body {
  background: var(--bg);
  color: var(--fg);
}

/* Estructura SPA */
#app {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

header, footer {
  padding: 1rem;
}

main {
  flex: 1;
  padding: 1rem;
}

/* Navegación */
nav a {
  margin-right: 1rem;
  text-decoration: none;
  color: var(--link);
}

nav a:hover {
  text-decoration: underline;
}

/* Tema claro por defecto */
:root {
  --bg: #f6f7f9;
  --fg: #1e1e1e;

  --header-bg: #ffffff;
  --footer-bg: #ffffff;

  --border: #dddddd;
  --link: #005bbb;
}

/* y lo aplicamos */
header {
  background: var(--header-bg);
  border-bottom: 1px solid var(--border);
}

footer {
  background: var(--footer-bg);
  border-top: 1px solid var(--border);
  font-size: 0.9rem;
}

/* Tema oscuro por defecto */
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #121212;
    --fg: #e0e0e0;

    --header-bg: #1a1a1a;
    --footer-bg: #1a1a1a;

    --border: #2a2a2a;
    --link: #6ca8ff;
  }
}
