/* ============================================================
   Davagib Brother — revista de análises de jogos
   Estética editorial: papel creme, tinta, acento coral, serif Fraunces
   Classes próprias com prefixo dg- (não colidem com o outro site)
   ============================================================ */
:root {
  --dg-papel:  #f6f1e7;
  --dg-papel2: #efe7d6;
  --dg-tinta:  #1a1410;
  --dg-tinta2: #5b5246;
  --dg-coral:  #ff5436;
  --dg-coral-d:#e23d20;
  --dg-amar:   #f2a01d;
  --dg-azul:   #213a8f;
  --dg-linha:  #2218; /* usado via rgba */
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--dg-papel);
  color: var(--dg-tinta);
  font-family: "DM Sans", system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.6;
}
h1,h2,h3,.dg-serif { font-family: "Fraunces", Georgia, serif; }
img { max-width: 100%; display: block; }
a { color: inherit; }

.dg-wrap { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.dg-kicker { text-transform: uppercase; letter-spacing: .22em; font-size: .72rem; font-weight: 700; color: var(--dg-coral-d); }
.dg-rule { height: 2px; background: var(--dg-tinta); opacity: .85; border: 0; margin: 0; }

/* ---- Top bar ---- */
.dg-top {
  position: sticky; top: 0; z-index: 50;
  background: var(--dg-papel);
  border-bottom: 2px solid var(--dg-tinta);
}
.dg-top-in { display: flex; align-items: center; justify-content: space-between; height: 66px; }
.dg-logo { font-family: "Fraunces", serif; font-weight: 900; font-size: 1.5rem; letter-spacing: -.02em; text-decoration: none; }
.dg-logo b { color: var(--dg-coral); }
.dg-menu { display: flex; gap: 30px; }
.dg-menu a { text-decoration: none; font-weight: 600; font-size: .95rem; position: relative; padding: 4px 0; }
.dg-menu a::after { content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background: var(--dg-coral); transition: width .25s; }
.dg-menu a:hover::after { width: 100%; }
.dg-burger { display: none; background: none; border: 2px solid var(--dg-tinta); border-radius: 8px; width: 44px; height: 40px; font-size: 1.2rem; cursor: pointer; }

/* ---- Hero ---- */
.dg-hero { padding: 70px 0 56px; border-bottom: 2px solid var(--dg-tinta); position: relative; overflow: hidden; }
.dg-hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.dg-hero h1 { font-size: clamp(2.6rem, 6vw, 4.4rem); line-height: .98; font-weight: 900; margin: 14px 0 18px; letter-spacing: -.02em; }
.dg-hero h1 em { font-style: italic; color: var(--dg-coral); }
.dg-hero p { font-size: 1.12rem; color: var(--dg-tinta2); max-width: 46ch; }
.dg-hero-actions { display: flex; gap: 14px; margin-top: 28px; flex-wrap: wrap; }

/* collage de ícones reais */
.dg-collage { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.dg-collage figure { margin: 0; position: relative; }
.dg-collage img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 20px; border: 2px solid var(--dg-tinta); box-shadow: 6px 6px 0 var(--dg-tinta); }
.dg-collage figure:nth-child(2){ transform: translateY(18px); }
.dg-collage figure:nth-child(4){ transform: translateY(-12px); }
.dg-collage figure:nth-child(6){ transform: translateY(14px); }

/* ---- Botões ---- */
.dg-btn { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: .98rem; padding: 13px 22px; border-radius: 999px; text-decoration: none; border: 2px solid var(--dg-tinta); cursor: pointer; transition: transform .15s, box-shadow .15s; }
.dg-btn:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--dg-tinta); }
.dg-btn--coral { background: var(--dg-coral); color: #fff; }
.dg-btn--ink   { background: var(--dg-tinta); color: var(--dg-papel); }
.dg-btn--ghost { background: transparent; color: var(--dg-tinta); }
.dg-btn--sm { padding: 9px 15px; font-size: .85rem; }

/* ---- Seção ---- */
.dg-sec { padding: 72px 0; border-bottom: 2px solid rgba(26,20,16,.12); }
.dg-sec--ink { background: var(--dg-tinta); color: var(--dg-papel); }
.dg-sec--ink .dg-kicker { color: var(--dg-amar); }
.dg-sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; margin-bottom: 38px; flex-wrap: wrap; }
.dg-sec-head h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); font-weight: 900; margin: 8px 0 0; letter-spacing: -.02em; }

