/**
 * Hub pages — full-width makeover (profile, links, market, status).
 * Loaded after hub.css. Edit hub/hero.php for banner; hub/sections/* for content.
 */

/* ── Full bleed stage ── */
.hub-public-body--full .hub-public-stage-wrap,
.hub-public-body--full .hub-public-main {
  max-width: none;
  width: 100%;
  padding-inline: 0;
}

.hub-public-body--full .hub-public-stage {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.hub-public-body--full .hub-public-stage__content {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: clamp(1rem, 2.5vw, 2rem) clamp(1rem, 3.5vw, 2.75rem) clamp(2.5rem, 5vw, 4rem);
  box-sizing: border-box;
}

.hub-public-body--full .hub-public-content,
.hub-public-body--full .hub-wrap,
.hub-public-body--full .profile-section.hub-wrap {
  max-width: none !important;
  width: 100%;
}

/* ── Cinematic hero ── */
.hub-public-cover--cinema .hub-public-cover__banner--cinema {
  min-height: clamp(16rem, 42vw, 28rem);
}

.hub-public-hero-stack--cinema .hub-public-cover--cinema.hub-public-cover--with-hub .hub-public-cover__banner--cinema {
  min-height: clamp(18rem, 48vw, 32rem);
}

.hub-public-cover__banner-fade--cinema {
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(0, 0, 0, 0.15) 35%,
    transparent 55%,
    rgba(15, 15, 20, 0.75) 78%,
    transparent 92%,
    var(--landing-bg-mid, var(--hub-cover-page-bg, #121212)) 100%
  ) !important;
}

.hub-hero-premium .hub-public-cover__banner-bg--mesh {
  background:
    radial-gradient(ellipse 90% 70% at 20% 20%, color-mix(in srgb, var(--hub-accent) 35%, transparent), transparent 55%),
    radial-gradient(ellipse 80% 60% at 85% 30%, rgba(59, 130, 246, 0.25), transparent 50%),
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(139, 92, 246, 0.18), transparent 55%),
    linear-gradient(135deg, #0c0c12 0%, #14141f 45%, #0a0a10 100%) !important;
}

.hub-public-cover__dock {
  position: relative;
  z-index: 4;
  width: 100%;
  margin-top: clamp(-4.5rem, -10vw, -2.5rem);
  padding: 0 clamp(1rem, 3.5vw, 2.75rem) clamp(0.5rem, 2vw, 1.25rem);
  box-sizing: border-box;
}

.hub-public-cover__dock-inner {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: clamp(1.15rem, 2.8vw, 1.75rem) clamp(1.25rem, 3.2vw, 2rem);
  border-radius: 20px;
}

.hub-public-cover--cinema .hub-public-cover__identity {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  max-width: none;
  width: 100%;
}

.hub-public-cover--cinema .hub-public-cover__avatar {
  width: clamp(5.5rem, 14vw, 8.5rem);
  height: clamp(5.5rem, 14vw, 8.5rem);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
}

.hub-public-cover__avatar-ph {
  font-weight: 800;
  color: #fff;
}

.hub-public-cover--cinema .hub-public-cover__title {
  font-size: clamp(2rem, 5.5vw, 3.25rem);
}

.hub-public-cover__badge {
  padding: 0.22rem 0.58rem;
  border-radius: 8px;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.88);
}

.hub-public-cover__badge--role {
  background: color-mix(in srgb, var(--hub-accent) 28%, rgba(0, 0, 0, 0.4));
  border-color: color-mix(in srgb, var(--hub-accent) 42%, transparent);
  color: #f5f3ff;
}

/* ── Sticky tab dock (full width) ── */
.hub-tab-dock {
  position: sticky;
  top: calc(var(--landing-nav-offset, 4.25rem) - 0.15rem);
  z-index: 25;
  width: 100%;
  margin: 0;
  padding: 0;
}

body:not(.hub-public-guest-shell) .hub-tab-dock {
  top: 0.35rem;
}

.hub-tab-dock__inner {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.35rem;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0.55rem clamp(1rem, 3.5vw, 2.75rem);
  box-sizing: border-box;
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--hub-scrollbar-thumb, color-mix(in srgb, var(--hub-accent) 40%, rgba(148, 163, 184, 0.4))) var(--hub-scrollbar-track, transparent);
}

