/* =========================================================================
   COMPONENT: TEAM (Carrusel lateral)
   Descripció: Carrusel d'equip amb fons fosc. 2 targetes visibles desktop.
   Adaptat de team-component.css original.
   Elements: .team__carousel-wrapper, .team__scroll-container, .team__track,
             .team__card, .team__nav, .team__dots, .team__dot--active
   ========================================================================= */

/* --- Variables --- */
.team {
   --team-bg: #0a0a0a;
   --team-text: #f5f5f5;
   --team-muted: #a0a0a0;
   --team-accent: var(--color-accent, #e87d52);
   --card-bg: rgba(255, 255, 255, 0.03);
   --card-hover-bg: rgba(255, 255, 255, 0.07);
   --card-border: rgba(255, 255, 255, 0.06);
   --card-gap: 2rem;
}

/* --- Secció --- */
.team {
   background-color: var(--team-bg);
   color: var(--team-text);
   padding: 6rem 2rem;
   overflow: hidden;
}

/* --- Header --- */
.team__header {
   text-align: center;
   max-width: 600px;
   margin: 0 auto 4rem;
}

.team__overline {
   font-size: 0.7rem;
   font-weight: 700;
   letter-spacing: 2px;
   text-transform: uppercase;
   color: var(--team-accent);
   margin: 0 0 0.75rem;
}

.team__title {
   font-family: var(--font-heading);
   font-size: clamp(1.75rem, 4vw, 2.5rem);
   font-weight: 700;
   color: var(--team-text);
   margin: 0 0 0.75rem;
}

.team__divider {
   width: 50px;
   height: 2px;
   background-color: var(--team-accent);
   margin: 0 auto 1.25rem;
}

.team__intro {
   font-size: 1.05rem;
   font-weight: 300;
   color: var(--team-muted);
   margin: 0;
}

/* --- Wrapper del carrusel (botó + contenidor + botó) --- */
.team__carousel-wrapper {
   position: relative;
   max-width: 1200px;
   margin: 0 auto;
   display: flex;
   align-items: center;
   gap: 1rem;
}

.team__scroll-container {
   overflow: hidden;
   width: 100%;
}

/* --- Track que es desplaça --- */
.team__track {
   display: flex;
   gap: var(--card-gap);
   transition: transform 0.5s ease-in-out;
   align-items: stretch;
}

/* --- Targeta: 2 per fila desktop, 1 mòbil --- */
.team__card {
   flex: 0 0 calc(50% - 1rem);
   /* 2 per vista */
   background: var(--card-bg);
   border: 1px solid var(--card-border);
   border-radius: 12px;
   overflow: hidden;
   transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}

.team__card:hover {
   transform: translateY(-8px);
   background: var(--card-hover-bg);
   border-color: rgba(232, 125, 82, 0.3);
}

.team__card-link {
   display: flex;
   flex-direction: column;
   height: 100%;
   text-decoration: none;
   color: inherit;
   border-radius: 12px;
   transition: all 0.3s ease;
}

.team__card-link:focus {
   outline: 2px solid var(--team-accent);
   outline-offset: 4px;
   background: var(--card-hover-bg);
   transform: translateY(-4px);
}

.team__card-link:hover {
   background: var(--card-hover-bg);
   transform: translateY(-4px);
}

/* --- Foto --- */
.team__photo {
   width: 100%;
   height: 350px;
   background-color: #1a1a1a;
   overflow: hidden;
}

.team__photo img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   object-position: center center;
   display: block;
   filter: grayscale(20%);
   transition: filter 0.3s ease;
}

.team__photo img[src="/assets/img/team-placeholder.jpg"] {
   background: linear-gradient(135deg, #333 0%, #555 100%);
   display: flex;
   align-items: center;
   justify-content: center;
   color: #888;
   font-size: 0.9rem;
   text-align: center;
   padding: 1rem;
}

.team__card:hover .team__photo img {
   filter: grayscale(0%);
}

/* --- Info --- */
.team__info {
   padding: 2rem;
   display: flex;
   flex-direction: column;
   flex: 1;
}

.team__name {
   font-family: var(--font-heading);
   font-size: 1.4rem;
   font-weight: 700;
   color: var(--team-text);
   margin: 0 0 0.4rem;
}

.team__role {
   font-size: 0.8rem;
   font-weight: 600;
   letter-spacing: 2px;
   text-transform: uppercase;
   color: var(--team-accent);
   margin: 0 0 1rem;
}

.team__specialties {
   display: flex;
   flex-wrap: wrap;
   gap: 0.4rem;
   margin-bottom: 1rem;
   min-height: 56px;
   align-content: flex-start;
}

.team__specialty {
   font-size: 0.75rem;
   font-weight: 500;
   background: rgba(232, 125, 82, 0.10);
   color: var(--team-accent);
   border-radius: 4px;
   padding: 0.3rem 0.75rem;
}

.team__bio {
   font-size: 0.9rem;
   line-height: 1.65;
   color: var(--team-muted);
   font-weight: 300;
   flex-grow: 1;
   margin: 0 0 1.5rem;
}

.team__cta {
   font-size: 0.875rem;
   font-weight: 600;
   color: var(--team-accent);
   border-bottom: 1px solid transparent;
   padding-bottom: 2px;
   transition: border-color 0.2s ease, padding-left 0.2s ease;
   display: inline-block;
   margin-top: auto;
}

.team__card:hover .team__cta {
   border-bottom-color: var(--team-accent);
   padding-left: 4px;
}

/* --- Botons de navegació --- */
.team__nav {
   flex-shrink: 0;
   width: 50px;
   height: 50px;
   border-radius: 50%;
   border: none;
   background: rgba(255, 255, 255, 0.1);
   color: var(--team-text);
   cursor: pointer;
   font-size: 1.2rem;
   display: flex;
   align-items: center;
   justify-content: center;
   transition: background 0.3s ease;
   z-index: 10;
}

.team__nav:hover:not(:disabled) {
   background: var(--team-accent);
}

.team__nav:disabled {
   opacity: 0.3;
   cursor: not-allowed;
}

/* --- Dots indicadors --- */
.team__dots {
   display: flex;
   justify-content: center;
   gap: 0.6rem;
   margin-top: 2rem;
}

.team__dot {
   width: 10px;
   height: 10px;
   border-radius: 50%;
   border: none;
   background: rgba(255, 255, 255, 0.2);
   cursor: pointer;
   padding: 0;
   transition: background 0.2s ease, transform 0.2s ease;
}

.team__dot--active {
   background: var(--team-accent);
   transform: scale(1.3);
}

/* --- Responsive --- */
@media (max-width: 768px) {
   .team__card {
      flex: 0 0 100%;
   }

   .team__nav {
      display: none;
   }

   .team__scroll-container {
      scroll-snap-type: x mandatory;
      overflow-x: auto;
   }

   .team__card {
      scroll-snap-align: center;
   }

   .team__photo {
      height: 280px;
   }
}

@media (max-width: 540px) {
   .team {
      padding: 4rem 1.25rem;
   }
}