.elementor-13 .elementor-element.elementor-element-0bea4f3{--display:flex;--min-height:100vh;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--align-items:stretch;--flex-wrap:nowrap;}.elementor-13 .elementor-element.elementor-element-0bea4f3:not(.elementor-motion-effects-element-type-background), .elementor-13 .elementor-element.elementor-element-0bea4f3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://tech.teamasia.com/wp-content/uploads/2026/01/background.png");background-position:top center;background-repeat:no-repeat;background-size:cover;}.elementor-13 .elementor-element.elementor-element-e15d3b1{--display:flex;}@media(max-width:1024px){.elementor-13 .elementor-element.elementor-element-0bea4f3{--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:10px 10px;--row-gap:10px;--column-gap:10px;}}/* Start custom CSS for container, class: .elementor-element-0bea4f3 *//* =========================================================
   CNY Hero Flip – FINAL (Non‑Skinny Guaranteed)
   Includes:
   - Transparent stage + embers + aura + load entrance
   - Hero flip overlay + behind blur
   - Side‑pinned back panel (left stays left, right stays right)
   - HARD FIX: prevents “skinny panel” via min-width + minmax grid columns
   Works with your exact HTML/JS.
   ========================================================= */

/* ---------- Transparent Stage + subtle embers ---------- */
.cny-stage{
  background: transparent;
  min-height: auto;
  display: grid;
  place-items: center;
  padding: 48px 20px;
  position: relative;
  overflow: hidden;
}

.cny-stage::before,
.cny-stage::after{
  content:"";
  position:absolute;
  inset:-30%;
  pointer-events:none;
  opacity: 0.25;
  background:
    radial-gradient(circle at 18% 30%, rgba(255, 210, 120, 0.22) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 42%, rgba(255, 140, 60, 0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 45% 70%, rgba(255, 210, 120, 0.14) 0 2px, transparent 3px),
    radial-gradient(circle at 62% 78%, rgba(255, 80, 80, 0.10) 0 2px, transparent 3px);
  filter: blur(0.3px);
  animation: embers 9s linear infinite;
}

.cny-stage::after{
  opacity: 0.18;
  animation-duration: 12s;
}

@keyframes embers{
  from{ transform: translate3d(0,0,0); }
  to  { transform: translate3d(6%,-6%,0); }
}

/* ---------- Two-up layout ---------- */
.cny-pair{
  --gap: clamp(14px, 4vw, 36px);
  width: min(980px, 100%);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--gap);
  align-items: start;
  position: relative;
  z-index: 1;
  isolation: isolate;
  min-width: 0; /* important in some theme layouts */
}

@media (max-width: 720px){
  .cny-pair{ grid-template-columns: 1fr; }
}

/* ---------- Card base ---------- */
.cny-card{
  position: relative;
  border-radius: 22px;
  overflow: visible;
  transform-origin: 50% 70%;
  min-width: 0; /* allow normal card content sizing without weird overflow */

  /* pre-load entrance state */
  opacity: 0;
  transform: perspective(1000px) translateY(26px) rotateX(14deg) scale(0.96);
  filter: blur(14px);

  transition:
    transform 260ms ease,
    filter 260ms ease,
    opacity 260ms ease;
}

.cny-card.left  { --delay: 120ms; }
.cny-card.right { --delay: 320ms; }

/* ---------- Aura layers ---------- */
.cny-card::before{
  content:"";
  position:absolute;
  inset:-22px;
  border-radius: 28px;
  z-index: -2;
  pointer-events:none;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 210, 120, 0.55), transparent 55%),
    radial-gradient(circle at 70% 80%, rgba(255, 60, 60, 0.38), transparent 60%),
    radial-gradient(circle at 50% 50%, rgba(255, 190, 90, 0.20), transparent 62%);
  filter: blur(14px);
  opacity: 0;
  transform: scale(0.98);
}

.cny-card::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius: 26px;
  z-index: -1;
  pointer-events:none;
  background: conic-gradient(
    from 210deg,
    rgba(255, 220, 140, 0.00) 0 35%,
    rgba(255, 220, 140, 0.38) 42%,
    rgba(255, 70, 70, 0.20) 52%,
    rgba(255, 220, 140, 0.00) 60% 100%
  );
  filter: blur(12px);
  opacity: 0;
  transform: rotate(-18deg) scale(1);
}

