/* =============================================
   SENTINELAS DO REINO — style.css v2.0
   ============================================= */

*{ margin:0; padding:0; box-sizing:border-box; font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif; }

:root{
  --bg1:#071120; --bg2:#10284a; --bg3:#0c1d35;
  --card:#10233f; --card2:#16345c; --card3:#1b3f6d;
  --gold:#f4c95d; --gold2:#ffdf8a; --gold-soft:rgba(244,201,93,.16);
  --text:#f5f7fb; --muted:#c8d2e3; --muted-2:#9fb1cb;
  --ok:#7ee081; --danger:#ff8f8f; --blue:#7cc7d4;
  --blue-soft:rgba(124,199,212,.14);
  --line:rgba(255,255,255,.08); --line-strong:rgba(255,255,255,.14);
  --shadow-lg:0 20px 45px rgba(0,0,0,.28); --shadow-md:0 14px 30px rgba(0,0,0,.22);
  --shadow-sm:0 10px 22px rgba(0,0,0,.16);
  --radius-xl:28px; --radius-lg:22px; --radius-md:18px; --radius-sm:14px;
  --transition:.22s ease;
}

html{ scroll-behavior:smooth; }

body{
  background:
    radial-gradient(circle at top, rgba(124,199,212,.10), transparent 22%),
    radial-gradient(circle at right top, rgba(244,201,93,.08), transparent 25%),
    linear-gradient(180deg, var(--bg2) 0%, var(--bg1) 60%, #050d18 100%);
  color:var(--text); min-height:100vh; line-height:1.5;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button,input,select,textarea{ font:inherit; }

.container{ width:min(1200px,94%); margin:auto; padding:24px 0 44px; }
.muted{ color:var(--muted); }
.fail{ color:var(--danger); }
.success{ color:var(--ok); }

/* ---- HEADER / BRAND ---- */
header, .mission-header{
  display:flex; justify-content:space-between; align-items:center;
  gap:16px; padding:18px 0 22px; flex-wrap:wrap;
  width:min(1200px,94%); margin:auto;
}

.brand{ display:flex; align-items:center; gap:14px; }
.brand-badge{
  width:50px; height:50px; border-radius:16px; display:flex; align-items:center;
  justify-content:center; background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#3b2a09; font-size:24px; font-weight:900; box-shadow:var(--shadow-sm); flex-shrink:0;
}
.brand strong{ display:block; font-size:1.5rem; letter-spacing:.2px; }
.brand small{ color:var(--muted); display:block; margin-top:3px; font-size:.9rem; }

.actions{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }

/* ---- BOTÕES ---- */
.btn{
  padding:10px 22px; border-radius:var(--radius-sm); border:none; cursor:pointer;
  font-weight:600; font-size:.92rem; transition:var(--transition); display:inline-flex;
  align-items:center; gap:6px;
}
.btn-primary{ background:linear-gradient(135deg,var(--gold),var(--gold2)); color:#1a1200; }
.btn-primary:hover{ filter:brightness(1.1); transform:translateY(-1px); }
.btn-secondary{ background:rgba(255,255,255,.08); color:var(--text); border:1px solid var(--line-strong); }
.btn-secondary:hover{ background:rgba(255,255,255,.14); }
.btn-dark{ background:rgba(0,0,0,.3); color:var(--muted); border:1px solid var(--line); }
.btn-dark:hover{ background:rgba(0,0,0,.5); color:var(--text); }
.btn:disabled{ opacity:.45; cursor:not-allowed; transform:none !important; }

/* ---- PANELS / CARDS ---- */
.panel{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:22px;
  box-shadow:var(--shadow-sm);
}
.card{
  background:var(--card2); border:1px solid var(--line); border-radius:var(--radius-md);
  padding:16px 18px;
}
.card h3{ font-size:1rem; margin-bottom:6px; }

/* ---- HERO ---- */
.hero{
  display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));
  border:1px solid var(--line); border-radius:var(--radius-xl); padding:32px;
  box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.hero::before{
  content:""; position:absolute; right:-80px; top:-80px; width:220px; height:220px;
  border-radius:50%; background:radial-gradient(circle,rgba(244,201,93,.18),transparent 70%);
  pointer-events:none;
}
.hero h1{ font-size:clamp(1.8rem,5vw,3.2rem); line-height:1.1; margin-bottom:14px; }
.hero p{ color:var(--muted); line-height:1.7; margin-bottom:18px; max-width:60ch; }
.hero img{ width:100%; border-radius:20px; object-fit:cover; box-shadow:var(--shadow-md); max-height:380px; }

/* ---- BADGES / PILLS ---- */
.badge{
  background:var(--gold-soft); color:var(--gold); border:1px solid rgba(244,201,93,.3);
  border-radius:8px; padding:4px 12px; font-size:.78rem; font-weight:600;
}
.badges{ display:flex; flex-wrap:wrap; gap:6px; margin:10px 0; }

.hud-pill{
  background:rgba(255,255,255,.07); border:1px solid var(--line); border-radius:8px;
  padding:4px 10px; font-size:.8rem; color:var(--muted); white-space:nowrap;
}

/* ---- GRIDS ---- */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:860px){ .grid-2,.grid-3{ grid-template-columns:1fr; } }

/* ---- JOURNEY CARDS (jornadas.php) ---- */
.journey-map{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; margin-top:20px; }

.journey-card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg);
  overflow:hidden; transition:var(--transition); position:relative;
}
.journey-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--line-strong); }
.journey-card.concluida{ border-color:rgba(126,224,129,.25); }
.journey-card.bloqueada{ opacity:.5; pointer-events:none; }