.hub-tab-dock__tab {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex-shrink: 0;
  padding: 0.55rem 1rem;
  border-radius: 12px;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.72);
  border: 1px solid transparent;
  transition: background 0.18s ease, color 0.15s ease, border-color 0.18s ease;
}

.hub-tab-dock__tab:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}

.hub-tab-dock__tab--active {
  color: #fff;
  background: color-mix(in srgb, var(--hub-accent) 22%, rgba(0, 0, 0, 0.5));
  border-color: color-mix(in srgb, var(--hub-accent) 45%, rgba(255, 255, 255, 0.12));
  box-shadow: 0 0 24px color-mix(in srgb, var(--hub-accent) 20%, transparent);
}

.hub-tab-dock__tab--edit {
  margin-left: auto;
  color: color-mix(in srgb, var(--hub-accent) 30%, #e9d5ff);
}

.hub-tab-dock__ic {
  display: inline-flex;
  opacity: 0.9;
}

.hub-public-body--with-hero .hub-public-floating-nav {
  display: none !important;
}

/* ── Page canvas ── */
.hub-page {
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0;
}

.hub-page__mesh {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.45;
  background:
    radial-gradient(ellipse 80% 50% at 10% 0%, color-mix(in srgb, var(--hub-accent) 12%, transparent), transparent 55%),
    radial-gradient(ellipse 60% 40% at 95% 20%, rgba(59, 130, 246, 0.06), transparent 50%);
}

.hub-page__inner {
  position: relative;
  z-index: 1;
  width: 100%;
}

/* Full-width section strip */
.hub-section-intro--strip {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.85rem 1.25rem;
  width: 100%;
  max-width: none;
  margin: 0 0 1.5rem;
  padding: clamp(1rem, 2.5vw, 1.35rem) clamp(1.1rem, 2.5vw, 1.5rem);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
  box-shadow: 0 16px 48px -24px rgba(0, 0, 0, 0.65);
  overflow: hidden;
}

.hub-section-intro__strip-bg {
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, var(--hub-accent), color-mix(in srgb, var(--hub-accent) 30%, #3b82f6));
  border-radius: 18px 0 0 18px;
}

.hub-section-intro--strip .hub-section-intro__icon {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  margin-left: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: color-mix(in srgb, var(--hub-accent) 60%, #e9d5ff);
  background: color-mix(in srgb, var(--hub-accent) 14%, rgba(0, 0, 0, 0.35));
  border: 1px solid color-mix(in srgb, var(--hub-accent) 28%, rgba(255, 255, 255, 0.08));
}

.hub-section-intro--strip .hub-section-intro__body {
  flex: 1 1 16rem;
  min-width: 0;
}

.hub-section-intro--strip .hub-section-intro__title {
  font-size: clamp(1.35rem, 3.2vw, 2rem);
}

.hub-section-intro--strip .hub-section-intro__cta {
  margin-left: auto;
}

/* ── Links makeover ── */
.hub-page__split--links {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  width: 100%;
}

@media (min-width: 72rem) {
  .hub-page__split--links {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
    align-items: start;
  }
}

.hub-links-about {
  padding: 1.25rem 1.35rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  height: 100%;
}

.hub-link-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 17rem), 1fr));
  gap: 0.85rem;
  width: 100%;
  list-style: none;
  padding: 0;
  margin: 0;
}

.hub-mui-list.hub-link-grid {
  display: grid;
}

.hub-link-tile {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem 1.1rem;
  border-radius: 16px;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
  border: 1px solid rgba(255, 255, 255, 0.09);
  box-shadow: 0 8px 28px -12px rgba(0, 0, 0, 0.55);
  transition: transform 0.18s ease, border-color 0.2s ease, box-shadow 0.22s ease;
}