/* ---------- Flip system ---------- */
.cny-flip{
  position: relative;
  transform-style: preserve-3d;
  transition: transform 900ms cubic-bezier(.2,.9,.2,1);
  cursor: pointer;
  outline: none;
  will-change: transform;
  min-width: 0;
}

.cny-face{ backface-visibility: hidden; }
.cny-front{ transform: rotateY(0deg); }

.cny-back{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  transform: rotateY(180deg);
  pointer-events: none;
  min-width: 0;
}

.cny-flip.is-flipped{ transform: rotateY(180deg); }
.cny-flip.is-flipped .cny-back{ pointer-events: auto; }

/* ---------- Front image frame (cropped portrait) ---------- */
.cny-frame{
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 211, 130, 0.25);
  box-shadow:
    0 18px 55px rgba(0, 0, 0, 0.25),
    0 0 0 1px rgba(255, 56, 56, 0.10) inset;

  aspect-ratio: 3 / 4;
  max-height: min(78vh, 760px);
  position: relative;
}

.cny-frame img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 30%;
  display: block;
  transform: scale(1.06);
  filter: saturate(0.92) contrast(1.05);
}

.cny-frame::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity: 0;
  transform: translateX(-120%);
  background: linear-gradient(
    110deg,
    transparent 0%,
    rgba(255, 235, 190, 0.00) 35%,
    rgba(255, 235, 190, 0.26) 48%,
    rgba(255, 235, 190, 0.00) 62%,
    transparent 100%
  );
}

/* ---------- Back panel (readable, non-skinny) ---------- */
.cny-back-panel{
  /* Hard minimum prevents skinny panels even if the grid tries to squeeze */
  min-width: 380px;
  width: min(92%, 520px);
  max-width: 520px;

  height: min(92%, 540px);
  max-height: 92%;
  border-radius: 20px;
  padding: 20px 22px 16px;

  background:
    radial-gradient(120% 140% at 10% 0%, rgba(255, 215, 140, 0.18), transparent 60%),
    radial-gradient(140% 160% at 100% 100%, rgba(255, 70, 70, 0.14), transparent 60%),
    rgba(10, 0, 10, 0.78);

  color: rgba(255,255,255,0.92);
  border: 1px solid rgba(255, 211, 130, 0.28);
  box-shadow:
    0 18px 60px rgba(0,0,0,0.45),
    0 0 0 1px rgba(255, 56, 56, 0.10) inset;

  transform: translateZ(45px);
  overflow: auto;
}

.cny-back-panel h3{
  margin: 0 0 10px;
  font-size: 18px;
  letter-spacing: 0.3px;
  color: rgba(255, 220, 150, 0.98);
}

.cny-back-panel p{
  margin: 0 0 12px;
  line-height: 1.6;
  font-size: 14px;
  color: rgba(255,255,255,0.90);
}

.cny-back-meta{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  opacity: 0.85;
  color: rgba(255, 235, 190, 0.9);
  border-top: 1px solid rgba(255, 211, 130, 0.18);
  padding-top: 10px;
}

.cny-flip:focus-visible .cny-frame,
.cny-flip:focus-visible .cny-back-panel{
  outline: 2px solid rgba(255, 220, 150, 0.55);
  outline-offset: 4px;
}

/* =========================================================
   HERO MODE + BEHIND BLUR + SIDE PIN
   ========================================================= */

.cny-card.is-hero{
  grid-column: 1 / -1;
  grid-row: 1;
  z-index: 50;
}

/* hero flip forward */
.cny-card.is-hero .cny-flip{
  transform: rotateY(180deg) translateZ(90px);
}

/* unclicked behind + blur (stays in same row) */
.cny-pair.has-hero .cny-card:not(.is-hero){
  grid-row: 1;
  z-index: 0;
  opacity: 0.22;
  filter: blur(10px) saturate(0.85);
  transform: scale(0.985);
  pointer-events: none;

  transition:
    filter 650ms cubic-bezier(.2,.9,.2,1),
    opacity 650ms cubic-bezier(.2,.9,.2,1),
    transform 650ms cubic-bezier(.2,.9,.2,1);
}

.cny-pair.has-hero .cny-card:not(.is-hero)::before{
  opacity: 0.35 !important;
  filter: blur(18px) !important;
}
.cny-pair.has-hero .cny-card:not(.is-hero)::after{
  opacity: 0.18 !important;
}