.journey-card-img{ width:100%; height:160px; object-fit:cover; }
.journey-card-body{ padding:16px; }
.journey-card-body h3{ font-size:1.05rem; margin-bottom:4px; }
.journey-card-body p{ font-size:.85rem; color:var(--muted); line-height:1.5; margin-bottom:12px; }

.pilar-tag{
  display:inline-block; border:1px solid; border-radius:6px; padding:2px 10px;
  font-size:.76rem; font-weight:700; letter-spacing:.5px; margin-bottom:8px;
}

.journey-card-status{
  display:flex; align-items:center; gap:8px; padding:10px 16px;
  border-top:1px solid var(--line); background:rgba(0,0,0,.15);
  font-size:.82rem; color:var(--muted);
}
.status-dot{
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
}
.status-dot.ok{ background:var(--ok); box-shadow:0 0 6px var(--ok); }
.status-dot.pending{ background:var(--gold); }
.status-dot.locked{ background:var(--muted-2); }

/* ---- MISSÃO LAYOUT ---- */
.journey-layout{
  display:grid; grid-template-columns:1fr 300px; gap:18px;
  width:min(1200px,94%); margin:auto; padding-bottom:40px;
}
@media(max-width:900px){ .journey-layout{ grid-template-columns:1fr; } }

.journey-main{ display:flex; flex-direction:column; gap:16px; }
.journey-side{ display:flex; flex-direction:column; gap:0; }

/* barra de progresso da jornada */
.journey-progress-bar{
  height:6px; background:rgba(255,255,255,.1); border-radius:3px; overflow:hidden;
}
.journey-progress-fill{
  height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2));
  border-radius:3px; transition:width .4s ease;
}

.journey-step-badge{ display:flex; gap:6px; align-items:center; margin-top:6px; }
.step-dot{
  width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.15);
  transition:var(--transition);
}
.step-dot.active{ background:var(--gold); box-shadow:0 0 8px var(--gold); }
.step-dot.done{ background:var(--ok); }

