/* ============================================================
   ClubBrain Sport — Showcase da plataforma + Time executivo
   ============================================================ */

/* ---------- Showcase ---------- */
.showcase-stage {
  position: relative;
  margin-top: 36px;
  display: flex;
  justify-content: center;
}
.browser {
  width: 100%;
  max-width: 920px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  box-shadow: var(--shadow);
  overflow: hidden;
}
.browser-bar {
  display: flex; align-items: center; gap: 14px;
  padding: 13px 18px; border-bottom: 1px solid var(--line-soft);
  background: rgba(255,255,255,0.02);
}
.browser-bar .dots { display: flex; gap: 7px; }
.browser-bar .dots i { width: 11px; height: 11px; border-radius: 50%; background: rgba(255,255,255,0.16); }
.browser-bar .addr {
  flex: 1; max-width: 360px; margin: 0 auto;
  font-size: 0.78rem; color: var(--text-3);
  background: rgba(0,0,0,0.3); border: 1px solid var(--line-soft);
  padding: 6px 16px; border-radius: 999px; text-align: center;
}
.browser-body { padding: 26px; }

/* ---------- Screenshot gallery ---------- */
.shot-frame { padding: 0; line-height: 0; background: #eaf0fb; }
.shot-frame img { width: 100%; height: auto; display: block; }
#mainShot { transition: opacity .3s ease; }
.gallery-tabs {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
  margin-top: 26px;
}
.gallery-tab {
  font-family: var(--font-body); font-weight: 600; font-size: 0.9rem;
  color: var(--text-2); background: rgba(255,255,255,0.03);
  border: 1px solid var(--line); border-radius: 999px; padding: 10px 18px;
  cursor: pointer; transition: all .18s ease;
}
.gallery-tab:hover { border-color: rgba(95,224,107,0.4); color: var(--text); }
.gallery-tab.active { background: var(--grad); color: var(--accent-ink); border-color: transparent; }


.report-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.report-head .t { font-family: var(--font-display); font-weight: 600; font-size: 1.35rem; }
.report-head .s { color: var(--text-3); font-size: 0.85rem; margin-top: 4px; }
.report-tabs { display: flex; gap: 8px; }
.report-tabs span {
  font-size: 0.78rem; font-weight: 600; padding: 7px 14px; border-radius: 999px;
  color: var(--text-3); border: 1px solid var(--line-soft);
}
.report-tabs span.on { color: var(--accent-ink); background: var(--grad); border-color: transparent; }

.report-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 20px; }
.report-kpis .mk .v { font-size: 1.5rem; }

.report-chart {
  border: 1px solid var(--line-soft); border-radius: 16px;
  padding: 22px; background: rgba(255,255,255,0.02);
}
.report-chart .ct { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.report-chart .ct b { font-size: 0.95rem; }
.report-chart .ct .legend { font-size: 0.76rem; color: var(--text-3); display: flex; gap: 16px; }
.report-chart .ct .legend i { width: 9px; height: 9px; border-radius: 3px; display: inline-block; margin-right: 6px; vertical-align: middle; }
.bigchart { width: 100%; height: 180px; display: block; }

/* Phone */
.phone {
  position: absolute;
  right: -8px; bottom: -42px;
  width: 232px;
  border-radius: 36px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #0c1614, #060b0a);
  padding: 9px;
  box-shadow: 0 40px 90px -30px rgba(0,0,0,0.8);
}
.phone::before {
  content: ""; position: absolute; top: 17px; left: 50%; transform: translateX(-50%);
  width: 78px; height: 6px; border-radius: 99px; background: rgba(255,255,255,0.18); z-index: 3;
}
.phone-screen {
  border-radius: 28px; overflow: hidden; background: #04100c;
  border: 1px solid var(--line-soft);
}
.ps-top {
  background: var(--grad); color: var(--accent-ink);
  padding: 30px 16px 18px;
}
.ps-top .club { display: flex; align-items: center; gap: 9px; font-family: var(--font-display); font-weight: 700; font-size: 0.92rem; }
.ps-top .club img { width: 24px; height: 24px; }
.ps-top .hi { font-weight: 600; font-size: 1.05rem; margin-top: 14px; }
.ps-top .hi span { opacity: .7; font-weight: 500; }
.ps-body { padding: 14px; display: flex; flex-direction: column; gap: 11px; }
.ps-card {
  border: 1px solid var(--line-soft); border-radius: 13px; padding: 13px;
  background: rgba(255,255,255,0.025);
}
.ps-card .lbl { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-3); }
.ps-card .big { font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; margin-top: 5px; display: flex; align-items: center; justify-content: space-between; }
.ps-pill { font-size: 0.62rem; font-weight: 700; text-transform: uppercase; padding: 3px 8px; border-radius: 6px; color: var(--accent); background: rgba(95,224,107,0.14); }
.ps-card .sub { color: var(--text-3); font-size: 0.74rem; margin-top: 4px; }
.ps-btn {
  background: var(--grad); color: var(--accent-ink); text-align: center;
  font-weight: 700; font-size: 0.82rem; padding: 11px; border-radius: 11px; margin-top: 2px;
}