.hub-link-tile:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--hub-accent) 40%, rgba(255, 255, 255, 0.14));
  box-shadow: 0 16px 40px -14px color-mix(in srgb, var(--hub-accent) 25%, rgba(0, 0, 0, 0.6));
}

.hub-link-tile__ic {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: color-mix(in srgb, var(--hub-accent) 16%, rgba(0, 0, 0, 0.35));
  border: 1px solid color-mix(in srgb, var(--hub-accent) 28%, transparent);
}

.hub-link-tile__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.hub-link-tile__label {
  font-weight: 700;
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.95);
}

.hub-link-tile__hint {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.45);
}

.hub-link-tile__arrow {
  flex-shrink: 0;
  opacity: 0.45;
  font-size: 1.1rem;
}

.hub-link-tile--discord {
  padding: 0.65rem;
}

/* ── Status board ── */
.hub-status-board {
  width: 100%;
}

.hub-status-grid--board {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  gap: 1rem;
}

@media (min-width: 64rem) {
  .hub-status-grid--board {
    grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
  }
}

.hub-status-card--board {
  min-height: 7.5rem;
}

.hub-status-card--board-wide {
  grid-column: 1 / -1;
  min-height: 10rem;
  align-items: center;
  text-align: center;
}

.hub-status-card__beam {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--status-c, #94a3b8), transparent);
  opacity: 0.85;
}

/* ── Market full width ── */
.hub-market-canvas {
  width: 100%;
  max-width: none;
}

.hub-page--market .hub-market-filters--compact {
  width: 100%;
  max-width: none;
}

.hub-page--market .hub-market-live__board,
.hub-page--market .hub-product-grid--public {
  width: 100%;
  max-width: none !important;
}

.hub-page--market .hub-product-grid--public {
  --hub-market-cols: 4;
}

@media (max-width: 1400px) {
  .hub-page--market .hub-product-grid--public { --hub-market-cols: 3; }
}
@media (max-width: 1024px) {
  .hub-page--market .hub-product-grid--public { --hub-market-cols: 2; }
}
@media (max-width: 520px) {
  .hub-page--market .hub-product-grid--public { --hub-market-cols: 1; }
}

.hub-page--market .hub-card.hub-card--market {
  width: 100%;
  max-width: none;
}

/* ── Profile dashboard ── */
.hub-profile-bento {
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.35rem;
}

.hub-profile-dashboard {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  width: 100%;
}

.hub-profile-dashboard__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 56rem) {
  .hub-profile-dashboard__row {
    grid-template-columns: 1fr 1fr;
  }
}

.hub-profile-dashboard__panel {
  padding: 1.35rem 1.45rem;
  border-radius: 16px;
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.hub-profile-dashboard__panel--wide {
  grid-column: 1 / -1;
}

.hub-page__empty {
  max-width: 36rem;
  margin: 2rem auto;
}

/* Light theme */
[data-mantine-color-scheme="light"] .hub-tab-dock {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.95));
  border-bottom-color: #e2e8f0;
}

[data-mantine-color-scheme="light"] .hub-tab-dock__tab {
  color: #475569;
}

[data-mantine-color-scheme="light"] .hub-tab-dock__tab--active {
  color: #0f172a;
}

[data-mantine-color-scheme="light"] .hub-public-cover__dock-inner {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.92));
  border-color: #e2e8f0;
}

[data-mantine-color-scheme="light"] .hub-section-intro--strip {
  background: #fff;
  border-color: #e2e8f0;
}

[data-mantine-color-scheme="light"] .hub-link-tile,
[data-mantine-color-scheme="light"] .hub-profile-dashboard__panel {
  background: #fff;
  border-color: #e2e8f0;
}

[data-mantine-color-scheme="light"] .hub-link-tile__label {
  color: #0f172a;
}

@media (max-width: 640px) {
  .hub-public-cover__dock-inner {
    border-radius: 16px;
  }
  .hub-public-cover--cinema .hub-public-cover__identity {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .hub-public-cover--cinema .hub-public-cover__copy {
    align-items: center;
    text-align: center;
  }
  .hub-tab-dock__tab--edit {
    margin-left: 0;
  }
}