/* cena */
.scene-panel{ position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.scene-img{ width:100%; max-height:280px; object-fit:cover; display:block; }
.scene-overlay{
  position:absolute; bottom:0; left:0; right:0; padding:16px;
  background:linear-gradient(transparent, rgba(0,0,0,.7));
}

/* etapa */
.etapa-card{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px;
}
.etapa-titulo{ font-size:1.3rem; margin-bottom:12px; }
.etapa-cena{ color:var(--muted); line-height:1.8; font-size:1rem; }
.etapa-cena em{ color:var(--gold); font-style:italic; }

/* versículo */
.versiculo-box{
  display:flex; gap:10px; align-items:flex-start;
  background:var(--gold-soft); border:1px solid rgba(244,201,93,.2);
  border-radius:var(--radius-sm); padding:14px 16px;
}
.versiculo-box em{ color:var(--gold); font-size:.9rem; line-height:1.6; }
.versiculo-icone{ font-size:1.1rem; flex-shrink:0; margin-top:2px; }

/* char mini */
.char-card-mini{
  display:flex; gap:12px; align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  border:1px solid var(--line); border-radius:var(--radius-md); padding:12px;
}
.char-card-mini img{ width:48px; height:60px; border-radius:10px; object-fit:cover; object-position:top; flex-shrink:0; }
.char-info{ display:flex; flex-direction:column; }
.char-info strong{ font-size:.95rem; }
.char-info span{ font-size:.8rem; color:var(--muted); }

/* barras de atributo */
.attr-bar-wrap{ display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.attr-bar-label{ font-size:.78rem; color:var(--muted); min-width:110px; }
.attr-bar-track{
  flex:1; height:6px; background:rgba(255,255,255,.1); border-radius:3px; overflow:hidden;
}
.attr-bar-fill{ height:100%; border-radius:3px; transition:width .4s ease; }
.attr-bar-val{ font-size:.78rem; color:var(--muted); min-width:20px; text-align:right; }

/* ---- ESCOLHAS ---- */
.escolhas-grid{ display:flex; flex-direction:column; gap:10px; margin-top:16px; }

.escolhas-titulo{
  font-size:.82rem; color:var(--gold); font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; margin-bottom:8px; margin-top:4px;
  display:flex; align-items:center; gap:6px;
}
.escolhas-titulo::before{ content:""; display:block; width:3px; height:14px; background:var(--gold); border-radius:2px; }

.escolha-btn{
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.04); border:1.5px solid rgba(255,255,255,.12);
  border-radius:var(--radius-sm); padding:16px 18px;
  color:var(--text); text-align:left; cursor:pointer;
  transition:all .2s ease; font-size:.95rem; line-height:1.5;
  position:relative; overflow:hidden;
}
.escolha-btn::after{
  content:"Escolher →"; position:absolute; right:14px; top:50%; transform:translateY(-50%);
  font-size:.75rem; color:var(--muted-2); opacity:0; transition:opacity .2s;
}
.escolha-btn:hover:not(:disabled){
  background:rgba(244,201,93,.08); border-color:rgba(244,201,93,.5);
  transform:translateX(6px); box-shadow:0 4px 16px rgba(244,201,93,.1);
}
.escolha-btn:hover:not(:disabled)::after{ opacity:1; }
.escolha-btn:active:not(:disabled){ transform:translateX(3px) scale(.99); }
.escolha-btn:disabled{ cursor:not-allowed; opacity:.7; }

.escolha-letra{
  width:32px; height:32px; border-radius:10px;
  background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:.88rem; flex-shrink:0; color:var(--text);
}
.escolha-ok{ border-color:var(--ok)!important; background:rgba(126,224,129,.1)!important; }
.escolha-ok .escolha-letra{ background:var(--ok); color:#0a1a0a; }
.escolha-parcial{ border-color:var(--gold)!important; background:var(--gold-soft)!important; }
.escolha-parcial .escolha-letra{ background:var(--gold); color:#1a1200; }
.escolha-fail{ border-color:var(--danger)!important; background:rgba(255,143,143,.08)!important; }
.escolha-fail .escolha-letra{ background:var(--danger); color:#1a0000; }

/* ---- FEEDBACK ---- */
.feedback-box{
  display:flex; gap:14px; align-items:flex-start;
  border-radius:var(--radius-sm); padding:16px; margin-top:14px;
}
.feedback-sucesso{ background:rgba(126,224,129,.1); border:1px solid rgba(126,224,129,.3); }
.feedback-parcial{ background:rgba(244,201,93,.08); border:1px solid rgba(244,201,93,.25); }
.feedback-falha{ background:rgba(255,143,143,.08); border:1px solid rgba(255,143,143,.2); }
.feedback-icone{ font-size:1.5rem; flex-shrink:0; }
.feedback-box strong{ display:block; margin-bottom:4px; }
.feedback-box p{ color:var(--muted); font-size:.92rem; line-height:1.6; }

.reward-pill{
  display:inline-flex; align-items:center; gap:4px;
  background:var(--gold-soft); color:var(--gold);
  border:1px solid rgba(244,201,93,.3); border-radius:6px;
  padding:3px 10px; font-size:.8rem; font-weight:600; margin:2px;
}

/* ---- QUIZ ---- */
.quiz-box{ margin-top:8px; }
.quiz-pergunta{
  background:rgba(255,255,255,.05); border:1px solid var(--line);
  border-radius:var(--radius-sm); padding:14px 16px;
  font-size:1rem; line-height:1.6; margin-bottom:4px;
}

/* ---- TESTE / DADO ---- */
.teste-box{ margin-top:8px; }
.teste-info{
  display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px;
}
.teste-stat{
  flex:1; min-width:110px;
  background:rgba(255,255,255,.05); border:1px solid var(--line);
  border-radius:var(--radius-sm); padding:12px 14px; text-align:center;
}
.teste-stat span{ display:block; font-size:.78rem; color:var(--muted); margin-bottom:4px; }
.teste-stat strong{ font-size:1.4rem; }

.dice-area{ display:flex; align-items:center; gap:20px; margin:16px 0; }

.dice{
  width:80px; height:80px; border-radius:16px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#1a1200; font-size:2.2rem; font-weight:900;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(244,201,93,.3); flex-shrink:0;
  transition:transform .1s;
}
.dice-final{ transform:scale(1.12); box-shadow:0 6px 24px rgba(244,201,93,.5); }

.teste-resultado{ margin-top:14px; }
.teste-math{
  background:rgba(255,255,255,.05); border-radius:var(--radius-sm); padding:10px 14px;
  font-size:.92rem; color:var(--muted);
}
.teste-math strong{ color:var(--text); font-size:1.1rem; }

/* ---- LOG ---- */
.log{ background:rgba(0,0,0,.25); border:1px solid var(--line); border-radius:var(--radius-sm); padding:10px; }
.log-item{
  font-size:.8rem; color:var(--muted-2); padding:4px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.log-item:last-child{ border-bottom:none; }

/* ---- LOADING ---- */
.loading{
  text-align:center; padding:60px 20px; color:var(--muted);
  font-size:1.1rem; animation:pulse 1.5s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{opacity:.5} 50%{opacity:1} }

/* ---- NARRATIVA INICIAL ---- */
.narrativa-wrap{
  width:min(680px,94%); margin:0 auto 40px;
  display:flex; flex-direction:column; gap:0;
  border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.narrativa-scene{ position:relative; }
.narrativa-img{ width:100%; max-height:320px; object-fit:cover; display:block; }
.narrativa-overlay{
  position:absolute; inset:0;
  background:linear-gradient(transparent 40%, rgba(7,17,32,.95));
}
.narrativa-title-over{
  position:absolute; bottom:24px; left:24px; right:24px;
}
.narrativa-title-over h1{ font-size:clamp(1.4rem,4vw,2rem); text-shadow:0 2px 8px rgba(0,0,0,.5); }

.narrativa-content{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid var(--line); border-top:none; padding:28px;
}
.narrativa-texto{
  font-size:1.05rem; line-height:1.85; color:var(--muted);
  margin-bottom:20px;
}
.narrativa-texto em{ color:var(--gold); font-style:italic; }
.narrativa-versiculo{
  display:flex; gap:8px; padding:12px 14px;
  background:var(--gold-soft); border-radius:var(--radius-sm); margin-bottom:14px;
}
.narrativa-versiculo em{ color:var(--gold); font-size:.9rem; line-height:1.5; }
.narrativa-etapas-info{
  font-size:.85rem; color:var(--muted); margin-bottom:4px; text-align:center;
}

/* ---- TELA FINAL ---- */
.victory-full{
  width:min(640px,94%); margin:0 auto 60px;
  position:relative; border-radius:var(--radius-xl);
  overflow:hidden; text-align:center;
}
.victory-glow{
  position:absolute; inset:-2px;
  background:linear-gradient(135deg, var(--cor,#f4c95d), transparent 60%);
  z-index:0; opacity:.3; border-radius:var(--radius-xl);
}
.victory-content{
  position:relative; z-index:1;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12); border-radius:var(--radius-xl); padding:40px 32px;
}
.victory-emoji{ font-size:3.5rem; margin-bottom:12px; }
.victory-titulo{ font-size:1.8rem; margin-bottom:6px; }
.victory-jornada{ font-size:1.1rem; color:var(--gold); margin-bottom:8px; }
.victory-titulo-earned{
  display:inline-block; background:var(--gold-soft); color:var(--gold);
  border:1px solid rgba(244,201,93,.3); border-radius:8px;
  padding:4px 16px; font-size:.9rem; font-weight:700; margin-bottom:16px;
}
.victory-msg{ color:var(--muted); line-height:1.7; margin-bottom:18px; font-size:1rem; }
.victory-versiculo{
  display:flex; gap:8px; align-items:flex-start; justify-content:center;
  background:var(--gold-soft); border-radius:var(--radius-sm);
  padding:12px 16px; margin-bottom:20px;
}
.victory-versiculo em{ color:var(--gold); font-size:.9rem; line-height:1.5; text-align:left; }
.victory-rewards{ display:flex; justify-content:center; gap:16px; margin-bottom:16px; }
.reward-big{
  background:rgba(255,255,255,.06); border:1px solid var(--line-strong);
  border-radius:var(--radius-sm); padding:12px 20px;
  font-size:1.4rem; font-weight:700; color:var(--gold);
}
.reward-big span{ display:block; font-size:.72rem; color:var(--muted); font-weight:400; margin-top:2px; }
.victory-atributos{ display:flex; flex-wrap:wrap; justify-content:center; gap:6px; margin-bottom:16px; }
.victory-nivel{
  background:rgba(255,255,255,.05); border-radius:var(--radius-sm);
  padding:10px 16px; font-size:.9rem; color:var(--muted); margin-bottom:4px;
}
.victory-nivel strong{ color:var(--text); }

/* ---- JORNADAS PAGE ---- */
.jornadas-header{
  width:min(1200px,94%); margin:auto;
}

.personagem-hud{
  display:flex; gap:16px; align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.03));
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:18px 22px;
  margin-bottom:20px;
}
.personagem-hud img{ width:70px; height:70px; border-radius:14px; object-fit:cover; flex-shrink:0; }
.hud-dados{ flex:1; }
.hud-nome{ font-size:1.2rem; font-weight:700; }
.hud-classe{ font-size:.85rem; color:var(--muted); }
.hud-stats{ display:flex; gap:14px; margin-top:10px; flex-wrap:wrap; }
.hud-stat{ display:flex; flex-direction:column; align-items:center; }
.hud-stat span{ font-size:.72rem; color:var(--muted); }
.hud-stat strong{ font-size:1rem; }

.progresso-geral{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:var(--radius-md); padding:16px 20px;
  margin-bottom:24px;
}
.progresso-geral h3{ margin-bottom:10px; font-size:.95rem; }
.progress-track{ height:8px; background:rgba(255,255,255,.1); border-radius:4px; overflow:hidden; margin-bottom:8px; }
.progress-fill{ height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2)); border-radius:4px; transition:width .6s ease; }
.progress-txt{ font-size:.82rem; color:var(--muted); }

/* atributos espirituais no painel de jornadas */
.esp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.esp-item{
  background:rgba(255,255,255,.04); border:1px solid var(--line);
  border-radius:var(--radius-sm); padding:10px 12px;
}
.esp-label{ font-size:.78rem; color:var(--muted); margin-bottom:4px; }
.esp-nivel{ font-size:.7rem; color:var(--muted-2); }

/* skill box */
.skill-box{
  background:rgba(244,201,93,.06); border:1px solid rgba(244,201,93,.2);
  border-radius:var(--radius-sm); padding:14px 16px; margin-top:14px;
}
.skill-box strong{ font-size:.9rem; color:var(--gold); }
.skill-box p{ font-size:.82rem; color:var(--muted); margin-top:4px; }

/* ---- FORMULÁRIOS ---- */
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.field label{ font-size:.88rem; color:var(--muted); font-weight:600; }
.field input, .field select{
  background:rgba(255,255,255,.07); border:1px solid var(--line-strong);
  border-radius:var(--radius-sm); padding:12px 14px; color:var(--text);
  font-size:.95rem; transition:var(--transition); outline:none;
}
.field input:focus, .field select:focus{ border-color:var(--gold); background:rgba(255,255,255,.1); }

/* ---- CRIAÇÃO DE PERSONAGEM ---- */
.class-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:10px; }
@media(max-width:600px){ .class-grid{ grid-template-columns:1fr; } }

.class-card{
  background:var(--card); border:2px solid var(--line); border-radius:var(--radius-md);
  padding:14px; text-align:center; cursor:pointer; transition:var(--transition);
}
.class-card:hover{ border-color:var(--line-strong); transform:translateY(-2px); }
.class-card.selected{ border-color:var(--gold); background:var(--gold-soft); }
.class-card img{ width:70px; height:90px; object-fit:cover; border-radius:10px; margin:0 auto 10px; }
.class-card h3{ font-size:.85rem; margin-bottom:4px; }
.class-card p{ font-size:.75rem; color:var(--muted); line-height:1.4; }

.attr-card{
  display:flex; justify-content:space-between; align-items:center;
  background:var(--card2); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:12px 14px; margin-bottom:8px;
}
.attr-info strong{ font-size:.9rem; }
.attr-info div{ font-size:.78rem; color:var(--muted); margin-top:2px; }
.attr-controls{ display:flex; align-items:center; gap:10px; }
.attr-btn{
  width:30px; height:30px; border-radius:8px; border:1px solid var(--line-strong);
  background:rgba(255,255,255,.08); color:var(--text); cursor:pointer; font-size:1.1rem;
  display:flex; align-items:center; justify-content:center; transition:var(--transition);
}
.attr-btn:hover{ background:rgba(255,255,255,.15); }
.attr-value{ width:28px; text-align:center; font-weight:700; font-size:1rem; }

.preview-box{
  background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
}
.preview-avatar img{
  width:120px; height:160px; object-fit:cover; border-radius:16px;
  margin:0 auto 16px; box-shadow:var(--shadow-md);
}

.stats{ display:flex; gap:14px; flex-wrap:wrap; margin-top:12px; }
.stat{ display:flex; flex-direction:column; align-items:center; }
.stat span{ font-size:.75rem; color:var(--muted); }
.stat strong{ font-size:1.1rem; }

.points-box{
  background:var(--gold-soft); border:1px solid rgba(244,201,93,.3);
  border-radius:var(--radius-sm); padding:8px 14px;
  font-size:.88rem; color:var(--gold); margin-bottom:12px;
}

/* ---- STATS DO PERSONAGEM ---- */
.hero-mini{
  display:flex; gap:20px; align-items:center;
}
.avatar img{
  width:90px; height:110px; object-fit:cover;
  border-radius:16px; box-shadow:var(--shadow-md);
}

/* ---- RESPONSIVO ---- */
@media(max-width:640px){
  .hero{ grid-template-columns:1fr; }
  .hero img{ max-height:220px; }
  .journey-layout{ padding:0 16px 40px; }
  .victory-content{ padding:28px 20px; }
  .victory-rewards{ gap:10px; }
}
