/* Portfolio styles: 3D presence map and team layouts.
   Source: portfolio.html split for cacheability and ownership. */
    /* ============ TEAM ============ */
    /* ── Presence Map ── */
    .presence-map {
      position: relative;
      border-radius: 20px;
      overflow: hidden;
      background:
        radial-gradient(circle at 63% 45%, rgba(255, 159, 61, .14), transparent 32%),
        radial-gradient(circle at 26% 72%, rgba(126, 218, 255, .08), transparent 28%),
        linear-gradient(135deg, rgba(12, 10, 8, .96), rgba(3, 3, 3, .9));
      border: 1px solid rgba(245, 241, 234, .06);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
    }

    .presence-map::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      background-image:
        linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px);
      background-size: 44px 44px;
      mask-image: radial-gradient(circle at 50% 48%, black, transparent 76%);
      opacity: .32;
      pointer-events: none;
    }

    .presence-map::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, .38) 100%);
      pointer-events: none;
    }

    .presence-map__chart {
      position: relative;
      z-index: 1;
      width: 100%;
      height: clamp(380px, 55vw, 680px);
      min-height: 360px;
      overflow: hidden;
      isolation: isolate;
      cursor: grab;
      touch-action: none;
      user-select: none;
    }

    /* The scene must fill the chart without catching status/legend divs. */
    .presence-map__scene,
    .presence-map__chart > .scene-container,
    .presence-map__chart canvas {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100% !important;
      height: 100% !important;
      display: block;
    }

    .presence-map__chart.is-grabbing,
    .presence-map__chart.is-grabbing canvas {
      cursor: grabbing;
    }

    .presence-map__state {
      position: absolute;
      z-index: 9;
      inset: 0;
      display: grid;
      place-items: center;
      padding: 24px;
      color: rgba(245, 241, 234, .74);
      font: 800 10px/1.5 var(--mono);
      letter-spacing: .14em;
      text-align: center;
      text-transform: uppercase;
      pointer-events: none;
      transition: opacity .24s ease;
    }

    .presence-map__state.is-hidden {
      opacity: 0;
    }

    /* globe.gl nests its scene container; lift it above the vignette without touching UI overlays. */
    .presence-map__chart > div,
    .presence-map__chart > div > div,
    .presence-map__chart .scene-container,
    .presence-map__chart > .scene-container {
      position: relative !important;
      z-index: 3;
      overflow: visible !important;
    }

    .presence-map__chart .scene-container,
    .presence-map__chart > .scene-container {
      isolation: isolate;
    }

    .presence-map__chart .scene-container canvas,
    .presence-map__chart > .scene-container canvas {
      position: absolute !important;
      inset: 0;
      z-index: 1 !important;
    }

    .presence-map__chart .scene-tooltip,
    .presence-map__chart [class*="tooltip"],
    .presence-map__chart .scene-container .scene-tooltip,
    .presence-map__chart .scene-container [class*="tooltip"],
    .presence-map__chart > .scene-container > :not(canvas),
    .presence-map__chart > .scene-tooltip,
    .presence-map__chart > [class*="tooltip"],
    .presence-map__chart > .scene-container .scene-tooltip,
    .presence-map__chart > .scene-container [class*="tooltip"],
    .presence-map__chart > .scene-container [style*="translate3d"] {
      position: absolute;
      z-index: 2147483000 !important;
      pointer-events: none;
      transform-style: preserve-3d;
      will-change: transform, opacity;
      isolation: auto;
    }

    .presence-map__chart .scene-tooltip,
    .presence-map__chart .scene-container .scene-tooltip,
    .presence-map__chart > .scene-container .scene-tooltip,
    .presence-map__chart > .scene-container [class*="tooltip"] {
      filter: drop-shadow(0 14px 30px rgba(0, 0, 0, .42));
      mix-blend-mode: normal;
    }

    .presence-map__chart .scene-tooltip > span {
      display: inline-flex;
      align-items: center;
      max-width: min(260px, calc(100vw - 48px));
      font-family: var(--sf-display) !important;
      font-weight: 650 !important;
      line-height: 1.18 !important;
      box-shadow:
        0 16px 36px rgba(0, 0, 0, .58),
        inset 0 1px 0 rgba(255, 255, 255, .08);
    }

    .presence-map__hub-label {
      position: absolute;
      z-index: 10;
      top: 18px;
      right: 18px;
      display: grid;
      gap: 5px;
      max-width: min(260px, calc(100% - 36px));
      padding: 11px 13px;
      border: 1px solid rgba(255, 159, 61, .2);
      border-radius: 18px;
      background: rgba(6, 5, 4, .72);

      color: rgba(245, 241, 234, .86);
      font: 800 10px/1.35 var(--mono);
      letter-spacing: .08em;
      text-transform: uppercase;
      pointer-events: none;
      box-shadow:
        0 18px 54px rgba(0, 0, 0, .34),
        inset 0 1px 0 rgba(255, 255, 255, .08);
      backdrop-filter: blur(16px) saturate(130%);
      -webkit-backdrop-filter: blur(16px) saturate(130%);
      transition:
        opacity 240ms cubic-bezier(.22, 1, .36, 1),
        transform 240ms cubic-bezier(.22, 1, .36, 1),
        filter 240ms cubic-bezier(.22, 1, .36, 1);
    }

    .presence-map.is-globe-dragging .presence-map__hub-label {
      opacity: 0;
      transform: translate3d(0, -8px, 0) scale(.98);
      filter: blur(5px);
    }

    .presence-map__hold-progress {
      --globe-hold-progress: 0;
      position: absolute;
      z-index: 18;
      left: 50%;
      top: 50%;
      width: min(154px, calc(100% - 32px));
      display: grid;
      gap: 7px;
      padding: 9px 10px;
      border: 1px solid rgba(255, 177, 86, .24);
      border-radius: 999px;
      background:
        radial-gradient(circle at 18% 0%, rgba(255, 177, 86, .22), transparent 58%),
        linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .025)),
        rgba(6, 5, 4, .82);
      color: rgba(245, 241, 234, .84);
      font: 850 8px/1 var(--mono);
      letter-spacing: .12em;
      text-align: center;
      text-transform: uppercase;
      pointer-events: none;
      opacity: 0;
      filter: blur(4px);
      transform: translate3d(-50%, calc(-100% - 16px), 0) scale(.96);
      box-shadow:
        0 18px 44px rgba(0, 0, 0, .42),
        0 0 30px rgba(255, 138, 61, .12),
        inset 0 1px 0 rgba(255, 255, 255, .1);
      backdrop-filter: blur(16px) saturate(128%);
      -webkit-backdrop-filter: blur(16px) saturate(128%);
      transition:
        opacity 140ms ease,
        filter 140ms ease,
        transform 140ms ease;
    }

    .presence-map__hold-progress.is-active {
      opacity: 1;
      filter: blur(0);
      transform: translate3d(-50%, calc(-100% - 16px), 0) scale(1);
    }

    .presence-map__hold-progress.is-complete {
      border-color: rgba(255, 201, 135, .5);
      box-shadow:
        0 18px 48px rgba(0, 0, 0, .44),
        0 0 42px rgba(255, 138, 61, .26),
        inset 0 1px 0 rgba(255, 255, 255, .16);
    }

    .presence-map__hold-progress-track {
      display: block;
      height: 4px;
      overflow: hidden;
      border-radius: 999px;
      background: rgba(245, 241, 234, .1);
    }

    .presence-map__hold-progress-bar {
      display: block;
      width: 100%;
      height: 100%;
      border-radius: inherit;
      background: linear-gradient(90deg, #ff7a1a, #ffd197);
      transform: scaleX(var(--globe-hold-progress));
      transform-origin: left center;
      box-shadow: 0 0 18px rgba(255, 138, 61, .48);
    }

    .presence-map__hub-label strong,
    .presence-map__hub-place {
      color: #ffbd7a;
      font: 760 clamp(18px, 1.6vw, 24px)/1 var(--sf-display);
      letter-spacing: 0;
      text-transform: none;
    }

    .presence-map__hub-kicker,
    .presence-map__hub-count {
      color: rgba(245, 241, 234, .72);
      font: 850 9px/1.15 var(--mono);
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .presence-map__legend {
      position: absolute;
      z-index: 10;
      bottom: 18px;
      left: 20px;
      display: flex;
      flex-direction: column;
      gap: 6px;
      pointer-events: none;
      max-width: min(240px, 46vw);
    }

    .presence-map__legend-item {
      display: grid;
      grid-template-columns: auto auto minmax(0, 1fr) auto;
      align-items: center;
      gap: 7px;
      font: 700 10px/1 var(--mono);
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--dim);
    }

    .presence-map__legend-rank {
      color: rgba(255, 204, 142, .76);
      font-weight: 900;
    }

    .presence-map__legend-item strong {
      min-width: 0;
      overflow: hidden;
      color: rgba(245, 241, 234, .82);
      font: inherit;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .presence-map__legend-item em {
      color: var(--amber-soft);
      font-style: normal;
      font-weight: 900;
    }

    .presence-map__legend-dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .presence-map__load {
      position: absolute;
      z-index: 20;
      inset: clamp(18px, 3vw, 34px);
      display: grid;
      place-items: center;
      padding: clamp(18px, 4vw, 34px);
      border: 1px solid rgba(255, 159, 61, .18);
      border-radius: 18px;
      background:
        radial-gradient(circle at 50% 0%, rgba(255, 159, 61, .18), transparent 42%),
        linear-gradient(135deg, rgba(10, 8, 7, .88), rgba(3, 3, 3, .72));
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .06),
        0 22px 70px rgba(0, 0, 0, .4);
      text-align: center;
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      transition: opacity .28s ease, transform .28s ease, visibility .28s ease;
    }

    .presence-map.is-globe-requested .presence-map__load,
    .presence-map.is-globe-ready .presence-map__load {
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      transform: scale(.985);
    }

    .presence-map.is-globe-error .presence-map__load {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
      transform: none;
    }

    .presence-map__load-card {
      width: min(100%, 520px);
      display: grid;
      justify-items: center;
      gap: 14px;
    }

    .presence-map__load-kicker {
      font: 900 10px/1 var(--mono);
      letter-spacing: .18em;
      text-transform: uppercase;
      color: #ffb46d;
    }

    .presence-map__load-title {
      margin: 0;
      font-family: var(--display);
      font-size: clamp(30px, 5vw, 54px);
      line-height: .95;
      letter-spacing: -.03em;
      color: var(--ink);
    }

    .presence-map__load-copy {
      margin: 0;
      max-width: 46ch;
      color: rgba(245, 241, 234, .72);
      font-size: clamp(13px, 1.4vw, 15px);
      line-height: 1.55;
    }

    .presence-map__load-button {
      min-height: 46px;
      margin-top: 6px;
      padding: 0 20px;
      border: 1px solid rgba(255, 159, 61, .42);
      border-radius: 999px;
      background: linear-gradient(135deg, #ffb35f, #ff7a18);
      color: #120806;
      box-shadow: 0 12px 34px rgba(255, 119, 24, .22);
      font: 950 11px/1 var(--mono);
      letter-spacing: .12em;
      text-transform: uppercase;
      cursor: pointer;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
    }

    .presence-map__load-button:hover {
      transform: translateY(-1px);
      box-shadow: 0 16px 42px rgba(255, 119, 24, .3);
    }

    .presence-map__load-button:focus-visible {
      outline: 2px solid rgba(255, 220, 168, .95);
      outline-offset: 4px;
    }

    .presence-map__load-button:disabled {
      cursor: wait;
      filter: saturate(.8);
      opacity: .78;
      transform: none;
    }

    .presence-map__load-note {
      color: rgba(245, 241, 234, .46);
      font: 800 10px/1.4 var(--mono);
      letter-spacing: .09em;
      text-transform: uppercase;
    }


    /* ── Team grid ── */
    .team-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1px;
      background: var(--line);
      border: 1px solid var(--line)
    }

    .member {
      background: var(--bg);
      padding: 36px;
      display: flex;
      flex-direction: column;
      gap: 20px;
      position: relative;
      cursor: pointer;
      transition: background .35s;
      min-height: 520px;
    }

    .member:hover {
      border-color: rgba(255, 138, 61, .22);
      background: #0e0e12;
      box-shadow:
        inset 0 0 0 1px rgba(255, 138, 61, .07),
        0 18px 42px rgba(0, 0, 0, .22);
    }

    .member--lead {
      grid-column: span 1;
    }

    .team-grid--core {
      margin-bottom: 14px;
    }

    .member__photo {
      aspect-ratio: 1/1;
      background: #161618;
      border: 1px solid var(--line);
      position: relative;
      overflow: hidden;
    }

    .member__photo::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 55%, rgba(0, 0, 0, .5) 100%);
    }

    .member__photo .ph {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      filter: grayscale(.2) contrast(1.05);
      transition: filter .5s, transform .8s;
    }

    .member__photo .ph--diogo {
      background-image: url("../diogo.png");
      background-position: center 30%;
    }

    .member__photo .ph--thiago {
      background-image: url("../thiago.png");
      background-position: center 30%;
    }

    .member__photo .ph--mateus {
      background-image: url("../mateus.jpg");
      background-position: center 25%;
    }

    .member__photo .ph--felipe {
      background-image: url("../felipe.jpg");
      background-position: center 20%;
    }

    .member:hover .member__photo .ph {
      filter: grayscale(0) contrast(1.1);
      transform: scale(1.04)
    }

    .member__photo .placeholder {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      font-family: var(--mono);
      font-size: 10px;
      letter-spacing: .18em;
      color: var(--ink-mute);
      text-transform: uppercase;
      background: repeating-linear-gradient(135deg, #131316 0, #131316 8px, #16161b 8px, #16161b 16px);
    }

    .member__role {
      font-family: var(--mono);
      font-size: 10px;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--amber);
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .member__meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding-top: 2px;
    }

    .member__role::before {
      content: "";
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--amber)
    }

    .member__name {
      font-family: var(--display);
      font-weight: 400;
      font-size: clamp(34px, 3.2vw, 44px);
      line-height: 1.0;
      letter-spacing: -.025em;
      text-wrap: balance;
      word-break: keep-all;
      padding-bottom: .05em;
    }

    .member__name em {
      font-family: var(--display);
      font-style: normal;
      color: var(--amber-soft);
      font-weight: 500
    }

    .member__bio {
      font-family: var(--display);
      font-weight: 300;
      font-size: 14px;
      line-height: 1.55;
      color: var(--ink-dim);
      max-width: 42ch;
    }

    .member__skills {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-top: auto;
      padding-top: 20px;
      border-top: 1px solid var(--line)
    }

    .member__skills span {
      font-family: var(--mono);
      font-size: 10px;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--ink-dim);
      padding: 5px 10px;
      border: 1px solid var(--line-2);
      border-radius: 999px;
    }

    .member__num {
      display: inline-flex;
      align-items: center;
      min-height: 30px;
      padding: 0 12px;
      border: 1px solid rgba(255, 255, 255, .12);
      border-radius: 999px;
      background: rgba(255, 255, 255, .035);
      font-family: var(--mono);
      font-size: 10px;
      letter-spacing: .14em;
      color: rgba(245, 240, 236, .58);
      text-transform: uppercase;
      white-space: nowrap;
    }

    .member--core .member__role {
      color: var(--amber)
    }

    .member--support .member__role {
      color: var(--ink-dim)
    }

    .member--support .member__role::before {
      background: var(--ink-dim)
    }

    /* hierarchy: DJs full-width pair on top, support below */
    .team-grid {
      grid-template-columns: 1fr 1fr
    }

    .team-grid .member--core {}

    @media(max-width:900px) {
      .team-grid {
        grid-template-columns: 1fr
      }
    }
