/* ============================================================
   3D Image Carousel for Elementor — Stylesheet v1.1.0
   Two layouts: .tce-layout-fan  |  .tce-layout-stack
   ============================================================ */

/* ── Reset & Container ─────────────────────────────────────── */
.tce-carousel-wrap {
  position: relative;
  width: 100%;     overflow: hidden;
    padding: 0 100px;
 box-sizing: border-box;
  -webkit-user-select: none;
  user-select: none;
}

/* ── Section Heading with horizontal lines ─────────────────── */
.tce-section-heading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  text-align: center;
  font-size: clamp(22px, 4vw, 36px);
  font-weight: 800;
  letter-spacing: 0.15em;
  color: #fff;
  margin: 0 0 40px;
  text-transform: uppercase;
  white-space: nowrap;
}
.tce-section-heading::before,
.tce-section-heading::after {
  content: '';
  display: block;
  height: 2px;
  width: 80px;
  background: #ff6b00;
  flex-shrink: 0;
  margin: 0 18px;
}

/* ── Stage (holds track + arrows) ─────────────────────────── */
.tce-stage {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Navigation Arrows ─────────────────────────────────────── */
.tce-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  background: transparent; 
  color: #ff6b00;  
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.25s, color 0.25s, transform 0.25s;
  flex-shrink: 0;
  padding: 0;
  line-height: 1;
}
.tce-arrow:hover {
  transform: translateY(-50%) scale(1.08);
}
/* Arrow icon image support */
.tce-arrow img,
.tce-arrow svg {
  width:50px; 
  display: block;
  pointer-events: none;
}
.tce-arrow-prev { left: 10px; }
.tce-arrow-next { right: 10px; }

/* ── Track ─────────────────────────────────────────────────── */
.tce-track {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1400px;
}

/* ── Individual Cards ──────────────────────────────────────── */
.tce-slide-card {
  position: absolute;
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  transition:
    transform 0.6s cubic-bezier(.25,.8,.25,1),
    opacity   0.6s ease,
    box-shadow 0.6s ease;
  backface-visibility: hidden;
  will-change: transform, opacity;
}
.tce-slide-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.tce-card-link {
  position: absolute;
  inset: 0;
  z-index: 5;
}
.tce-card-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.38);
  transition: background 0.4s;
}
.tce-slide-card.tce-active .tce-card-overlay {
  background: rgba(0,0,0,0.08);
}

/* ── Active card — orange border glow ─────────────────────── */
.tce-slide-card.tce-active {
  box-shadow: 0 0 0 3px #ff6b00, 0 24px 70px rgba(0,0,0,.75);
}

/* ════════════════════════════════════════════════════════════
   LAYOUT 1 — FAN SPREAD
   Exactly matches reference: centre card large & straight,
   side cards angled with increasing rotation & scale-down.
   3 cards visible on each side (pos ±1, ±2, ±3).
   ════════════════════════════════════════════════════════════ */
.tce-layout-fan .tce-track {
  height: 380px;
}

.tce-layout-fan .tce-slide-card {
  width:  40%;
  max-width: 500px;
  height: 80%;
}

/* ── Centre (active) ── */
.tce-layout-fan .tce-slide-card[data-pos="0"] {
  transform: translateX(0) scale(1) rotateY(0deg);
  z-index: 10;
  opacity: 1;
}

/* ── ±1  (nearest side) ── */
.tce-layout-fan .tce-slide-card[data-pos="1"] {
  transform: translateX(62%) scale(0.80) rotateY(-22deg);
  z-index: 8;
  opacity: 0.88;
}
.tce-layout-fan .tce-slide-card[data-pos="-1"] {
  transform: translateX(-62%) scale(0.80) rotateY(22deg);
  z-index: 8;
  opacity: 0.88;
}

/* ── ±2  (mid side) ── */
.tce-layout-fan .tce-slide-card[data-pos="2"] {
  transform: translateX(112%) scale(0.63) rotateY(-36deg);
  z-index: 6;
  opacity: 0.65;
}
.tce-layout-fan .tce-slide-card[data-pos="-2"] {
  transform: translateX(-112%) scale(0.63) rotateY(36deg);
  z-index: 6;
  opacity: 0.65;
}

/* ── ±3  (far side, partially clipped) ── */
.tce-layout-fan .tce-slide-card[data-pos="3"] {
  transform: translateX(155%) scale(0.48) rotateY(-48deg);
  z-index: 4;
  opacity: 0.38;
}
.tce-layout-fan .tce-slide-card[data-pos="-3"] {
  transform: translateX(-155%) scale(0.48) rotateY(48deg);
  z-index: 4;
  opacity: 0.38;
}