/* ---- Destaque (review grande) ---- */
.dg-feat { display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center; }
.dg-feat-shot { border: 2px solid var(--dg-tinta); border-radius: 18px; overflow: hidden; box-shadow: 8px 8px 0 var(--dg-coral); }
.dg-feat-shot img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.dg-feat-meta { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.dg-feat-meta img { width: 58px; height: 58px; border-radius: 14px; border: 2px solid var(--dg-tinta); }
.dg-feat h3 { font-size: 2rem; margin: 0; line-height: 1.05; }
.dg-feat p { color: var(--dg-tinta2); }
.dg-feat--ink p { color: #c9c1b2; }

/* ---- Cartões de análise ---- */
.dg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.dg-card { background: #fff; border: 2px solid var(--dg-tinta); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; transition: transform .18s, box-shadow .18s; }
.dg-card:hover { transform: translateY(-6px); box-shadow: 8px 10px 0 var(--dg-tinta); }
.dg-card-head { display: flex; gap: 14px; padding: 18px 18px 0; align-items: center; }
.dg-card-head img { width: 62px; height: 62px; border-radius: 14px; border: 2px solid var(--dg-tinta); }
.dg-card-cat { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--dg-coral-d); }
.dg-card h3 { margin: 3px 0 0; font-size: 1.3rem; }
.dg-card-body { padding: 14px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.dg-card-body p { font-size: .92rem; color: var(--dg-tinta2); margin: 0 0 16px; }
.dg-card-foot { margin-top: auto; display: flex; gap: 8px; }
.dg-stars { color: var(--dg-amar); letter-spacing: 1px; font-size: .9rem; }
.dg-nota { font-weight: 800; }

/* ---- Ranking ---- */
.dg-board { border: 2px solid var(--dg-papel); border-radius: 14px; overflow: hidden; max-width: 760px; margin: 0 auto; }
.dg-board table { width: 100%; border-collapse: collapse; }
.dg-board th, .dg-board td { padding: 14px 18px; text-align: left; }
.dg-board thead th { background: rgba(255,255,255,.08); font-family: "DM Sans"; text-transform: uppercase; letter-spacing: .08em; font-size: .76rem; }
.dg-board tbody tr { border-top: 1px solid rgba(246,241,231,.16); }
.dg-board .num { font-weight: 800; }
.dg-board .pts { text-align: right; font-weight: 800; color: var(--dg-amar); }

/* ---- Opiniões ---- */
.dg-voices { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.dg-voice { background: #fff; border: 2px solid var(--dg-tinta); border-radius: 16px; padding: 24px; position: relative; }
.dg-voice::before { content: "\201C"; font-family: "Fraunces", serif; font-size: 4rem; line-height: .6; color: var(--dg-coral); position: absolute; top: 18px; right: 20px; opacity: .25; }
.dg-voice p { font-size: 1.02rem; }
.dg-voice-who { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.dg-av { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 800; }

/* ---- Contato (bloco, sem formulário) ---- */
.dg-contact { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: center; }
.dg-contact h2 { font-size: clamp(2rem,4vw,3rem); margin: 10px 0 14px; }
.dg-cards { display: grid; gap: 16px; }
.dg-cinfo { display: flex; gap: 16px; align-items: flex-start; background: #fff; border: 2px solid var(--dg-tinta); border-radius: 14px; padding: 18px 20px; }
.dg-cinfo .ico { font-size: 1.5rem; }
.dg-cinfo b { display: block; font-size: 1.05rem; }
.dg-cinfo span { color: var(--dg-tinta2); font-size: .92rem; }
.dg-cinfo a { color: var(--dg-coral-d); font-weight: 600; text-decoration: none; }

/* ---- Footer rico ---- */
.dg-foot { background: var(--dg-tinta); color: var(--dg-papel); padding: 56px 0 28px; }
.dg-foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 36px; }
.dg-foot h4 { font-family: "DM Sans"; text-transform: uppercase; letter-spacing: .12em; font-size: .76rem; color: var(--dg-amar); margin: 0 0 16px; }
.dg-foot a { color: #d8d0c2; text-decoration: none; display: block; padding: 5px 0; font-size: .95rem; }
.dg-foot a:hover { color: #fff; }
.dg-foot-logo { font-family: "Fraunces", serif; font-weight: 900; font-size: 1.6rem; }
.dg-foot-logo b { color: var(--dg-coral); }
.dg-foot-about { color: #c9c1b2; font-size: .95rem; margin: 14px 0 18px; max-width: 36ch; }
.dg-foot-soc { display: flex; gap: 10px; }
.dg-foot-soc a { width: 38px; height: 38px; border: 1px solid rgba(246,241,231,.3); border-radius: 10px; display: grid; place-items: center; padding: 0; }
.dg-foot-bottom { border-top: 1px solid rgba(246,241,231,.16); margin-top: 40px; padding-top: 22px; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: .85rem; color: #b7afa0; }
.dg-foot-bottom .legal { display: flex; gap: 18px; flex-wrap: wrap; }
.dg-foot-bottom a { color: #d8d0c2; display: inline; padding: 0; }

/* ---- Página de ficha ---- */
.ficha-hero { background: var(--dg-tinta); color: var(--dg-papel); padding: 56px 0; }
.ficha-hero-in { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.ficha-hero img.app { width: 120px; height: 120px; border-radius: 28px; border: 2px solid var(--dg-papel); box-shadow: 8px 8px 0 var(--dg-coral); }
.ficha-hero h1 { font-size: clamp(2.2rem,5vw,3.4rem); margin: 8px 0; }
.ficha-hero .sub { color: #c9c1b2; }
.shots { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 16px; }
.shots img { width: 100%; border-radius: 14px; border: 2px solid var(--dg-tinta); cursor: zoom-in; transition: transform .15s; }
.shots img:hover { transform: scale(1.02); }
.ficha-body { display: grid; grid-template-columns: 1.7fr 1fr; gap: 44px; }
.ficha-body h2 { font-size: 1.8rem; margin: 0 0 14px; }
.ficha-body p { color: #2a231b; }
.ficha-side { background: #fff; border: 2px solid var(--dg-tinta); border-radius: 16px; padding: 22px; align-self: start; position: sticky; top: 86px; }
.ficha-side table { width: 100%; border-collapse: collapse; }
.ficha-side th, .ficha-side td { padding: 9px 0; border-bottom: 1px solid rgba(26,20,16,.12); text-align: left; font-size: .92rem; }
.ficha-side th { color: var(--dg-tinta2); font-weight: 600; }
.pc { list-style: none; padding: 0; margin: 0; }
.pc li { padding: 6px 0; font-weight: 600; }
.pc .ok { color: #1c8a52; }
.pc .no { color: var(--dg-coral-d); }
.lb { position: fixed; inset: 0; background: rgba(20,16,12,.92); display: none; place-items: center; z-index: 99; padding: 30px; }
.lb.on { display: grid; }
.lb img { max-width: 90vw; max-height: 88vh; border-radius: 14px; border: 2px solid #fff; }

/* ---- Responsivo ---- */
@media (max-width: 900px) {
  .dg-hero-grid, .dg-feat, .dg-contact, .ficha-body { grid-template-columns: 1fr; }
  .dg-grid, .dg-voices { grid-template-columns: 1fr 1fr; }
  .dg-foot-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .ficha-side { position: static; }
}
@media (max-width: 620px) {
  .dg-menu { display: none; position: absolute; top: 66px; left: 0; right: 0; flex-direction: column; gap: 0; background: var(--dg-papel); border-bottom: 2px solid var(--dg-tinta); padding: 10px 24px 18px; }
  .dg-menu.on { display: flex; }
  .dg-menu a { padding: 12px 0; border-bottom: 1px solid rgba(26,20,16,.1); }
  .dg-burger { display: block; }
  .dg-grid, .dg-voices, .dg-foot-grid { grid-template-columns: 1fr; }
  body { font-size: 16px; }
}
