/* =========================================================================
   FEIRAN ABOUT / WHO WE ARE — scoped Elementor widget styles
   Everything namespaced under .feiran-about-widget so it never collides
   with the host theme. Mirrors the Feiran homepage "About" section.
   ========================================================================= */

.feiran-about-widget{
  /* Brand tokens — overridable from the Style tab */
  --fa-red-600:#d92231;
  --fa-navy-900:#101a36;
  --fa-ink-900:#101a36;
  --fa-ink-700:#28344a;
  --fa-ink-500:#5d6478;
  --fa-ink-400:#8a8f9c;
  --fa-line:#e1e2e6;
  --fa-line-strong:#cdd0d6;
  --fa-bg-elev:#f6f7f9;
  --fa-white:#ffffff;

  --fa-card-radius:18px;
  --fa-btn-radius:999px;
  --fa-gap:80px;
  --fa-content-max:1320px;

  --fa-font: "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --fa-mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
  --fa-easing:cubic-bezier(.2,.7,.2,1);

  font-family:var(--fa-font);
  color:var(--fa-ink-900);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.feiran-about-widget *,
.feiran-about-widget *::before,
.feiran-about-widget *::after{ box-sizing:border-box; }

/* ---- Section shell --------------------------------------------------- */
.feiran-about{
  width:100%;
}
.feiran-about__container{
  width:100%;
  max-width:var(--fa-content-max);
  margin:0 auto;
}
.feiran-about__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--fa-gap);
  align-items:center;
}
/* Image-left variant */
.feiran-about[data-fa-image="left"] .feiran-about__media{ order:-1; }

/* ---- Text column ----------------------------------------------------- */
.feiran-about__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--fa-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--fa-ink-500);
  margin:0 0 18px;
}
.feiran-about__eyebrow::before{
  content:"";
  width:24px;height:1px;
  background:var(--fa-red-600);
  opacity:.9;
}

.feiran-about__headline{
  margin:0 0 22px;
  font-size:clamp(28px, 3vw, 44px);
  font-weight:600;
  line-height:1.05;
  letter-spacing:-0.02em;
  color:var(--fa-ink-900);
  text-wrap:balance;
}

.feiran-about__body{
  margin:0;
  max-width:54ch;
  font-size:17px;
  line-height:1.55;
  color:var(--fa-ink-700);
  text-wrap:pretty;
}

.feiran-about__points{
  list-style:none;
  margin:32px 0 36px;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.feiran-about__points li{
  display:flex;
  gap:14px;
  align-items:flex-start;
  font-size:15.5px;
  line-height:1.55;
  color:var(--fa-ink-900);
}
.feiran-about__points .fa-num{
  flex:0 0 auto;
  font-family:var(--fa-mono);
  font-size:12px;
  color:var(--fa-red-600);
  padding-top:3px;
}

/* ---- Button ---------------------------------------------------------- */
.feiran-about__cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  border-radius:var(--fa-btn-radius);
  font-size:15px;
  font-weight:500;
  color:var(--fa-ink-900);
  background:transparent;
  box-shadow:inset 0 0 0 1px var(--fa-line-strong);
  transition:transform .25s var(--fa-easing), background .2s, box-shadow .25s;
  white-space:nowrap;
}
.feiran-about__cta:hover{
  background:var(--fa-white);
  box-shadow:inset 0 0 0 1px var(--fa-ink-900);
}
.feiran-about__cta .fa-arrow{
  width:14px;height:14px;
  display:inline-block;
  transition:transform .25s var(--fa-easing);
}
.feiran-about__cta:hover .fa-arrow{ transform:translateX(4px); }
.feiran-about__cta .fa-arrow svg{ display:block;width:100%;height:100% }

/* ---- Media card ------------------------------------------------------ */
.feiran-about__media{
  position:relative;
  aspect-ratio:1 / 1.02;
  border-radius:var(--fa-card-radius);
  overflow:hidden;
  background:var(--fa-navy-900);
  box-shadow:0 30px 60px -30px rgba(7,13,28,.4);
  isolation:isolate;
}
.feiran-about__photo{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.001); /* avoid sub-pixel edge */
  transition:transform 1.2s var(--fa-easing);
}
.feiran-about__media:hover .feiran-about__photo{ transform:scale(1.04); }
.feiran-about__photo::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(10,16,36,.35) 0%,
    rgba(10,16,36,.12) 28%,
    rgba(10,16,36,.10) 50%,
    rgba(10,16,36,.88) 100%);
}

.feiran-about__corner{
  position:absolute;
  z-index:2;
  font-family:var(--fa-mono);
  font-size:11px;
  line-height:1;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.78);
}
.feiran-about__corner--tl{ top:34px; left:34px; }
.feiran-about__corner--tr{ top:34px; right:34px; }
.feiran-about__corner--br{ bottom:34px; right:34px; }

.feiran-about__caption{
  position:absolute;
  z-index:2;
  left:34px;
  right:34px;
  bottom:64px;
  color:rgba(255,255,255,.9);
  font-family:var(--fa-mono);
  font-size:13px;
  line-height:1.5;
}
.feiran-about__caption strong{
  display:block;
  margin-bottom:4px;
  font-family:var(--fa-font);
  font-size:20px;
  font-weight:600;
  letter-spacing:-.01em;
  color:#fff;
}

/* ---- Entrance reveal ------------------------------------------------- */
.feiran-about [data-fa-reveal]{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .8s var(--fa-easing), transform .8s var(--fa-easing);
}
.feiran-about [data-fa-reveal].is-in{
  opacity:1;
  transform:translateY(0);
}
.feiran-about__media[data-fa-reveal]{ transform:translateY(28px) scale(.985); }
.feiran-about__media[data-fa-reveal].is-in{ transform:translateY(0) scale(1); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:980px){
  .feiran-about__grid{
    grid-template-columns:1fr;
    gap:48px;
  }
  /* On stack, image always sits below the copy regardless of side setting */
  .feiran-about[data-fa-image="left"] .feiran-about__media{ order:0; }
  .feiran-about__media{ aspect-ratio:16 / 12; }
}

@media (max-width:680px){
  .feiran-about__corner,
  .feiran-about__caption{ left:22px; right:22px; }
  .feiran-about__corner--tl{ top:24px; left:22px; }
  .feiran-about__corner--tr{ top:24px; right:22px; }
  .feiran-about__corner--br{ bottom:24px; right:22px; }
  .feiran-about__caption{ bottom:50px; }
  .feiran-about__caption strong{ font-size:18px; }
  .feiran-about__body{ font-size:16px; }
}

@media (prefers-reduced-motion: reduce){
  .feiran-about *{
    animation:none !important;
    transition:none !important;
  }
  .feiran-about [data-fa-reveal]{ opacity:1 !important; transform:none !important; }
}
