/* ============================================================
   República dos Malandros — CSS mobile-first
   Paleta oficial (doc 07):
   Verde Petróleo #0E3B36 | Verde Esmeralda #13815B | Ouro #F2B21A
   Creme #F5EBDD | Carvão #111316 | Vermelho de Alerta #C62828
   ============================================================ */

:root {
    --petroleo: #0E3B36;
    --esmeralda: #13815B;
    --ouro: #F2B21A;
    --creme: #F5EBDD;
    --carvao: #111316;
    --alerta: #C62828;
    --petroleo-claro: #14524A;
    --creme-escuro: #E8DCC8;
    --font-display: 'Barlow Condensed', 'Oswald', sans-serif;
    --font-body: 'Inter', 'Roboto', sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: var(--font-body);
    /* Backdrop com vinheta: no desktop as laterais escurecem em vez de
       ficar num verde chapado (corrige a sensação de "vazio"). */
    background:
        radial-gradient(120% 80% at 50% 0%, rgba(19, 129, 91, 0.28) 0%, transparent 60%),
        radial-gradient(140% 120% at 50% 100%, rgba(14, 59, 54, 0.5) 0%, transparent 70%),
        linear-gradient(180deg, var(--carvao) 0%, #0a2320 45%, #071a18 100%);
    background-attachment: fixed;
    color: var(--creme);
    min-height: 100vh;
    padding-bottom: 76px; /* espaço da bottomnav */
}

/* Faixa de conteúdo com moldura sutil no desktop, separando do backdrop. */
@media (min-width: 900px) {
    body { padding-bottom: 24px; }
    .app-shell {
        max-width: 1080px;
        margin: 0 auto;
        background: linear-gradient(180deg, rgba(17, 19, 22, 0.35), rgba(10, 35, 32, 0.15));
        border-left: 1px solid rgba(242, 178, 26, 0.15);
        border-right: 1px solid rgba(242, 178, 26, 0.15);
        min-height: 100vh;
    }
}

a { color: var(--ouro); }

/* ---------- Topbar ---------- */
.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: var(--carvao);
    border-bottom: 2px solid var(--ouro);
    position: sticky;
    top: 0;
    z-index: 20;
}
.brand {
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--creme);
    text-decoration: none;
    letter-spacing: 0.5px;
}
.brand-star { color: var(--ouro); }
.topbar-link { color: var(--ouro); text-decoration: none; font-weight: 600; font-size: 0.9rem; }

/* ---------- Statusbar do jogador ---------- */
.statusbar {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 8px 16px;
    background: var(--petroleo-claro);
    border-bottom: 1px solid rgba(242, 178, 26, 0.3);
    font-size: 0.82rem;
    white-space: nowrap;
    position: sticky;
    top: 50px;
    z-index: 19;
}
.stat { font-weight: 600; }

/* ---------- Container / seções ---------- */
.container { max-width: 640px; margin: 0 auto; padding: 16px; }
.section { margin-bottom: 24px; }
.section-title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    text-transform: uppercase;
    color: var(--ouro);
    margin-bottom: 10px;
    letter-spacing: 0.5px;
}
.center { text-align: center; }
.muted { color: rgba(245, 235, 221, 0.65); }
.small { font-size: 0.85rem; }
.quote { font-style: italic; color: var(--ouro); font-size: 0.9rem; margin: 8px 0; }
.gold { color: var(--ouro); }

