/* ============================================================
   ARKADICE RPG — Custom Theme
   MkDocs Material (Slate) — Dark Fantasy TTRPG Style
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Cinzel+Decorative:wght@400;700&family=Merriweather:ital,wght@0,300;0,400;0,700;1,300;1,400&display=swap');

/* ── Variáveis Globais ─────────────────────────────────────── */
:root {
    --md-text-font: "Merriweather", serif;
    --md-typeset-font: "Cinzel", serif;

    --gold: #c9a227;
    --gold-light: #dfcd8c;
    --gold-dim: rgba(201, 162, 39, 0.25);
    --gold-subtle: rgba(201, 162, 39, 0.08);

    --bg-base: #121212;
    --bg-raised: #1a1a1a;
    --bg-surface: #222222;
    --bg-elevated: #2a2a2a;
    --bg-header: #0c0c0c;

    --fg-primary: #e8e0d0;
    /* Warm off-white — less harsh than pure white */
    --fg-secondary: #a89f8c;
    /* Parchment-toned subtitle */
    --fg-muted: #6e6659;

    --border-dim: #2e2e2e;
    --border-gold: rgba(201, 162, 39, 0.35);

    --md-primary-fg-color: #1a1a1a !important;
    --md-accent-fg-color: var(--gold) !important;

    /* Expansão agressiva da largura do conteúdo */
    --md-grid-width: 80% !important;
}

/* Forçar largura máxima do grid e do conteúdo central */
.md-grid {
    max-width: 80% !important;
}

.md-main__inner {
    max-width: 80% !important;
}

/* ── Slate Scheme Overrides ────────────────────────────────── */
[data-md-color-scheme="slate"] {
    --md-default-bg-color: var(--bg-base);
    --md-default-fg-color: var(--fg-primary);
    --md-default-fg-color--light: var(--fg-secondary);
    --md-default-fg-color--lighter: var(--fg-muted);
    --md-code-bg-color: #0d0d0d;
    --md-code-fg-color: #c8bfa8;

    /* Links dentro do Material */
    --md-typeset-a-color: var(--gold-light);
}

/* ── Base ──────────────────────────────────────────────────── */
body {
    background-color: var(--bg-base);
}

/* Textura sutil de pergaminho escuro (opcional — remove se não quiser) */
.md-main__inner {
    background-image:
        radial-gradient(ellipse at top left, rgba(201, 162, 39, 0.03) 0%, transparent 60%),
        radial-gradient(ellipse at bottom right, rgba(80, 40, 10, 0.06) 0%, transparent 60%);
}

/* ── Header ────────────────────────────────────────────────── */
.md-header {
    background-color: var(--bg-header) !important;
    border-bottom: 1px solid var(--gold);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
}

.md-header__title {
    font-family: "Cinzel Decorative", "Cinzel", serif !important;
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--gold) !important;
    text-shadow: 0 0 18px rgba(201, 162, 39, 0.4);
}

/* Ícones do header */
.md-header__button {
    color: var(--fg-secondary) !important;
    transition: color 0.2s ease;
}

.md-header__button:hover {
    color: var(--gold) !important;
}

/* Search bar */
.md-search__input {
    background-color: var(--bg-surface) !important;
    color: var(--fg-primary) !important;
    border: 1px solid var(--border-dim);
    border-radius: 4px;
}

.md-search__input:focus {
    border-color: var(--gold) !important;
    box-shadow: 0 0 0 2px var(--gold-dim);
}

/* ── Sidebar / Nav ─────────────────────────────────────────── */
.md-sidebar {
    background-color: #0e0e0e;
    border-right: 1px solid var(--border-dim);
}

.md-nav {
    font-family: "Cinzel", serif;
    font-size: 0.78rem;
    letter-spacing: 0.3px;
}

.md-nav__title {
    color: var(--gold-light) !important;
    font-weight: 700;
    font-size: 0.72rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    border-bottom: 1px solid var(--border-gold);
    padding-bottom: 0.4em;
    margin-bottom: 0.3em;
}

.md-nav__link {
    color: var(--fg-secondary) !important;
    transition: color 0.15s ease, padding-left 0.15s ease;
}

.md-nav__link:hover {
    color: var(--gold-light) !important;
    padding-left: 4px;
}

.md-nav__link--active,
.md-nav__link--active:hover {
    color: var(--gold) !important;
    font-weight: 600;
    border-left: 2px solid var(--gold);
    padding-left: 6px;
}

/* ── Secções de Navegação (Categorias) ────────────────────── */
.md-nav__item--section>.md-nav__link {
    color: var(--gold) !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-size: 0.82rem;
    margin-top: 0.8em;
    padding-top: 0.5em;
    opacity: 1 !important;
}

.md-nav__item--section {
    margin-top: 0.5em;
}

/* ── Tipografia Principal ──────────────────────────────────── */

/* Decorador dourado antes de H1 */
.md-typeset h1::before {
    content: "⚔ ";
    font-size: 0.8em;
    opacity: 0.6;
}

.md-typeset h1 {
    font-family: "Cinzel", serif !important;
    font-weight: 700;
    font-size: 2.4em;
    color: var(--gold-light) !important;
    border-bottom: 1px solid var(--gold);
    padding-bottom: 0.3em;
    margin-top: 1.2em;
    letter-spacing: 1px;
    text-shadow: 0 1px 8px rgba(201, 162, 39, 0.2);
}

.md-typeset h2 {
    font-family: "Cinzel", serif !important;
    font-weight: 600;
    font-size: 1.55em;
    color: var(--gold) !important;
    border-bottom: 1px solid var(--gold-dim);
    padding-bottom: 0.2em;
    margin-top: 2em;
    letter-spacing: 0.5px;
}