/* ── Hidden / far off screen ── */
.tce-layout-fan .tce-slide-card[data-pos="edge"],
.tce-layout-fan .tce-slide-card[data-pos="-edge"] {
  opacity: 0;
  pointer-events: none;
  z-index: 1;
}
.tce-layout-fan .tce-slide-card[data-pos="edge"] {
  transform: translateX(200%) scale(0.4) rotateY(-55deg);
}
.tce-layout-fan .tce-slide-card[data-pos="-edge"] {
  transform: translateX(-200%) scale(0.4) rotateY(55deg);
}

/* ════════════════════════════════════════════════════════════
   LAYOUT 2 — FLAT STACK
   Slight vertical offset, depth scale, very minimal rotation.
   3 cards each side.
   ════════════════════════════════════════════════════════════ */
.tce-layout-stack .tce-track {
  height: 320px;
}
.tce-layout-stack .tce-slide-card {
  width: 40%;
  max-width: 500px;
  height: 100%;
}

/* Centre */
.tce-layout-stack .tce-slide-card[data-pos="0"] {
  transform: translateX(0) translateY(0) scale(1) rotateY(0deg);
  z-index: 10;
  opacity: 1;
}
/* ±1 */
.tce-layout-stack .tce-slide-card[data-pos="1"] {
  transform: translateX(48%) translateY(5%) scale(0.84) rotateY(-7deg);
  z-index: 8;
  opacity: 0.80;
}
.tce-layout-stack .tce-slide-card[data-pos="-1"] {
  transform: translateX(-48%) translateY(5%) scale(0.84) rotateY(7deg);
  z-index: 8;
  opacity: 0.80;
}
/* ±2 */
.tce-layout-stack .tce-slide-card[data-pos="2"] {
  transform: translateX(88%) translateY(10%) scale(0.68) rotateY(-12deg);
  z-index: 6;
  opacity: 0.55;
}
.tce-layout-stack .tce-slide-card[data-pos="-2"] {
  transform: translateX(-88%) translateY(10%) scale(0.68) rotateY(12deg);
  z-index: 6;
  opacity: 0.55;
}
/* ±3 */
.tce-layout-stack .tce-slide-card[data-pos="3"] {
  transform: translateX(122%) translateY(16%) scale(0.54) rotateY(-16deg);
  z-index: 4;
  opacity: 0.30;
}
.tce-layout-stack .tce-slide-card[data-pos="-3"] {
  transform: translateX(-122%) translateY(16%) scale(0.54) rotateY(16deg);
  z-index: 4;
  opacity: 0.30;
}
/* Hidden */
.tce-layout-stack .tce-slide-card[data-pos="edge"],
.tce-layout-stack .tce-slide-card[data-pos="-edge"] {
  opacity: 0;
  pointer-events: none;
  z-index: 1;
}

/* ── Info Panel ────────────────────────────────────────────── */
.tce-info-panel {
  text-align: center;
  min-height: 88px;
  margin-top: 22px;
  padding: 0 10%;
}
.tce-info-item {
  animation: tceFadeUp 0.4s ease both;
}
@keyframes tceFadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tce-active-label {
  font-size: clamp(13px, 2.2vw, 18px);
  font-weight: 800;
  letter-spacing: 0.12em;
  color: #ff6b00;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.tce-active-desc {
  font-size: clamp(12px, 1.6vw, 15px);
  color: #ccc;
  margin: 0 0 14px;
  line-height: 1.6;
}
.tce-cta-btn {
  display: inline-block;
  background: #ff6b00;
  color: #fff;
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 28px;
  border-radius: 4px;
  transition: background 0.25s, transform 0.2s;
}
.tce-cta-btn:hover {
  background: #e05e00;
  transform: translateY(-2px);
  color: #fff;
}

/* ── Dots ──────────────────────────────────────────────────── */
.tce-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
}
.tce-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.3s, transform 0.3s;
}
.tce-dot.tce-dot-active {
  background: #ff6b00;
  transform: scale(1.45);
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .tce-layout-fan .tce-track  { height: 320px; }
  .tce-layout-stack .tce-track { height: 280px; }
  .tce-layout-fan  .tce-slide-card { width: 44%; }
  .tce-layout-stack .tce-slide-card { width: 48%; }

  /* fan ±3 barely peeks */
  .tce-layout-fan .tce-slide-card[data-pos="3"]  { transform: translateX(168%) scale(0.42) rotateY(-50deg); opacity:.22; }
  .tce-layout-fan .tce-slide-card[data-pos="-3"] { transform: translateX(-168%) scale(0.42) rotateY(50deg); opacity:.22; }
}