/* ---------- Flash ---------- */
.flash {
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 14px;
    font-weight: 600;
    font-size: 0.92rem;
    border: 1px solid transparent;
}
.flash-success { background: rgba(19, 129, 91, 0.25); border-color: var(--esmeralda); color: #9fe8c9; }
.flash-error { background: rgba(198, 40, 40, 0.22); border-color: var(--alerta); color: #ffb3b3; }
.flash-info { background: rgba(242, 178, 26, 0.15); border-color: var(--ouro); color: var(--ouro); }

/* ---------- Cards ---------- */
.card {
    background: rgba(17, 19, 22, 0.55);
    border: 1px solid rgba(242, 178, 26, 0.25);
    border-radius: 14px;
    padding: 16px;
    margin-bottom: 14px;
}
.card h2, .card h3 { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.4px; }
.card-disabled { opacity: 0.55; }

/* ---------- Botões ---------- */
.btn {
    display: inline-block;
    padding: 12px 20px;
    border: none;
    border-radius: 10px;
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: transform 0.1s ease, filter 0.15s ease;
}
.btn:active { transform: scale(0.98); }
.btn-primary { background: var(--esmeralda); color: #fff; box-shadow: 0 3px 0 #0c5a40; }
.btn-primary:hover { filter: brightness(1.1); }
.btn-outline { background: transparent; color: var(--ouro); border: 2px solid var(--ouro); }
.btn-gold { background: var(--ouro); color: var(--carvao); box-shadow: 0 3px 0 #b8860b; }
.btn-danger { background: var(--alerta); color: #fff; }
.btn-block { display: block; width: 100%; }
.btn-lg { padding: 15px 26px; font-size: 1.2rem; }
.btn[disabled] { opacity: 0.5; cursor: not-allowed; }

/* ---------- Hero (home) ---------- */
.hero { text-align: center; padding: 40px 8px 24px; }
.hero-title {
    font-family: var(--font-display);
    font-size: 2.6rem;
    text-transform: uppercase;
    line-height: 1.05;
    text-shadow: 2px 2px 0 var(--carvao);
}
.hero-slogan { color: var(--ouro); font-weight: 700; margin: 10px 0 4px; }
.hero-sub { color: rgba(245, 235, 221, 0.8); margin-bottom: 20px; }
.hero-cta { display: flex; flex-direction: column; gap: 10px; max-width: 320px; margin: 0 auto 14px; }
.hero-season { font-size: 0.85rem; color: rgba(245, 235, 221, 0.6); }

/* ---------- Imagens ---------- */
.hero-bg {
    background-size: cover;
    background-position: center;
    border-radius: 0 0 22px 22px;
    margin: -16px -16px 16px;
    padding: 32px 16px 28px;
}
.hero-logo {
    width: min(320px, 76%);
    filter: drop-shadow(0 10px 26px rgba(0, 0, 0, 0.65));
}
.class-portrait {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid rgba(242, 178, 26, 0.35);
    margin-bottom: 8px;
    display: block;
}
.player-avatar {
    width: 84px;
    height: 84px;
    object-fit: cover;
    border-radius: 14px;
    border: 2px solid var(--ouro);
    flex-shrink: 0;
}
.player-info { flex: 1; }
.card-banner {
    background-size: cover;
    background-position: center;
    padding: 28px 18px;
    text-align: center;
    border-color: var(--ouro);
}
.region-map {
    width: 100%;
    border-radius: 14px;
    border: 1px solid rgba(242, 178, 26, 0.35);
    margin-bottom: 14px;
    display: block;
}

/* ---------- Grid de classes ---------- */
.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.card-class { margin: 0; }
.card-class h3 { color: var(--ouro); font-size: 1.05rem; }

/* ---------- Formulários ---------- */
.auth-box { max-width: 420px; margin: 24px auto; }
.auth-box-wide { max-width: 560px; }
.form { display: flex; flex-direction: column; gap: 14px; margin-top: 14px; }
.form label { display: flex; flex-direction: column; gap: 6px; font-weight: 600; font-size: 0.9rem; }
.form input, .form select, .form textarea {
    padding: 12px;
    border-radius: 10px;
    border: 1px solid rgba(242, 178, 26, 0.35);
    background: var(--carvao);
    color: var(--creme);
    font-family: var(--font-body);
    font-size: 1rem;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}
.form label { min-width: 0; }
.form input:focus, .form select:focus, .form textarea:focus {
    outline: 2px solid var(--esmeralda);
    border-color: var(--esmeralda);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 480px) {
    .form-row { grid-template-columns: 1fr; }
}
.form-section {
    font-family: var(--font-display);
    text-transform: uppercase;
    color: var(--ouro);
    font-size: 1.15rem;
    margin-top: 8px;
    border-top: 1px solid rgba(242, 178, 26, 0.2);
    padding-top: 14px;
}

/* ---------- Seletor de classe ---------- */
.class-picker { display: flex; flex-direction: column; gap: 10px; }
.class-option input { position: absolute; opacity: 0; }
.class-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 2px solid rgba(242, 178, 26, 0.25);
    background: rgba(17, 19, 22, 0.5);
    cursor: pointer;
    transition: border-color 0.15s ease;
}
.class-option input:checked + .class-card {
    border-color: var(--ouro);
    background: rgba(242, 178, 26, 0.12);
}
.class-card strong { font-family: var(--font-display); text-transform: uppercase; font-size: 1.05rem; color: var(--ouro); }
.class-card .weak { color: #e8a0a0; }
.class-card .ability { color: #9fe8c9; }

/* ---------- Barras de progresso ---------- */
.bar-group { margin: 12px 0; }
.bar-label { display: flex; justify-content: space-between; font-size: 0.85rem; font-weight: 600; margin-bottom: 4px; }
.bar { height: 12px; background: var(--carvao); border-radius: 8px; overflow: hidden; border: 1px solid rgba(242, 178, 26, 0.2); }
.bar-fill { height: 100%; border-radius: 8px; transition: width 0.4s ease; }
.bar-energy { background: linear-gradient(90deg, var(--ouro), #ffd45e); }
.bar-xp { background: linear-gradient(90deg, var(--esmeralda), #23c98a); }
.bar-heat { background: linear-gradient(90deg, #e07020, var(--alerta)); }

/* ---------- Dashboard ---------- */
.card-player { border-color: var(--ouro); }
.player-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.player-name { font-family: var(--font-display); font-size: 1.6rem; text-transform: uppercase; }
.rank-badge {
    background: var(--ouro);
    color: var(--carvao);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1.2rem;
    padding: 6px 12px;
    border-radius: 10px;
    text-align: center;
    line-height: 1;
}
.rank-badge span { display: block; font-size: 0.65rem; text-transform: uppercase; }
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 14px; }
.stat-box {
    background: rgba(17, 19, 22, 0.6);
    border-radius: 10px;
    padding: 10px 6px;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.stat-value { font-weight: 700; color: var(--ouro); font-size: 0.95rem; }
.stat-name { font-size: 0.7rem; text-transform: uppercase; color: rgba(245, 235, 221, 0.6); }

/* ---------- Ações ---------- */
.action-list { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.card-action { margin: 0; }
.action-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.action-head h3 { font-size: 1.05rem; color: var(--creme); }
.action-meta { color: rgba(245, 235, 221, 0.75); margin: 8px 0; }
.chance { font-weight: 800; font-family: var(--font-display); font-size: 1.15rem; white-space: nowrap; }
.chance-good { color: #23c98a; }
.chance-mid { color: var(--ouro); }
.chance-bad { color: #ff7b6b; }
.badge {
    font-size: 0.65rem;
    padding: 2px 8px;
    border-radius: 20px;
    text-transform: uppercase;
    font-weight: 700;
    vertical-align: middle;
    font-family: var(--font-body);
}
.badge-gold { background: var(--ouro); color: var(--carvao); }
.blocked-msg { color: #ffb3b3; font-style: italic; }
.result-card { border-width: 2px; }
.result-success { border-color: var(--esmeralda); }
.result-fail { border-color: var(--alerta); }

/* ---------- Logs ---------- */
.log-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.log-item { background: rgba(17, 19, 22, 0.5); border-radius: 10px; padding: 10px 12px; border-left: 4px solid var(--esmeralda); }
.log-fail { border-left-color: var(--alerta); }
.log-head { display: flex; justify-content: space-between; gap: 8px; }

/* ---------- Wizard de cadastro (V2) ---------- */
.wizard-steps {
    display: flex;
    justify-content: center;
    gap: 26px;
    margin: 14px 0 18px;
}
.wizard-step {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(17, 19, 22, 0.6);
    border: 2px solid rgba(242, 178, 26, 0.3);
    color: var(--creme);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1rem;
    line-height: 1;
    position: relative;
}
.wizard-step small {
    font-size: 0.5rem;
    text-transform: uppercase;
    font-family: var(--font-body);
    color: rgba(245, 235, 221, 0.6);
}
.wizard-step-active { border-color: var(--ouro); background: rgba(242, 178, 26, 0.15); color: var(--ouro); }
.wizard-step-done { border-color: var(--esmeralda); color: var(--esmeralda); }
.wizard-panel { border: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.wizard-panel[hidden] { display: none; } /* display:flex acima anularia o atributo hidden */
.wizard-nav { display: flex; gap: 10px; justify-content: space-between; }
.wizard-nav .btn { flex: 1; }

/* ---------- Carrossel (V2) ---------- */
.carousel-wrap { position: relative; }
.carousel {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding: 4px 2px 10px;
    -webkit-overflow-scrolling: touch;
}
.carousel-item {
    flex: 0 0 92%;
    scroll-snap-align: center;
}
.carousel .class-card { height: 100%; }
.carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 2px solid var(--ouro);
    background: rgba(17, 19, 22, 0.85);
    color: var(--ouro);
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.carousel-prev { left: -6px; }
.carousel-next { right: -6px; }
.class-selected-badge {
    display: none;
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--ouro);
    color: var(--carvao);
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 20px;
    z-index: 2;
}
.class-option { position: relative; }
.class-option input:checked + .class-card .class-selected-badge { display: inline-block; }
.class-option input:checked + .class-card {
    border-color: var(--ouro);
    background: rgba(242, 178, 26, 0.12);
    box-shadow: 0 0 18px rgba(242, 178, 26, 0.35);
}
.class-card .bonus { color: #9fe8c9; }
.class-card .choose-class { margin-top: 10px; cursor: pointer; }

/* ---------- Login / auth (V2) ---------- */
.auth-hero {
    background-size: cover;
    background-position: center;
    border-radius: 16px;
    padding: 22px 14px;
}
.card-auth { border-color: var(--ouro); max-width: 420px; margin: 0 auto; }
.auth-logo {
    display: block;
    width: 110px;
    height: auto;
    margin: 0 auto 10px;
    filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.5));
}

/* ---------- Calor: destaque só quando alto (V2) ---------- */
.stat-heat-high {
    background: var(--alerta);
    color: #fff;
    padding: 2px 8px;
    border-radius: 12px;
    animation: heat-pulse 1.6s ease-in-out infinite;
}
@keyframes heat-pulse {
    0%, 100% { box-shadow: 0 0 0 rgba(198, 40, 40, 0.6); }
    50% { box-shadow: 0 0 10px rgba(198, 40, 40, 0.9); }
}
.bar-group-quiet .bar-fill { opacity: 0.55; }

/* ---------- Resultado instantâneo de ação (animações) ---------- */
.result-animated { animation: result-pop 0.45s cubic-bezier(0.34, 1.56, 0.64, 1); }
@keyframes result-pop {
    0% { transform: scale(0.85); opacity: 0; }
    70% { transform: scale(1.03); }
    100% { transform: scale(1); opacity: 1; }
}
.result-title { font-family: var(--font-display); font-size: 1.25rem; text-transform: uppercase; }
.result-deltas .delta-pop {
    display: inline-block;
    animation: delta-rise 0.5s ease both;
    margin-right: 6px;
    font-weight: 700;
}
.result-deltas .delta-pop:nth-child(1) { animation-delay: 0.15s; }
.result-deltas .delta-pop:nth-child(2) { animation-delay: 0.3s; }
.result-deltas .delta-pop:nth-child(3) { animation-delay: 0.45s; }
.result-deltas .delta-pop:nth-child(4) { animation-delay: 0.6s; }
.result-deltas .delta-pop:nth-child(5) { animation-delay: 0.75s; }
@keyframes delta-rise {
    from { transform: translateY(10px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
.btn-rolling { animation: dice-shake 0.5s ease infinite; }
@keyframes dice-shake {
    0%, 100% { transform: rotate(0); }
    25% { transform: rotate(-3deg); }
    75% { transform: rotate(3deg); }
}
.card-event { border-color: var(--ouro); padding: 0; overflow: hidden; }
.event-banner {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    border-bottom: 2px solid var(--ouro);
}
.event-body { padding: 14px 16px; }
.mission-list { display: flex; flex-direction: column; gap: 10px; }
.card-mission { margin: 0; }
.card-mission .bar { margin: 8px 0; }
.card-checkin { border-color: var(--esmeralda); }

/* ---------- Bairros / zonas (V3.2) ---------- */
.zone-list { display: flex; flex-direction: column; gap: 14px; margin-top: 12px; }
/* Card com imagem full-bleed no topo (a arte já tem moldura pintada,
   então nada de borda/rounding extra brigando com ela). */
.card-zone { margin: 0; padding: 0; overflow: hidden; }
.card-zone-active { border-color: var(--ouro); box-shadow: 0 0 16px rgba(242, 178, 26, 0.3); }
.zone-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    border-bottom: 2px solid var(--ouro);
}
.zone-body { padding: 14px 16px; }
@media (min-width: 700px) {
    .zone-list { display: grid; grid-template-columns: 1fr 1fr; }
}

/* ---------- Ranking ---------- */
.tabs { display: flex; gap: 6px; overflow-x: auto; margin: 12px 0; padding-bottom: 4px; }
.tab {
    padding: 8px 14px;
    border-radius: 20px;
    background: rgba(17, 19, 22, 0.6);
    color: var(--creme);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    border: 1px solid rgba(242, 178, 26, 0.25);
}
.tab-active { background: var(--ouro); color: var(--carvao); border-color: var(--ouro); }
.ranking-list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.ranking-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(17, 19, 22, 0.5);
    border-radius: 10px;
    padding: 10px 12px;
}
.ranking-me { border: 1px solid var(--ouro); background: rgba(242, 178, 26, 0.1); }
.ranking-pos {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1.2rem;
    color: var(--ouro);
    min-width: 28px;
    text-align: center;
}
.ranking-name { flex: 1; display: flex; flex-direction: column; }
.ranking-score { font-weight: 700; font-size: 0.9rem; white-space: nowrap; }

/* ---------- Bottom nav ---------- */
.bottomnav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    background: var(--carvao);
    border-top: 2px solid var(--ouro);
    z-index: 30;
}
.bottomnav a {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 8px 4px 10px;
    color: var(--creme);
    text-decoration: none;
    font-size: 1.2rem;
}
.bottomnav a span { font-size: 0.65rem; text-transform: uppercase; font-weight: 600; }

/* ---------- Admin ---------- */
.admin-nav { display: flex; gap: 6px; overflow-x: auto; margin-bottom: 16px; padding-bottom: 4px; }
.table-wrap { overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.table th, .table td { padding: 8px 10px; text-align: left; border-bottom: 1px solid rgba(242, 178, 26, 0.15); }
.table th { color: var(--ouro); text-transform: uppercase; font-size: 0.72rem; }

/* ---------- Desktop ---------- */
@media (min-width: 700px) {
    .container { max-width: 860px; }
    .grid { grid-template-columns: repeat(4, 1fr); }
    .carousel-item { flex: 0 0 32%; }
    .hero-title { font-size: 3.4rem; }
    .hero-cta { flex-direction: row; justify-content: center; max-width: none; }
    .class-picker { display: grid; grid-template-columns: 1fr 1fr; }
    .action-list { display: grid; grid-template-columns: 1fr 1fr; }
    body { padding-bottom: 20px; }
    .bottomnav { position: sticky; max-width: 860px; margin: 0 auto; border-radius: 12px 12px 0 0; }
}

/* ---------- Desktop wide: usa a largura do app-shell ---------- */
@media (min-width: 900px) {
    .container { max-width: none; padding: 20px 28px; }
    .topbar { padding: 14px 28px; }
    .statusbar {
        justify-content: center;
        gap: 18px;
        overflow-x: visible;
        font-size: 0.95rem;
        padding: 10px 28px;
    }
    .bottomnav { max-width: 1080px; }
    /* Dashboard em 2 colunas: status à esquerda, o resto à direita. */
    .dash-grid { display: grid; grid-template-columns: 340px 1fr; gap: 20px; align-items: start; }
    .dash-side { position: sticky; top: 110px; }
    .action-list { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1100px) {
    .action-list { grid-template-columns: repeat(3, 1fr); }
    .zone-list { grid-template-columns: 1fr 1fr; }
    .mission-list { display: grid; grid-template-columns: repeat(3, 1fr); }
}