.md-typeset h3 {
    font-family: "Cinzel", serif !important;
    font-weight: 400;
    font-size: 1.2em;
    color: #c4a96e !important;
    margin-top: 1.6em;
}

.md-typeset h4,
.md-typeset h5,
.md-typeset h6 {
    font-family: "Cinzel", serif !important;
    font-weight: 400;
    color: var(--fg-secondary) !important;
}

.md-typeset p,
.md-typeset li {
    font-family: "Merriweather", serif;
    font-size: 1.0rem;
    line-height: 1.85;
    color: var(--fg-primary);
    font-weight: 300;
}

.md-typeset strong {
    color: #ffffff;
    font-weight: 700;
}

.md-typeset em {
    color: var(--gold-light);
    font-style: italic;
}

/* ── Links ─────────────────────────────────────────────────── */
.md-typeset a {
    color: var(--gold-light);
    text-decoration: none;
    border-bottom: 1px dotted var(--gold-light);
    transition: color 0.2s ease, border-color 0.2s ease;
}

.md-typeset a:hover {
    color: #ffffff;
    border-bottom: 1px solid #ffffff;
}

/* ── Tabelas (Statblocks) ──────────────────────────────────── */
.md-typeset table {
    background-color: var(--bg-raised);
    border: 1px solid var(--border-gold);
    border-radius: 4px;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
}

.md-typeset table th {
    background-color: #1e1a10;
    color: var(--gold-light);
    font-family: "Cinzel", serif;
    font-weight: 600;
    font-size: 0.85em;
    letter-spacing: 0.8px;
    border-bottom: 1px solid var(--gold);
    padding: 0.8em 1.2em;
    vertical-align: middle !important;
    text-align: center;
    /* Cabeçalhos centralizados por padrão */
}

.md-typeset table tr:nth-child(even) {
    background-color: #161616;
}

.md-typeset table tr:hover {
    background-color: #1f1c12;
}

.md-typeset table td {
    border-bottom: 1px solid var(--border-dim);
    color: var(--fg-primary);
    padding: 0.8em 1.2em;
    font-size: 0.95rem;
    vertical-align: middle !important;
    /* Forçar alinhamento vertical central */
}

/* Centralizar colunas curtas (como valores, porcentagens, ícones simples) */
.md-typeset table td:first-child,
.md-typeset table td:nth-child(2),
.md-typeset table td:nth-child(4) {
    text-align: center;
}

/* ── Admonitions ───────────────────────────────────────────── */

/* Default (genérico) */
.md-typeset .admonition,
.md-typeset details {
    border-radius: 3px;
    border-left: 3px solid var(--gold);
    background: var(--bg-raised);
    color: var(--fg-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.md-typeset .admonition-title,
.md-typeset summary {
    font-family: "Cinzel", serif;
    font-weight: 600;
    font-size: 0.88em;
    letter-spacing: 0.5px;
    color: var(--gold) !important;
    background-color: #1e1a10 !important;
    border-bottom: 1px solid var(--border-gold);
}

/* Tipos específicos — sobreescrevem a cor da borda lateral */
.md-typeset .admonition.note {
    border-left-color: #6a9fcb;
}

.md-typeset .admonition.warning {
    border-left-color: #c97a27;
}

.md-typeset .admonition.danger {
    border-left-color: #b03030;
}

.md-typeset .admonition.tip {
    border-left-color: #4a9e6b;
}

/* ── Código ────────────────────────────────────────────────── */
.md-typeset code {
    background-color: #181818;
    color: #c8bfa8;
    border: 1px solid var(--border-dim);
    border-radius: 3px;
    font-size: 0.88em;
    padding: 0.1em 0.35em;
}

.md-typeset pre>code {
    background-color: #0d0d0d;
    border: 1px solid var(--border-dim);
    border-radius: 4px;
}

/* ── Botão "Back to top" ───────────────────────────────────── */
.md-top {
    background-color: var(--bg-elevated);
    color: var(--gold);
    border: 1px solid var(--border-gold);
}

.md-top:hover {
    background-color: #1e1a10;
    color: var(--gold-light);
}

/* ── Footer ────────────────────────────────────────────────── */
.md-footer {
    background-color: var(--bg-header);
    border-top: 1px solid var(--border-gold);
    color: var(--fg-muted);
}

.md-footer-meta {
    background-color: #090909;
}

/* ── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar {
    width: 7px;
    height: 7px;
}

::-webkit-scrollbar-track {
    background: #0a0a0a;
}

::-webkit-scrollbar-thumb {
    background: #2e2e2e;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--gold);
}

/* ── Tags / Badges (se usar o plugin tags) ─────────────────── */
.md-tag {
    background-color: #1e1a10;
    color: var(--gold);
    border: 1px solid var(--border-gold);
    font-family: "Cinzel", serif;
    font-size: 0.75em;
    border-radius: 3px;
    padding: 0.1em 0.5em;
}

/* ── Seleção de texto ──────────────────────────────────────── */
::selection {
    background-color: rgba(201, 162, 39, 0.3);
    color: #ffffff;
}

/* ── Element Icons Helper ── */
.element-icon {
    vertical-align: middle;
    display: inline-block;
    height: 1.15em !important;
    /* Proporcional à altura da linha do texto */
    width: auto !important;
    /* Mantém a proporção original do ícone */
    margin-top: -0.15em;
    /* Ajuste fino para alinhar ao centro da linha */
    margin-right: 0.1em;
}

/* Fix visibility for Perditio (Black icon) in Dark Mode */
[data-md-color-scheme="slate"] .element-icon-perditio {
    filter: invert(0.9) brightness(1.2);
}