/* /modules/social-bar.css  (novo layout: menor, sem menu, colado no mapa) */

:root{
  --radius:18px;

  /* altura mais “Google-like” (você pediu ícones menores) */
  --sb-h: 64px;
  --sb-h-desktop: 66px;

  /* cores reais */
  --bar-bg: #282d2b;
  --btn-bg: #2e3130;

  --txt: #ffffff;
  --muted: rgba(255,255,255,.92);

  /* padding simétrico nas laterais */
  --side-pad: 14px;

  /* tamanho dos ícones e números (menores) */
  --icon: 18px;
  --count: 14px;
}

/* Desktop */
@media (min-width: 821px){
  :root{ --sb-h: var(--sb-h-desktop); }
}

/* Root ocupa espaço normal no layout (não absoluto) */
#social-bar-root{
  width: 100%;
}






/* ===== Spinner pequeno ===== */
.sbSpinner{
  width:12px;
  height:12px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  border-radius:50%;

  /* ⭐ centralização perfeita */
  display:block;
  margin:0 auto;

  animation: sbSpin .8s linear infinite;
}

@keyframes sbSpin{
  to{ transform: rotate(360deg); }
}







/* animação quando o número aparece */
.sbCount{
  transition: transform .25s ease, opacity .25s ease;
}

.sbCount.loaded{
  animation: sbPop .25s ease;
}

@keyframes sbPop{
  0%{
    opacity:0;
    transform:scale(0.85);
  }
  100%{
    opacity:1;
    transform:scale(1);
  }
}




@keyframes sbSpin{
  to{ transform: rotate(360deg); }
}


/* Barra principal */
.socialbar{
  height: var(--sb-h);
  width: 100%;
  background: var(--bar-bg);

  /* topo arredondado como no frame */
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);

  /* base reta (pra “colar” com o mapa sem arredondar embaixo) */
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;

  display:flex;
  align-items:center;
  justify-content:center;

  padding: 0 var(--side-pad);

  /* sem sombra exagerada (pra parecer Google) */
  box-shadow: 0 10px 18px rgba(0,0,0,.18);
}

/* GRID: 4 colunas iguais (seguir, like, comentários, compartilhar)
   -> espaçamento uniforme e bordas simétricas
*/
.socialbar__grid{
  width:100%;
  height:100%;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  align-items:center;
  column-gap: 0;
}

/* Cada item centralizado */
.sbCol{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap: 6px;
  min-width:0;
}

/* Botão seguir/seguindo */
.followBtn{
  background: var(--btn-bg);
  color: var(--txt);
  border: 0;
  border-radius: 999px;
  padding: 6px 14px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .6px;
  text-transform: uppercase;
  cursor: pointer;
  line-height: 1;
  user-select:none;
}

.followBtn:active{ transform: scale(.98); }

/* Botões de ícone */
.sbIconBtn{
  width: 22px;
  height: 22px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  user-select:none;
}

.sbIconBtn img{
  width: var(--icon);
  height: var(--icon);
  object-fit: contain;
  display:block;
}

.sbIconBtn:active{ transform: scale(.98); }

/* Números */
.sbCount{
  font-family: Arial, system-ui, -apple-system, Segoe UI, Roboto;
  font-size: var(--count);
  font-weight: 800;
  color: var(--muted);
  line-height: 1;
  user-select:none;
}

/* Mobile muito pequeno: compacta um tiquinho */
@media (max-width: 360px){
  :root{
    --side-pad: 10px;
    --icon: 17px;
    --count: 13px;
  }
  .followBtn{ padding: 6px 12px; font-size: 11px; }
}

/* =========================
   MODAL: COMENTÁRIOS
========================= */
.comments-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.65);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding: 18px;
}

.comments-box{
  width:min(520px, 96vw);
  max-height: min(640px, 86vh);
  background:#111;
  border-radius:16px;
  padding:14px;
  display:flex;
  flex-direction:column;
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
}

.comments-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}

.comments-title{
  color:#fff;
  font-weight:900;
  font-family: Arial, system-ui;
  font-size:16px;
}

.comments-close{
  width:36px;
  height:36px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:20px;
  cursor:pointer;
}

.comments-list{
  flex:1;
  overflow:auto;
  padding-right: 6px;
}

.comment{
  background:#1b1b1b;
  padding:10px;
  border-radius:12px;
  margin-bottom:8px;
  color:#eee;
  font-size:14px;
  font-family: Arial, system-ui;
}

.comment strong{ color:#fff; }

.comment-input{
  display:grid;
  grid-template-columns: 1fr 1.2fr auto;
  gap: 8px;
  margin-top:10px;
}

.comment-input input{
  width:100%;
  padding:10px;
  border-radius:10px;
  border:none;
  outline:none;
  font-family: Arial, system-ui;
}

.comment-input button{
  background:#00e454;
  border:none;
  padding:10px 14px;
  border-radius:10px;
  font-weight:900;
  cursor:pointer;
  font-family: Arial, system-ui;
  white-space: nowrap;
}

@media (max-width: 520px){
  .comment-input{ grid-template-columns: 1fr; }
}