/* HERO BACK FACE: 2-column canvas; minmax prevents weird shrink behavior */
.cny-card.is-hero .cny-back{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--gap);
  align-items: center;
  justify-items: stretch;
  place-items: normal; /* overrides earlier center placement */
}

/* pin panel to correct side */
.cny-card.left.is-hero .cny-back-panel{
  grid-column: 1;
  justify-self: start;
  margin-left: 8px;
}
.cny-card.right.is-hero .cny-back-panel{
  grid-column: 2;
  justify-self: end;
  margin-right: 8px;
}

/* Mobile: 1 column, allow smaller min width */
@media (max-width: 720px){
  .cny-card.is-hero .cny-back{
    grid-template-columns: 1fr;
    gap: 0;
  }

  .cny-back-panel{
    min-width: 0; /* allow it to fit small screens */
    width: 100%;
    max-width: 100%;
  }

  .cny-card.left.is-hero .cny-back-panel,
  .cny-card.right.is-hero .cny-back-panel{
    grid-column: 1;
    justify-self: stretch;
    margin-left: 0;
    margin-right: 0;
  }
}

/* ---------- Entrance animations (after page load) ---------- */
.page-loaded .cny-card{
  animation: magicalEntrance 1100ms cubic-bezier(.2,.9,.2,1) both;
  animation-delay: var(--delay, 0ms);
}

.page-loaded .cny-card::before{
  opacity: 0.95;
  animation:
    auraPop 1100ms cubic-bezier(.2,.9,.2,1) both,
    auraBreath 2.8s ease-in-out infinite;
  animation-delay:
    var(--delay, 0ms),
    calc(var(--delay, 0ms) + 900ms);
}

.page-loaded .cny-card::after{
  opacity: 0.70;
  animation:
    auraPop 1100ms cubic-bezier(.2,.9,.2,1) both,
    auraSpin 6.5s linear infinite;
  animation-delay:
    var(--delay, 0ms),
    calc(var(--delay, 0ms) + 900ms);
}

.page-loaded .cny-frame::after{
  animation: shimmer 1450ms cubic-bezier(.2,.8,.2,1) both;
  animation-delay: calc(var(--delay, 0ms) + 120ms);
}

.page-loaded .cny-frame img{
  animation: imgBloom 1200ms ease-out both;
  animation-delay: var(--delay, 0ms);
}

/* ---------- Keyframes ---------- */
@keyframes magicalEntrance{
  0%{
    opacity: 0;
    transform: perspective(1000px) translateY(26px) rotateX(14deg) scale(0.92);
    filter: blur(14px);
  }
  55%{
    opacity: 1;
    transform: perspective(1000px) translateY(0px) rotateX(0deg) scale(1.01);
    filter: blur(2px);
  }
  100%{
    opacity: 1;
    transform: perspective(1000px) translateY(0px) rotateX(0deg) scale(1.00);
    filter: blur(0px);
  }
}

@keyframes auraPop{
  0%   { transform: scale(0.88) rotate(-22deg); opacity: 0; }
  60%  { transform: scale(1.03) rotate(-10deg); opacity: 1; }
  100% { transform: scale(1.00) rotate(-18deg); opacity: 1; }
}

@keyframes auraBreath{
  0%,100% { transform: scale(0.98); opacity: 0.78; }
  50%     { transform: scale(1.03); opacity: 1.00; }
}

@keyframes auraSpin{
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes shimmer{
  0%   { opacity: 0; transform: translateX(-120%); }
  25%  { opacity: 1; }
  100% { opacity: 0; transform: translateX(120%); }
}

@keyframes imgBloom{
  0%   { transform: scale(1.10); filter: saturate(0.75) contrast(1.10); }
  100% { transform: scale(1.06); filter: saturate(0.98) contrast(1.06); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  .cny-stage::before,
  .cny-stage::after,
  .cny-card,
  .cny-card::before,
  .cny-card::after,
  .cny-frame::after,
  .cny-frame img,
  .cny-flip{
    animation: none !important;
    transition: none !important;
  }

  .cny-card{
    opacity: 1;
    transform: none;
    filter: none;
  }

  .cny-card::before{ opacity: 0.6; }
  .cny-card::after  { opacity: 0.4; }

  .cny-pair.has-hero .cny-card:not(.is-hero){
    filter: none !important;
    opacity: 0.35;
  }
}/* End custom CSS */