@media (max-width: 900px) {
  .tce-layout-fan .tce-track  { height: 270px; }
  .tce-layout-stack .tce-track { height: 240px; }
  .tce-layout-fan  .tce-slide-card { width: 52%; }
  .tce-layout-stack .tce-slide-card { width: 56%; }

  .tce-layout-fan .tce-slide-card[data-pos="1"]  { transform: translateX(64%) scale(0.74) rotateY(-18deg); opacity:.78; }
  .tce-layout-fan .tce-slide-card[data-pos="-1"] { transform: translateX(-64%) scale(0.74) rotateY(18deg); opacity:.78; }
  .tce-layout-fan .tce-slide-card[data-pos="2"]  { transform: translateX(116%) scale(0.57) rotateY(-30deg); opacity:.50; }
  .tce-layout-fan .tce-slide-card[data-pos="-2"] { transform: translateX(-116%) scale(0.57) rotateY(30deg); opacity:.50; }
  .tce-layout-fan .tce-slide-card[data-pos="3"]  { opacity:0; pointer-events:none; }
  .tce-layout-fan .tce-slide-card[data-pos="-3"] { opacity:0; pointer-events:none; }

  .tce-layout-stack .tce-slide-card[data-pos="1"]  { transform: translateX(54%) translateY(6%) scale(0.76) rotateY(-6deg); opacity:.68; }
  .tce-layout-stack .tce-slide-card[data-pos="-1"] { transform: translateX(-54%) translateY(6%) scale(0.76) rotateY(6deg); opacity:.68; }
  .tce-layout-stack .tce-slide-card[data-pos="2"]  { transform: translateX(98%) translateY(12%) scale(0.60) rotateY(-10deg); opacity:.38; }
  .tce-layout-stack .tce-slide-card[data-pos="-2"] { transform: translateX(-98%) translateY(12%) scale(0.60) rotateY(10deg); opacity:.38; }
  .tce-layout-stack .tce-slide-card[data-pos="3"]  { opacity:0; pointer-events:none; }
  .tce-layout-stack .tce-slide-card[data-pos="-3"] { opacity:0; pointer-events:none; }
}

@media (max-width: 600px) {
  .tce-layout-fan .tce-track,
  .tce-layout-stack .tce-track { height: 210px; }
  .tce-layout-fan  .tce-slide-card,
  .tce-layout-stack .tce-slide-card { width: 68%; }

  .tce-layout-fan .tce-slide-card[data-pos="1"]  { transform: translateX(66%) scale(0.66) rotateY(-14deg); opacity:.60; }
  .tce-layout-fan .tce-slide-card[data-pos="-1"] { transform: translateX(-66%) scale(0.66) rotateY(14deg); opacity:.60; }
  .tce-layout-fan .tce-slide-card[data-pos="2"]  { opacity:0; pointer-events:none; }
  .tce-layout-fan .tce-slide-card[data-pos="-2"] { opacity:0; pointer-events:none; }

  .tce-layout-stack .tce-slide-card[data-pos="1"]  { transform: translateX(58%) translateY(8%) scale(0.68) rotateY(-5deg); opacity:.55; }
  .tce-layout-stack .tce-slide-card[data-pos="-1"] { transform: translateX(-58%) translateY(8%) scale(0.68) rotateY(5deg); opacity:.55; }
  .tce-layout-stack .tce-slide-card[data-pos="2"]  { opacity:0; pointer-events:none; }
  .tce-layout-stack .tce-slide-card[data-pos="-2"] { opacity:0; pointer-events:none; }

  .tce-arrow-prev { left: 2px; }
  .tce-arrow-next { right: 2px; }
  .tce-info-panel { padding: 0 4%; }
  .tce-section-heading::before,
  .tce-section-heading::after { width: 40px; margin: 0 10px; }
}

@media (max-width: 400px) {
  .tce-layout-fan .tce-track,
  .tce-layout-stack .tce-track { height: 180px; }
  .tce-layout-fan  .tce-slide-card,
  .tce-layout-stack .tce-slide-card { width: 80%; }
  .tce-section-heading::before,
  .tce-section-heading::after { width: 24px; margin: 0 8px; }
}