/* ---------- Vídeo ---------- */
.video-wrap {
  max-width: 980px; margin: 52px auto 0;
  border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--shadow);
  background: #000; line-height: 0;
}
.video-wrap video { width: 100%; height: auto; display: block; }

/* ---------- Sobre / Missão ---------- */
.about-lead {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.3rem, 2.6vw, 2rem); line-height: 1.35; letter-spacing: -0.01em;
  max-width: 30ch;
}
.about-body { color: var(--text-2); font-size: 1.08rem; line-height: 1.7; max-width: 60ch; }
.about-body strong { color: var(--text); font-weight: 600; }
.about-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(34px, 6vw, 80px);
  align-items: start; margin-top: 18px;
}
.areas {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
  margin-top: 32px;
}
.area {
  display: flex; align-items: center; gap: 14px;
  border: 1px solid var(--line); border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), transparent);
  padding: 16px 18px;
  transition: transform .2s ease, border-color .2s ease;
}
.area:hover { transform: translateY(-3px); border-color: rgba(95,224,107,0.35); }
.area .emoji {
  font-size: 1.5rem; line-height: 1; width: 44px; height: 44px; flex: none;
  display: grid; place-items: center; border-radius: 11px;
  background: var(--grad-soft); border: 1px solid var(--line-soft);
}
.area .at { font-weight: 600; font-size: 1rem; }
.mission-band {
  margin-top: 36px; border: 1px solid rgba(95,224,107,0.28);
  background: var(--grad-soft); border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 44px); text-align: center;
}
.mission-band p {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.15rem, 2.4vw, 1.7rem); line-height: 1.4; letter-spacing: -0.01em;
  max-width: 46ch; margin-inline: auto;
}
.mission-band .grad-text { font-weight: 700; }
@media (max-width: 860px) {
  .about-grid { grid-template-columns: 1fr; gap: 32px; }
  .areas { grid-template-columns: 1fr; margin-top: 8px; }
}
.team-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
  margin-top: 36px;
}
.team-grid.team-exec {
  grid-template-columns: repeat(2, 1fr);
  max-width: 680px; margin-left: auto; margin-right: auto;
}
.team-grid.team-council {
  grid-template-columns: repeat(2, 1fr);
  max-width: 680px; margin-left: auto; margin-right: auto;
}
.member {
  border: 1px solid var(--line); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.025), transparent);
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease;
  display: flex; flex-direction: column;
}
.member:hover { transform: translateY(-4px); border-color: rgba(95,224,107,0.3); }
.member-photo {
  aspect-ratio: 1 / 1; width: 100%;
  position: relative;
  background: linear-gradient(150deg, var(--surface-2), var(--bg-2));
}
.member-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.avatar-fallback {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(2.6rem, 6vw, 3.4rem);
  letter-spacing: 0.02em;
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.member-photo::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 50% 0%, rgba(95,224,107,0.10), transparent 60%);
  pointer-events: none;
}
.member-body { padding: 20px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.member-body .name { font-family: var(--font-display); font-weight: 600; font-size: 1.18rem; }
.member-body .role {
  font-size: 0.8rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.member-body .bio { color: var(--text-2); font-size: 0.92rem; line-height: 1.5; margin-top: 4px; flex: 1; }
.member-linkedin {
  display: inline-flex; align-items: center; gap: 9px;
  margin-top: 12px; align-self: flex-start;
  font-size: 0.86rem; font-weight: 600; color: var(--text);
  border: 1px solid var(--line); border-radius: 999px; padding: 8px 15px;
  transition: all .18s ease;
}
.member-linkedin:hover { border-color: rgba(95,224,107,0.4); color: var(--accent); }
.member-linkedin svg { flex: none; }

@media (max-width: 980px) {
  .team-grid { grid-template-columns: 1fr 1fr; }
  .team-grid.team-council { grid-template-columns: 1fr; }
  .report-kpis { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .phone { display: none; }
  .team-grid, .team-grid.team-exec { grid-template-columns: 1fr; }
  .browser-body { padding: 18px; }
}
