:root {
  --ej-ink: #101010;
  --ej-ink-2: #1a1a1a;
  --ej-body: #44403a;
  --ej-muted: #8a8378;
  --ej-white: #ffffff;
  --ej-soft: #fbfaf7;
  --ej-border: #e5dfd4;
  --ej-teal: #32c7bc;
  --ej-teal-deep: #15998f;
  --ej-display: "Iowan Old Style", "Noto Serif TC", "Songti TC", Georgia, serif;
  --ej-body-font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Noto Sans TC", system-ui, sans-serif;
  --ej-pad: clamp(20px, 5vw, 56px);
  --ej-content: 1180px;
  --ej-wide: 1360px;
}

/* Portfolio CPT listing: Elementor Posts widget styled to match the portfolio grid. */
#portfolio-cpt-posts .elementor-posts-container {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

#portfolio-cpt-posts article.elementor-post {
  display: flex !important;
  flex-direction: column !important;
  gap: 11px !important;
  background: transparent !important;
}

#portfolio-cpt-posts .elementor-post__thumbnail__link {
  display: block !important;
  overflow: hidden !important;
  border-radius: 2px !important;
  margin: 0 !important;
  width: 100% !important;
}

#portfolio-cpt-posts .elementor-post__thumbnail {
  padding-bottom: 118% !important;
}

#portfolio-cpt-posts .elementor-post__thumbnail img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform .45s ease, filter .45s ease !important;
}

#portfolio-cpt-posts article.elementor-post:hover .elementor-post__thumbnail img {
  transform: scale(1.055) !important;
  filter: saturate(1.05) !important;
}

#portfolio-cpt-posts .elementor-post__text {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

#portfolio-cpt-posts .elementor-post__title,
#portfolio-cpt-posts .elementor-post__title a {
  color: #1F1F1F !important;
  font-family: "Noto Serif TC", serif !important;
  font-size: 22px !important;
  line-height: 1.45 !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
}

#portfolio-cpt-posts .elementor-post__excerpt,
#portfolio-cpt-posts .elementor-post__excerpt p {
  color: #8B857C !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
  margin: 0 !important;
}

#portfolio-cpt-posts .elementor-post__read-more {
  color: #159C95 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

@media (max-width: 1024px) {
  #portfolio-cpt-posts .elementor-posts-container {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  #portfolio-cpt-posts .elementor-posts-container {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  #portfolio-cpt-posts .elementor-post__title,
  #portfolio-cpt-posts .elementor-post__title a {
    font-size: 20px !important;
  }
}

body {
  color: var(--ej-body);
  font-family: var(--ej-body-font);
  line-height: 1.72;
}

.elementor-location-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 999;
}

.elementor-location-header .elementor-nav-menu {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(20px, 3vw, 42px);
}

.elementor-location-header .elementor-item {
  color: rgba(255, 255, 255, .9);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .12em;
  white-space: nowrap;
}

.elementor-location-header .elementor-item.elementor-item-active,
.elementor-location-header .elementor-item:hover {
  color: var(--ej-teal);
}

#ej-site-header {
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  padding: 18px var(--ej-pad) !important;
  transition: background .35s cubic-bezier(.19, 1, .22, 1), border-color .35s cubic-bezier(.19, 1, .22, 1), box-shadow .35s cubic-bezier(.19, 1, .22, 1), backdrop-filter .35s cubic-bezier(.19, 1, .22, 1);
}

body.ej-scrolled #ej-site-header {
  background: rgba(16, 16, 16, .94) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .14) !important;
  box-shadow: 0 18px 60px rgba(0, 0, 0, .14) !important;
  backdrop-filter: blur(18px) !important;
}

#ej-site-header .menu-item-148 {
  display: none !important;
}

#ej-site-header > .e-con-inner {
  width: min(100%, var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  display: grid !important;
  grid-template-columns: minmax(360px, 420px) minmax(500px, 1fr) auto !important;
  align-items: center !important;
  gap: clamp(18px, 3vw, 42px) !important;
}

#ej-site-header .elementor-widget-image {
  justify-self: start !important;
}

#ej-site-header .elementor-widget-nav-menu {
  justify-self: center !important;
  min-width: 0 !important;
  width: auto !important;
}

#ej-site-header .elementor-nav-menu {
  flex-wrap: nowrap !important;
}

.conversion-section {
  position: relative;
  overflow: hidden;
}

.hero-inner,
.hero-inner:empty {
  display: none !important;
}

.home-hero,
.about-hero,
.service-hero,
.portfolio-hero,
.case-hero,
.contact-hero,
.blog-hero {
  min-height: clamp(640px, 56vw, 850px);
  padding: clamp(116px, 14vh, 168px) var(--ej-pad) clamp(72px, 11vh, 112px) !important;
  color: var(--ej-white);
}

#home-hero {
  display: grid !important;
  align-items: center !important;
  padding: 0 !important;
}

#home-hero > #hero-content {
  --width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  --content-width: var(--ej-wide) !important;
  position: relative !important;
  left: max(var(--ej-pad), calc((100vw - var(--ej-wide)) / 2)) !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  justify-self: start !important;
  align-self: center !important;
  margin-inline: 0 !important;
  padding: 132px 0 72px !important;
  background: transparent !important;
}

#home-hero > #hero-content > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  gap: 22px !important;
  justify-items: start !important;
  justify-content: start !important;
  align-items: start !important;
}

.home-hero::before,
.about-hero::before,
.service-hero::before,
.portfolio-hero::before,
.case-hero::before,
.contact-hero::before,
.blog-hero::before,
.bottom-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 18% 28%, rgba(50, 199, 188, .24), transparent 34%),
    linear-gradient(90deg, rgba(16, 16, 16, .86), rgba(16, 16, 16, .48) 46%, rgba(16, 16, 16, .2));
  pointer-events: none;
}

.home-hero > .e-con-inner,
.about-hero > .e-con-inner,
.service-hero > .e-con-inner,
.portfolio-hero > .e-con-inner,
.case-hero > .e-con-inner,
.contact-hero > .e-con-inner,
.blog-hero > .e-con-inner,
.bottom-cta > .e-con-inner {
  position: relative;
  z-index: 1;
  width: min(100%, var(--ej-wide));
  margin-inline: auto;
}

.hero-copy,
.blog-hero-copy {
  --width: 560px !important;
  width: min(100%, 560px) !important;
  max-width: 560px !important;
  align-self: flex-start !important;
  padding: 0 !important;
  background: transparent !important;
}

.hero-copy .elementor-heading-title,
.blog-hero-copy .elementor-heading-title {
  color: var(--ej-white);
}

.hero-copy h1,
.blog-hero-copy h1,
.hero-copy .elementor-heading-title.elementor-size-default {
  font-family: var(--ej-display);
  font-size: clamp(40px, 6vw, 82px);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: .04em;
}

.hero-kicker .elementor-heading-title,
.eyebrow .elementor-heading-title {
  color: var(--ej-teal);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.hero-copy .elementor-widget-text-editor,
.blog-hero-copy .elementor-widget-text-editor {
  max-width: 430px;
  color: rgba(255, 255, 255, .82);
  font-size: clamp(16px, 1.8vw, 19px);
}

.hero-actions {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  width: auto !important;
  max-width: 560px;
}

.hero-actions .elementor-widget-button,
.hero-actions .elementor-button {
  --container-widget-width: auto;
  --container-widget-flex-grow: 0;
  width: auto !important;
  max-width: max-content !important;
  flex: 0 0 auto !important;
}

.hero-actions .btn .elementor-button {
  min-height: 49px;
  width: 135px !important;
  padding: 13px 20px;
  justify-content: center;
}

.intro {
  padding: clamp(76px, 8vw, 122px) 0 !important;
  background: var(--ej-white) !important;
  border-bottom: 1px solid var(--ej-border);
}

.intro > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), 1240px) !important;
  max-width: 1240px !important;
  margin-inline: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, .96fr) minmax(0, 1.04fr) !important;
  gap: clamp(56px, 7vw, 92px) !important;
  align-items: center !important;
}

.intro-media {
  position: relative !important;
  padding: 0 clamp(20px, 4vw, 34px) 36px 0 !important;
  background: transparent !important;
}

.intro-media > .e-con-inner {
  position: relative;
}

.intro-photo img {
  width: 100%;
  min-height: clamp(430px, 42vw, 584px);
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 26px 72px rgba(16, 16, 16, .10);
}

.experience-card {
  position: absolute !important;
  right: 0;
  bottom: 0;
  z-index: 2;
  width: min(44%, 238px) !important;
  min-height: 168px;
  border-radius: 5px;
  background: #087981 !important;
  color: var(--ej-white);
  box-shadow: 0 22px 44px rgba(16, 16, 16, .18);
}

.experience-card .elementor-heading-title {
  color: var(--ej-white) !important;
}

.elementor-50 .experience-card .experience-number .elementor-heading-title {
  font-family: var(--ej-body-font) !important;
  font-size: clamp(38px, 4vw, 58px) !important;
  font-weight: 850 !important;
  line-height: .95 !important;
}

.elementor-50 .experience-card .experience-label .elementor-heading-title {
  font-family: var(--ej-body-font) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  white-space: normal !important;
}

.intro-text {
  display: grid !important;
  align-content: center !important;
  padding-block: clamp(20px, 3vw, 42px) !important;
  background: transparent !important;
}

.intro-text .eyebrow {
  margin-bottom: 18px;
}

.about-title .elementor-heading-title,
.about-title {
  max-width: 610px;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.2;
  letter-spacing: .04em;
}

.intro-text .section-copy {
  max-width: 610px;
  margin-top: 18px;
  color: var(--ej-muted);
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 2.05;
  letter-spacing: .045em;
}

.stats {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 22px 46px !important;
  max-width: 520px;
  margin-top: clamp(32px, 4vw, 46px);
  background: transparent !important;
}

.stat {
  position: relative;
  min-width: 0;
  padding: 0 0 2px 22px !important;
  background: transparent !important;
}

.stat::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  bottom: 0;
  width: 1px;
  background: color-mix(in srgb, #087981, var(--ej-border) 68%);
}

.stat:nth-child(3) {
  grid-column: 1 / 2;
}

.stat-number .elementor-heading-title {
  color: #087981;
  font-family: var(--ej-body-font);
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 850;
  line-height: 1;
}

.stat-text .elementor-heading-title {
  margin-top: 8px;
  color: var(--ej-body);
  font-family: var(--ej-body-font);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.35;
  white-space: nowrap;
}

.section,
.section-soft,
.values-grid,
.bottom-cta {
  padding: clamp(58px, 8vw, 112px) var(--ej-pad) !important;
}

.section > .e-con-inner,
.section-soft > .e-con-inner,
.values-grid > .e-con-inner {
  width: min(100%, var(--ej-content));
  margin-inline: auto;
}

.container,
.container-wide {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  background: transparent !important;
}

.container-wide {
  max-width: var(--ej-wide) !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
}

.container > .e-con-inner,
.container-wide > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

.section-heading {
  display: grid !important;
  justify-items: start !important;
  gap: 10px !important;
  margin-block-end: 0 !important;
  background: transparent !important;
}

.section-heading > .e-con-inner,
.works-heading-box > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: start !important;
  gap: 10px !important;
  padding: 0 !important;
}

.title-rule .elementor-spacer-inner,
.step-line .elementor-spacer-inner {
  height: 1px !important;
}

.title-rule {
  width: 72px !important;
  max-width: 72px !important;
}

.title-rule .elementor-spacer-inner {
  background: var(--ej-teal);
}

.advantages {
  display: block !important;
  border-block: 1px solid var(--ej-border);
  background: transparent !important;
}

.advantages > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  padding: 0 !important;
}

.advantage {
  display: block !important;
  min-width: 0;
  padding: 28px 26px !important;
  border-inline-end: 1px solid var(--ej-border);
  background: transparent !important;
}

.advantage > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
  gap: 14px !important;
  padding: 0 !important;
}

.advantage:last-child {
  border-inline-end: 0;
}

.advantage .icon .elementor-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  color: var(--ej-teal-deep);
  border: 1px solid color-mix(in srgb, var(--ej-teal), transparent 62%);
  border-radius: 999px;
}

.advantage h3.elementor-heading-title,
.advantage .elementor-heading-title,
.service-card h3.elementor-heading-title,
.service-card .elementor-heading-title,
.project-card h3.elementor-heading-title,
.project-card .elementor-heading-title,
.process-step h3.elementor-heading-title,
.process-step .elementor-heading-title {
  margin: 0 !important;
  color: var(--ej-ink-2);
  font-family: var(--ej-body-font);
  font-weight: 700;
  letter-spacing: .06em;
}

.advantage .elementor-widget-text-editor,
.service-card .elementor-widget-text-editor,
.process-step .elementor-widget-text-editor {
  margin: 0 !important;
  color: var(--ej-muted);
  font-size: 14px;
  line-height: 1.8;
}

.services-grid {
  display: block !important;
  background: transparent !important;
}

.services-grid > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 24px !important;
  padding: 0 !important;
}

.service-card {
  display: block !important;
  overflow: clip !important;
  border: 1px solid var(--ej-border);
  border-radius: 8px;
  background: var(--ej-white) !important;
  box-shadow: 0 16px 32px rgba(16, 16, 16, .08);
  transition: transform .35s cubic-bezier(.19, 1, .22, 1), box-shadow .35s cubic-bezier(.19, 1, .22, 1);
}

.service-card > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 0 !important;
  padding: 0 !important;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 46px rgba(16, 16, 16, .12);
}

.service-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / .78;
  height: auto;
  min-height: 190px;
  object-fit: cover;
}

.service-copy {
  display: block !important;
  padding: 22px !important;
  background: transparent !important;
}

.service-copy > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
}

.works-head {
  display: flex !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: 24px !important;
  background: transparent !important;
}

.works-head > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: 0 !important;
}

.works-heading-box {
  display: grid !important;
  gap: 10px !important;
  background: transparent !important;
}

.btn-link .elementor-button {
  padding-inline: 0 !important;
  background: transparent !important;
  color: var(--ej-teal-deep) !important;
}

.projects-grid {
  display: block !important;
  background: transparent !important;
}

.projects-grid > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
  padding: 0 !important;
}

.project-card {
  display: block !important;
  min-width: 0;
  background: transparent !important;
}

.project-card > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 11px !important;
  padding: 0 !important;
}

.project-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / .72;
  height: auto;
  min-height: 160px;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 14px 30px rgba(16, 16, 16, .09);
  transition: transform .35s cubic-bezier(.19, 1, .22, 1), box-shadow .35s cubic-bezier(.19, 1, .22, 1);
}

.project-card:hover .project-photo img {
  transform: translateY(-4px);
  box-shadow: 0 22px 46px rgba(16, 16, 16, .12);
}

.project-card .elementor-heading-title {
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
}

.commercial {
  display: grid !important;
  grid-template-columns: minmax(320px, .88fr) minmax(0, 1.12fr) !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 0 !important;
  background: #f6f3ee !important;
}

.commercial > .e-con-inner {
  display: contents !important;
}

.commercial-copy {
  display: grid !important;
  align-content: center !important;
  gap: 22px !important;
  padding: clamp(44px, 7vw, 82px) clamp(28px, 6vw, 72px) !important;
  background: transparent !important;
}

.commercial-copy > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  align-content: center !important;
  gap: 22px !important;
  padding: 0 !important;
}

.commercial-copy .section-copy {
  max-width: 620px;
  color: var(--ej-muted);
  line-height: 2;
}

.commercial-points {
  display: block !important;
  margin-block: 8px !important;
  background: transparent !important;
}

.commercial-points > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  padding: 0 !important;
}

.commercial-point .elementor-heading-title {
  display: grid;
  justify-items: center;
  gap: 9px;
  color: var(--ej-muted);
  font-family: var(--ej-body-font);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}

.commercial-point .elementor-heading-title::before {
  content: "";
  width: 26px;
  height: 26px;
  border: 1.5px solid var(--ej-teal-deep);
  border-radius: 7px;
}

.commercial-photo {
  position: relative !important;
  min-height: 430px !important;
  background-position: center !important;
  background-size: cover !important;
}

.commercial-photo::after,
.bottom-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent, rgba(16, 16, 16, .1));
  pointer-events: none;
}

.process {
  display: block !important;
  background: transparent !important;
}

.process > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(42px, 7vw, 86px) !important;
  align-items: start !important;
  padding: 0 !important;
}

.process-column {
  display: block !important;
  min-width: 0;
  background: transparent !important;
}

.process-column > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: clamp(30px, 4vw, 46px) !important;
  padding: 0 !important;
}

.process-step {
  position: relative;
  display: block !important;
  min-width: 0;
  background: transparent !important;
}

.process-step > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 68px minmax(0, 1fr) !important;
  column-gap: 24px !important;
  align-items: start !important;
  padding: 0 !important;
}

.process-step::after {
  content: "";
  position: absolute;
  inset-block-start: 61px;
  inset-inline-start: 34px;
  width: 1px;
  height: calc(100% - 22px);
  background: var(--ej-border);
}

.process-column .process-step:last-child::after {
  display: none;
}

.step-marker {
  display: block !important;
  background: transparent !important;
}

.step-marker > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: center !important;
  gap: 8px !important;
  padding: 0 !important;
}

.step-icon .elementor-icon {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  color: var(--ej-teal-deep);
  border: 1px solid var(--ej-border);
  border-radius: 999px;
  background: var(--ej-white);
}

.step-arrow {
  width: 1px !important;
  min-height: 18px;
}

.step-arrow .elementor-spacer-inner {
  width: 1px;
  min-height: 18px;
  background: var(--ej-border);
}

.process-column .process-step:last-child .step-arrow {
  opacity: 0;
}

.step-copy,
.step-titleline {
  background: transparent !important;
}

.step-titleline {
  display: block !important;
}

.step-copy > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
}

.step-titleline > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 0 !important;
}

.step-titleline .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--ej-body);
  font-size: clamp(16px, 1.7vw, 19px);
  font-weight: 700;
  letter-spacing: .08em;
  white-space: nowrap;
}

.step-line {
  flex: 1 1 auto !important;
  min-width: 24px;
}

.step-line .elementor-spacer-inner {
  background: var(--ej-border);
}

.step-small .elementor-heading-title {
  color: color-mix(in srgb, var(--ej-muted), transparent 72%) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(22px, 2.8vw, 31px) !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  letter-spacing: .02em !important;
  white-space: nowrap !important;
}

.process-step .elementor-widget-text-editor {
  font-size: clamp(14px, 1.45vw, 16px);
  letter-spacing: .08em;
  line-height: 1.9;
}

.testimonials-wrap {
  display: block !important;
  background: transparent !important;
}

.testimonials-wrap > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 36px minmax(0, 1fr) 36px !important;
  align-items: center !important;
  gap: 20px !important;
  padding: 0 !important;
}

.testimonials {
  display: block !important;
  background: transparent !important;
}

.testimonials > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  padding: 0 !important;
}

.testimonial {
  display: block !important;
  padding: 26px !important;
  border: 1px solid var(--ej-border);
  border-radius: 8px;
  background: var(--ej-white) !important;
  box-shadow: 0 16px 34px rgba(16, 16, 16, .08);
}

.testimonial > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 22px !important;
  padding: 0 !important;
}

.testimonial .elementor-widget-text-editor {
  margin: 0;
  color: var(--ej-muted);
  font-size: 14px;
  line-height: 1.85;
}

.client {
  display: block !important;
  background: transparent !important;
}

.client > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 0 !important;
}

.avatar {
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 42%, rgba(50, 199, 188, .28), transparent 36%),
    #e8f3f1;
}

.avatar .elementor-spacer-inner {
  height: 42px !important;
}

.client-copy > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 2px !important;
  padding: 0 !important;
}

.client-title .elementor-heading-title {
  color: var(--ej-ink-2);
  font-family: var(--ej-body-font);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .05em;
}

.stars .elementor-heading-title {
  color: var(--ej-teal-deep);
  font-family: var(--ej-body-font);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
}

.arrow .elementor-button {
  width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  border: 1px solid var(--ej-border);
  border-radius: 999px !important;
  background: var(--ej-white) !important;
  color: var(--ej-body) !important;
  font-size: 24px;
  line-height: 1;
}

.bottom-cta {
  position: relative;
  overflow: hidden;
  min-height: 230px !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
  text-align: center;
  color: var(--ej-white);
  background: url("https://ejdesign.com.tw/wp-content/uploads/2026/07/ej-cta-material-gpt-image-2.webp") center / cover no-repeat !important;
}

.bottom-cta::before {
  z-index: 0;
  background: linear-gradient(180deg, rgba(16, 16, 16, .74), rgba(16, 16, 16, .86));
}

.bottom-cta > .e-con-inner {
  position: relative;
  z-index: 1;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  display: grid !important;
  justify-items: center !important;
  gap: 16px !important;
  padding: 0 !important;
}

.bottom-cta .container {
  width: 100% !important;
}

.bottom-cta .container > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: center !important;
  gap: 16px !important;
  padding: 0 !important;
}

.bottom-cta .elementor-heading-title {
  color: var(--ej-white);
  font-family: var(--ej-display);
  font-size: clamp(30px, 4.5vw, 48px);
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: .04em;
}

.bottom-cta .elementor-widget-text-editor {
  color: rgba(255, 255, 255, .82);
}

.elementor-location-footer .footer {
  display: block !important;
  width: 100% !important;
  background: var(--ej-ink) !important;
  color: rgba(255, 255, 255, .76);
  padding: 42px var(--ej-pad) 0 !important;
}

.elementor-location-footer .footer > .e-con-inner {
  width: min(100%, var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  display: grid !important;
  gap: 34px !important;
  padding: 0 !important;
}

.footer-grid {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  flex: 0 0 100% !important;
  align-self: stretch !important;
  background: transparent !important;
}

.footer-grid > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 1.3fr .72fr .72fr 1fr !important;
  gap: 42px !important;
  align-items: start !important;
  padding: 0 !important;
}

.footer-brand,
.footer-col,
.footer-contact-col,
.line-box,
.copyright {
  display: block !important;
  min-width: 0 !important;
  background: transparent !important;
}

.footer-brand > .e-con-inner,
.footer-col > .e-con-inner,
.footer-contact-col > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 12px !important;
  padding: 0 !important;
}

.footer-brand > .e-con-inner {
  gap: 16px !important;
}

.footer-logo img {
  width: 192px !important;
  max-width: 192px !important;
  height: auto;
}

.elementor-location-footer .footer p,
.elementor-location-footer .footer .elementor-widget-text-editor {
  margin: 0;
  color: rgba(255, 255, 255, .68);
  font-size: 14px;
  line-height: 1.85;
}

.elementor-location-footer .footer h3,
.elementor-location-footer .footer .footer-col .elementor-heading-title {
  color: var(--ej-white);
  font-family: var(--ej-body-font);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .12em;
}

.footer-links,
.footer-contact {
  font-size: 14px !important;
  line-height: 1.9 !important;
}

.elementor-location-footer .footer .footer-links.elementor-widget-text-editor {
  display: grid !important;
  gap: 8px !important;
}

.elementor-location-footer .footer .footer-links .elementor-widget-container {
  display: contents !important;
}

.elementor-location-footer .footer .footer-links br {
  display: none !important;
}

.elementor-location-footer .footer .footer-links a {
  display: block !important;
}

.footer-contact .elementor-widget-container {
  display: block;
}

.elementor-location-footer .footer .footer-contact.elementor-widget-text-editor {
  display: block !important;
  gap: 0 !important;
  line-height: 1.9 !important;
}

.elementor-location-footer .footer .footer-contact .elementor-widget-container {
  display: block !important;
}

.elementor-location-footer .footer .footer-contact a {
  display: inline !important;
}

.elementor-location-footer .footer .footer-contact br {
  display: inline !important;
}

.footer-links p,
.footer-contact p {
  margin: 0 !important;
}

.footer-links p:empty,
.footer-contact p:empty {
  display: none !important;
}

.elementor-location-footer .footer a {
  color: rgba(255, 255, 255, .72);
  text-decoration: none;
}

.elementor-location-footer .footer a:hover {
  color: var(--ej-teal);
}

.line-box {
  display: block !important;
  margin-top: 14px;
  padding: 13px !important;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 8px;
}

.line-box > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 44px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 0 !important;
}

.qr {
  width: 44px !important;
  height: 44px !important;
  background:
    linear-gradient(90deg, var(--ej-white) 2px, transparent 2px) 0 0 / 9px 9px,
    linear-gradient(var(--ej-white) 2px, transparent 2px) 0 0 / 9px 9px,
    rgba(255, 255, 255, .08);
}

.qr .elementor-spacer-inner {
  height: 44px !important;
}

.copyright {
  width: 100% !important;
  max-width: none !important;
  flex: 0 0 100% !important;
  align-self: stretch !important;
  border-top: 1px solid rgba(255, 255, 255, .1);
  padding: 18px 0 !important;
}

.copyright > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: 0 !important;
}

.copyright .elementor-heading-title {
  color: rgba(255, 255, 255, .56);
  font-family: var(--ej-body-font);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .04em;
}

.section-soft {
  background: linear-gradient(180deg, var(--ej-white), var(--ej-soft)) !important;
}

.section-title .elementor-heading-title,
.section-title {
  color: var(--ej-ink-2);
  font-family: var(--ej-display);
  font-size: clamp(30px, 4.2vw, 48px);
  font-weight: 500;
  line-height: 1.18;
}

.eyebrow,
.hero-kicker {
  margin-block-end: 8px;
}

.btn .elementor-button {
  min-height: 52px;
  padding: 14px 24px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .12em;
}

.btn-teal .elementor-button {
  background: var(--ej-teal);
  color: var(--ej-white);
}

.btn-outline .elementor-button {
  border: 1px solid rgba(255, 255, 255, .46);
  background: transparent;
  color: var(--ej-white);
}

.philosophy-grid,
.designer,
.licenses,
.attitude-row,
.contact-layout,
.service-intro,
.blog-layout {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(28px, 5vw, 72px) !important;
  align-items: center;
}

.designer-copy,
.licenses {
  padding: clamp(28px, 5vw, 58px) !important;
  border: 1px solid var(--ej-border);
  background: var(--ej-white) !important;
}

.elementor-widget-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.bottom-cta {
  min-height: 360px;
  display: grid !important;
  place-items: center;
  text-align: center;
  color: var(--ej-white);
}

.bottom-cta .elementor-heading-title {
  color: var(--ej-white);
  font-family: var(--ej-display);
  font-size: clamp(30px, 4vw, 54px);
}

.elementor-widget-form {
  padding: clamp(24px, 4vw, 44px);
  border: 1px solid var(--ej-border);
  background: var(--ej-white);
  box-shadow: 0 24px 80px rgba(16, 16, 16, .08);
}

.elementor-widget-form .elementor-field {
  border-color: var(--ej-border);
  border-radius: 0;
}

.elementor-widget-form .elementor-button {
  background: var(--ej-teal);
  color: var(--ej-white);
  border-radius: 999px;
}

@media (max-width: 900px) {
  .elementor-location-header .elementor-nav-menu {
    gap: 16px;
  }

  .philosophy-grid,
  .designer,
  .licenses,
  .attitude-row,
  .contact-layout,
  .service-intro,
  .blog-layout {
    grid-template-columns: 1fr;
  }

  .intro > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .intro-media {
    padding-right: 26px !important;
    padding-bottom: 32px !important;
  }

  .advantages > .e-con-inner,
  .services-grid > .e-con-inner,
  .projects-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .advantage:nth-child(2n),
  .advantage:last-child {
    border-inline-end: 0;
  }

  .advantage:nth-child(n + 3) {
    border-block-start: 1px solid var(--ej-border);
  }

  .commercial {
    grid-template-columns: 1fr !important;
  }

  .commercial-photo {
    min-height: 340px !important;
  }

  .process > .e-con-inner {
    grid-template-columns: 1fr !important;
    gap: 34px !important;
  }

  .process-step > .e-con-inner {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    column-gap: 18px !important;
  }

  .process-step::after {
    inset-inline-start: 29px;
  }

  .testimonials-wrap > .e-con-inner {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .testimonials-wrap .arrow {
    display: none !important;
  }

  .testimonials > .e-con-inner,
  .footer-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .footer-grid > .e-con-inner {
    gap: 30px !important;
  }
}

@media (max-width: 640px) {
  .home-hero,
  .about-hero,
  .service-hero,
  .portfolio-hero,
  .case-hero,
  .contact-hero,
  .blog-hero {
    min-height: 520px;
    padding-block: 112px 58px !important;
  }

  .hero-copy h1,
  .blog-hero-copy h1,
  .hero-copy .elementor-heading-title.elementor-size-default {
    font-size: clamp(34px, 10vw, 46px);
  }

  .advantages > .e-con-inner,
  .services-grid > .e-con-inner,
  .projects-grid > .e-con-inner,
  .commercial-points > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .advantage {
    border-inline-end: 0;
    border-block-start: 1px solid var(--ej-border);
  }

  .advantage:first-child {
    border-block-start: 0;
  }

  .commercial-points .elementor-heading-title {
    grid-template-columns: 28px 1fr;
    justify-items: start;
    text-align: start;
  }

  .commercial-point .elementor-heading-title {
    grid-template-columns: 28px 1fr;
    align-items: center;
    justify-items: start;
    text-align: start;
  }

  .process-column > .e-con-inner {
    gap: 30px !important;
  }

  .process-step > .e-con-inner {
    grid-template-columns: 50px minmax(0, 1fr) !important;
    column-gap: 16px !important;
  }

  .process-step::after {
    inset-block-start: 54px;
    inset-inline-start: 25px;
  }

  .step-icon .elementor-icon {
    width: 50px;
    height: 50px;
  }

  .step-titleline > .e-con-inner {
    flex-wrap: wrap !important;
  }

  .step-titleline .elementor-widget-heading:first-child .elementor-heading-title {
    white-space: normal;
  }

  .step-small .elementor-heading-title {
    font-size: 22px !important;
  }

  .testimonials > .e-con-inner,
  .footer-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .bottom-cta {
    min-height: 280px !important;
  }

  .copyright > .e-con-inner {
    flex-direction: column !important;
  }
}

.bottom-cta.home-bottom-cta {
  min-height: 230px !important;
  background-image: url("https://ejdesign.com.tw/wp-content/uploads/2026/07/ej-cta-material-gpt-image-2.webp") !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
}

body #home-bottom-cta.bottom-cta.e-con.e-parent,
body #home-bottom-cta.bottom-cta.e-con.e-parent:not(.e-lazyloaded):not(.e-no-lazyload) {
  background-image: url("https://ejdesign.com.tw/wp-content/uploads/2026/07/ej-cta-material-gpt-image-2.webp") !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
}

body #home-bottom-cta.bottom-cta.e-con.e-parent * {
  background-image: none !important;
}

body #home-bottom-cta.bottom-cta.e-con.e-parent::before {
  background-image: linear-gradient(rgba(16, 16, 16, .74), rgba(16, 16, 16, .86)) !important;
}

.bottom-cta.home-bottom-cta::before {
  background-image: linear-gradient(rgba(16, 16, 16, .74), rgba(16, 16, 16, .86)) !important;
}

@media (max-width: 640px) {
  .bottom-cta.home-bottom-cta {
    min-height: 280px !important;
  }
}

/* Cross-page conversion repair pass: restore card/grid structures flattened by the first import. */
.philosophy-grid,
.service-intro,
.contact-layout,
.case-layout,
.blog-layout,
.article-layout,
.curation-grid {
  display: block !important;
  background: transparent !important;
}

.philosophy-grid > .e-con-inner,
.service-intro > .e-con-inner,
.contact-layout > .e-con-inner,
.case-layout > .e-con-inner,
.blog-layout > .e-con-inner,
.article-layout > .e-con-inner,
.curation-grid > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(32px, 5vw, 72px) !important;
  align-items: center !important;
  padding: 0 !important;
}

.article-layout > .e-con-inner {
  grid-template-columns: minmax(0, .72fr) minmax(280px, .28fr) !important;
  align-items: start !important;
}

.blog-layout > .e-con-inner {
  grid-template-columns: minmax(0, .72fr) minmax(280px, .28fr) !important;
  align-items: start !important;
}

.philosophy-copy,
.intro-panel,
.contact-intro,
.designer-copy,
.case-panel,
.article-body,
.article-sidebar,
.blog-sidebar,
.curation-copy,
.contact-intro-copy,
.method-copy {
  display: block !important;
  min-width: 0 !important;
  background: transparent !important;
}

.philosophy-copy > .e-con-inner,
.intro-panel > .e-con-inner,
.contact-intro > .e-con-inner,
.designer-copy > .e-con-inner,
.case-panel > .e-con-inner,
.article-body > .e-con-inner,
.article-sidebar > .e-con-inner,
.blog-sidebar > .e-con-inner,
.curation-copy > .e-con-inner,
.contact-intro-copy > .e-con-inner,
.method-copy > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 16px !important;
  padding: 0 !important;
}

.philosophy-icons,
.feature-row,
.values-grid,
.attitude-row,
.reasons,
.process-strip,
.service-board,
.portfolio-grid,
.photo-gallery,
.more-grid,
.post-grid,
.related-grid,
.prep-grid,
.contact-process,
.contact-methods,
.filter-bar {
  display: block !important;
  background: transparent !important;
}

.philosophy-icons > .e-con-inner,
.feature-row > .e-con-inner,
.values-grid > .e-con-inner,
.attitude-row > .e-con-inner,
.reasons > .e-con-inner,
.process-strip > .e-con-inner,
.service-board > .e-con-inner,
.portfolio-grid > .e-con-inner,
.photo-gallery > .e-con-inner,
.more-grid > .e-con-inner,
.post-grid > .e-con-inner,
.related-grid > .e-con-inner,
.prep-grid > .e-con-inner,
.contact-process > .e-con-inner,
.contact-methods > .e-con-inner,
.filter-bar > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 24px !important;
  padding: 0 !important;
}

.philosophy-icons > .e-con-inner,
.feature-row > .e-con-inner,
.values-grid > .e-con-inner,
.attitude-row > .e-con-inner,
.reasons > .e-con-inner,
.prep-grid > .e-con-inner,
.contact-process > .e-con-inner {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.feature-row > .e-con-inner,
.prep-grid > .e-con-inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.service-board > .e-con-inner,
.post-grid > .e-con-inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.portfolio-grid > .e-con-inner {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

.photo-gallery > .e-con-inner {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.more-grid > .e-con-inner,
.related-grid > .e-con-inner {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.related-grid > .e-con-inner {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.process-strip > .e-con-inner {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.contact-methods > .e-con-inner {
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}

.filter-bar > .e-con-inner {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.value-card,
.attitude-step,
.feature-item,
.reason,
.process-node,
.service-board-card,
.portfolio-card,
.more-card,
.post-card,
.related-card,
.prep-card,
.step,
.method-card,
.sidebar-card,
.article-faq,
.article-quote {
  display: block !important;
  min-width: 0 !important;
  border: 1px solid var(--ej-border);
  border-radius: 8px;
  background: var(--ej-white) !important;
  box-shadow: 0 16px 34px rgba(16, 16, 16, .06);
}

.value-card > .e-con-inner,
.attitude-step > .e-con-inner,
.feature-item > .e-con-inner,
.reason > .e-con-inner,
.process-node > .e-con-inner,
.service-board-card > .e-con-inner,
.portfolio-card > .e-con-inner,
.more-card > .e-con-inner,
.post-card > .e-con-inner,
.related-card > .e-con-inner,
.prep-card > .e-con-inner,
.step > .e-con-inner,
.method-card > .e-con-inner,
.sidebar-card > .e-con-inner,
.article-faq > .e-con-inner,
.article-quote > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  gap: 12px !important;
  padding: 22px !important;
}

.service-board-card > .e-con-inner {
  grid-template-columns: minmax(0, 1fr) minmax(180px, .86fr) !important;
  gap: 0 !important;
  padding: 0 !important;
  align-items: stretch !important;
}

.service-board-card .service-copy > .e-con-inner {
  padding: 26px !important;
}

.method-card > .e-con-inner {
  grid-template-columns: 44px minmax(0, 1fr) !important;
  align-items: start !important;
  padding: 18px !important;
}

.philosophy-icon {
  border: 0;
  box-shadow: none;
  background: transparent !important;
}

.philosophy-icon > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: center !important;
  gap: 8px !important;
  padding: 0 !important;
  text-align: center;
}

.value-card .elementor-icon,
.reason .elementor-icon,
.feature-item .elementor-icon,
.method-icon .elementor-icon,
.process-icon .elementor-icon,
.philosophy-icon .elementor-icon {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  color: var(--ej-teal-deep);
  border: 1px solid color-mix(in srgb, var(--ej-teal), transparent 62%);
  border-radius: 999px;
}

.attitude-step-number .elementor-heading-title,
.prep-card-number .elementor-heading-title,
.step-number .elementor-heading-title,
.service-index .elementor-heading-title,
.process-node .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--ej-teal-deep);
  font-family: var(--ej-display);
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1;
}

.service-photo img,
.project-photo img,
.photo-card img,
.more-photo img,
.post-photo img,
.related-photo img,
.case-main-image img,
.curation-photo img,
.material-photo img,
.designer-photo img,
.contact-photo img,
.article-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  border-radius: 8px;
}

.service-photo img {
  border-radius: 0 8px 8px 0;
}

.portfolio-card,
.more-card,
.related-card {
  border: 0;
  box-shadow: none;
  background: transparent !important;
}

.portfolio-card > .e-con-inner,
.more-card > .e-con-inner,
.related-card > .e-con-inner {
  padding: 0 !important;
}

.portfolio-card .elementor-heading-title,
.more-card .elementor-heading-title {
  text-align: center;
  font-size: 15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.photo-card img {
  aspect-ratio: 1 / .72;
  min-height: 170px;
}

.post-card,
.related-card,
.sidebar-card,
.article-body,
.case-panel {
  background: var(--ej-white) !important;
}

.post-card .elementor-heading-title,
.related-card .elementor-heading-title,
.sidebar-card .elementor-heading-title,
.article-body .elementor-heading-title {
  color: var(--ej-ink-2);
}

.post-meta .elementor-heading-title {
  color: var(--ej-teal-deep);
  font-family: var(--ej-body-font);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
}

.article-body {
  padding: clamp(24px, 4vw, 48px) !important;
}

.article-body > .e-con-inner {
  padding: 0 !important;
  gap: 20px !important;
}

.article-body .elementor-widget-text-editor,
.article-body p,
.section-copy,
.profile-list {
  color: var(--ej-muted);
  line-height: 1.95;
}

.cta-band {
  position: relative;
  overflow: hidden;
  min-height: 260px;
  display: grid !important;
  place-items: center !important;
  text-align: center;
  color: var(--ej-white);
  background-image: url("https://ejdesign.com.tw/wp-content/uploads/2026/07/ej-cta-material-gpt-image-2.webp") !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
}

.cta-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(16, 16, 16, .74), rgba(16, 16, 16, .86));
  z-index: 0;
}

.cta-band > .e-con-inner {
  position: relative;
  z-index: 1;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  display: grid !important;
  justify-items: center !important;
  gap: 16px !important;
  padding: 0 !important;
}

.cta-band .container > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  justify-items: center !important;
  gap: 16px !important;
  padding: 0 !important;
}

.cta-band .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 500;
  line-height: 1.18;
}

.cta-band .elementor-widget-text-editor {
  color: rgba(255, 255, 255, .82);
}

@media (max-width: 900px) {
  .philosophy-grid > .e-con-inner,
  .service-intro > .e-con-inner,
  .contact-layout > .e-con-inner,
  .case-layout > .e-con-inner,
  .blog-layout > .e-con-inner,
  .article-layout > .e-con-inner,
  .curation-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .values-grid > .e-con-inner,
  .attitude-row > .e-con-inner,
  .reasons > .e-con-inner,
  .portfolio-grid > .e-con-inner,
  .photo-gallery > .e-con-inner,
  .more-grid > .e-con-inner,
  .process-strip > .e-con-inner,
  .contact-process > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .philosophy-icons > .e-con-inner,
  .feature-row > .e-con-inner,
  .values-grid > .e-con-inner,
  .attitude-row > .e-con-inner,
  .reasons > .e-con-inner,
  .process-strip > .e-con-inner,
  .service-board > .e-con-inner,
  .portfolio-grid > .e-con-inner,
  .photo-gallery > .e-con-inner,
  .more-grid > .e-con-inner,
  .post-grid > .e-con-inner,
  .related-grid > .e-con-inner,
  .prep-grid > .e-con-inner,
  .contact-process > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .service-board-card > .e-con-inner,
  .method-card > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .cta-band {
    min-height: 280px;
  }
}

/* Targeted visual QA pass for secondary pages. Keep these later than the
   broad conversion rules so Elementor widget defaults cannot stretch cards. */
.photo-gallery > .e-con-inner {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: clamp(14px, 2vw, 22px) !important;
  align-items: stretch !important;
}

.photo-gallery .photo-card {
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  height: clamp(280px, 32vw, 390px) !important;
  min-height: 0 !important;
  max-height: 390px !important;
  overflow: hidden !important;
  border-radius: 8px !important;
  box-shadow: 0 18px 48px rgba(16, 16, 16, .10) !important;
}

.photo-gallery .photo-card:nth-child(4n + 1) {
  grid-column: span 7 !important;
}

.photo-gallery .photo-card:nth-child(4n + 2) {
  grid-column: span 5 !important;
}

.photo-gallery .photo-card:nth-child(4n + 3) {
  grid-column: span 5 !important;
}

.photo-gallery .photo-card:nth-child(4n) {
  grid-column: span 7 !important;
}

.photo-gallery .photo-card .elementor-widget-container {
  height: 100% !important;
}

.photo-gallery .photo-card img {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
}

.post-card .elementor-heading-title {
  font-family: var(--ej-display) !important;
  font-size: clamp(26px, 3vw, 38px) !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: .045em !important;
}

.blog-layout .post-grid > .e-con-inner {
  grid-template-columns: 1fr !important;
  gap: 28px !important;
}

.post-card > .e-con-inner {
  grid-template-columns: minmax(220px, .46fr) minmax(0, .54fr) !important;
  min-height: 300px !important;
  gap: 0 !important;
  padding: 0 !important;
  align-items: stretch !important;
  align-content: stretch !important;
}

.post-card .post-photo {
  grid-column: 1 !important;
  grid-row: 1 / span 4 !important;
  min-height: 300px !important;
  height: 100% !important;
}

.post-card .post-photo img {
  min-height: 300px !important;
  border-radius: 0 !important;
}

.post-card .post-meta,
.post-card .elementor-widget-heading:not(.post-meta),
.post-card .elementor-widget-text-editor,
.post-card .elementor-widget-button {
  grid-column: 2 !important;
  width: auto !important;
  max-width: none !important;
  margin-inline: clamp(26px, 3vw, 34px) !important;
}

.post-card .post-meta {
  margin-block-start: clamp(26px, 4vw, 44px) !important;
  align-self: end !important;
}

.post-card .elementor-widget-heading:not(.post-meta),
.post-card .elementor-widget-text-editor {
  margin-block: 0 !important;
}

.post-card .elementor-widget-button {
  margin-block-end: clamp(26px, 4vw, 44px) !important;
  align-self: start !important;
}

.process-strip {
  position: relative !important;
}

.process-strip > .e-con-inner {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 0 !important;
  align-items: start !important;
}

.process-strip > .e-con-inner::before {
  content: "";
  position: absolute;
  inset-inline: 8%;
  inset-block-start: 36px;
  border-block-start: 1px dashed var(--ej-pearl);
}

.process-node {
  position: relative !important;
  z-index: 1 !important;
  display: block !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.process-node > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
  gap: 10px !important;
  padding: 0 14px !important;
}

.process-node .process-icon {
  width: 72px !important;
  height: 72px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid var(--ej-pearl) !important;
  border-radius: 999px !important;
  background: var(--ej-white) !important;
  color: var(--ej-teal-deep) !important;
}

.process-node .process-icon .elementor-icon {
  width: auto !important;
  height: auto !important;
  border: 0 !important;
  color: inherit !important;
  font-size: 30px !important;
}

.process-node .elementor-widget-heading:first-child .elementor-heading-title,
.process-node [id*="process-node-num"] .elementor-heading-title {
  color: var(--ej-gold) !important;
  font-family: var(--ej-display) !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

.process-node h3.elementor-heading-title,
.process-node [id*="process-node-title"] .elementor-heading-title {
  color: var(--ej-ink-2) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
}

.process-node .elementor-widget-text-editor {
  color: var(--ej-muted) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
}

.consult-panel .elementor-widget-form {
  padding: 0 !important;
}

.consult-panel .elementor-form-fields-wrapper {
  display: flex !important;
  gap: 14px 16px !important;
}

.consult-panel .elementor-col-50 {
  width: calc(50% - 8px) !important;
}

.consult-panel .elementor-col-100 {
  width: 100% !important;
}

.consult-panel .elementor-field-label {
  color: var(--ej-ink-2) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  margin-bottom: 8px !important;
}

.consult-panel .elementor-field-textual,
.consult-panel select {
  min-height: 54px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 6px !important;
  background: var(--ej-white) !important;
  color: var(--ej-ink-2) !important;
  font-size: 15px !important;
  padding: 13px 16px !important;
  box-shadow: none !important;
}

.consult-panel textarea.elementor-field-textual {
  min-height: 132px !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-subgroup {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
  width: 100% !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option {
  position: relative !important;
  display: grid !important;
  align-content: center !important;
  min-height: 86px !important;
  padding: 18px 18px 18px 70px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 8px !important;
  background: var(--ej-white) !important;
  cursor: pointer !important;
  transition: border-color .2s ease, background .2s ease, transform .2s ease !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option::before {
  content: "";
  position: absolute;
  inset-inline-start: 18px;
  inset-block-start: 50%;
  width: 38px;
  height: 38px;
  transform: translateY(-50%);
  border-radius: 999px;
  background: var(--ej-teal-soft);
}

.consult-panel .elementor-field-group-project_type .elementor-field-option::after {
  content: "";
  position: absolute;
  inset-inline-start: 33px;
  inset-block-start: 50%;
  width: 8px;
  height: 8px;
  transform: translateY(-50%);
  border-radius: 999px;
  background: var(--ej-teal-deep);
  opacity: .35;
}

.consult-panel .elementor-field-group-project_type input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:has(input:checked),
.consult-panel .elementor-field-group-project_type .elementor-field-option:hover {
  border-color: var(--ej-teal) !important;
  background: color-mix(in srgb, var(--ej-teal-soft), transparent 20%) !important;
  transform: translateY(-2px);
}

.consult-panel .elementor-field-group-project_type .elementor-field-option label {
  color: var(--ej-ink-2) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.5 !important;
  cursor: pointer !important;
}

.consult-panel .elementor-button {
  min-height: 54px !important;
  border-radius: 999px !important;
  background: var(--ej-gold) !important;
  color: var(--ej-white) !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
}

@media (max-width: 900px) {
  .photo-gallery .photo-card,
  .photo-gallery .photo-card:nth-child(n) {
    grid-column: span 6 !important;
  }
}

@media (max-width: 640px) {
  .photo-gallery .photo-card,
  .photo-gallery .photo-card:nth-child(n) {
    grid-column: span 12 !important;
    height: 300px !important;
    max-height: 300px !important;
  }

  .post-card > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .post-card .post-photo,
  .post-card .post-meta,
  .post-card .elementor-widget-heading:not(.post-meta),
  .post-card .elementor-widget-text-editor,
  .post-card .elementor-widget-button {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .post-card .post-meta,
  .post-card .elementor-widget-heading:not(.post-meta),
  .post-card .elementor-widget-text-editor,
  .post-card .elementor-widget-button {
    margin-inline: 24px !important;
  }

  .post-card .post-photo,
  .post-card .post-photo img {
    min-height: 230px !important;
  }

  .process-strip > .e-con-inner {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .process-strip > .e-con-inner::before {
    display: none !important;
  }

  .process-node > .e-con-inner {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    justify-items: start !important;
    text-align: start !important;
    column-gap: 16px !important;
    row-gap: 8px !important;
    padding: 0 !important;
  }

  .process-node .process-icon {
    grid-row: span 3 !important;
  }

  .consult-panel .elementor-field-group-project_type .elementor-field-subgroup {
    grid-template-columns: 1fr !important;
  }
}

/* 1920px rail correction for converted non-home pages.
   Original desktop exports use a centered 1360px wide rail and a 1180px
   standard content rail; the first import left several Elementor wrappers
   pinned to var(--ej-pad), which only looked acceptable at 1280px. */
.about-hero,
.service-hero,
.portfolio-hero,
.case-hero,
.contact-hero,
.blog-hero {
  padding-inline: 0 !important;
  display: grid !important;
  align-items: center !important;
}

.about-hero .hero-copy,
.service-hero .hero-copy,
.portfolio-hero .hero-copy,
.case-hero .hero-copy,
.contact-hero .hero-copy,
.blog-hero .blog-hero-copy {
  width: min(620px, calc(100vw - (var(--ej-pad) * 2))) !important;
  max-width: 620px !important;
  margin-inline-start: max(var(--ej-pad), calc((100vw - var(--ej-wide)) / 2)) !important;
  margin-inline-end: 0 !important;
  justify-self: start !important;
}

.conversion-section.e-con-boxed > .e-con-inner,
.section.e-con-boxed > .e-con-inner,
.section-soft.e-con-boxed > .e-con-inner,
.portfolio-intro > .e-con-inner,
.blog-articles-layout > .e-con-inner,
.blog-next-cta > .e-con-inner,
.article-related > .e-con-inner,
.contact-prep > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
}

.container-wide,
.container-wide > .e-con-inner,
.service-intro > .e-con-inner,
.service-board > .e-con-inner,
.portfolio-grid > .e-con-inner,
.blog-toolbar > .e-con-inner,
.article-layout > .e-con-inner,
.contact-layout > .e-con-inner,
.contact-process > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
}

#portfolio-intro > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  justify-self: center !important;
}

#portfolio-intro,
#article-hero,
#portfolio-cta,
#service-cta,
#about-cta,
#article-cta,
#contact-cta {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-content: center !important;
  justify-items: center !important;
}

.conversion-section.service-board > .e-con-inner,
.conversion-section.portfolio-grid > .e-con-inner,
.conversion-section.article-layout > .e-con-inner,
.conversion-section.contact-layout > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  justify-self: center !important;
}

#about-designer {
  padding-inline: 0 !important;
}

#article-hero > .article-shell {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  justify-self: center !important;
}

.article-hero > .e-con-inner,
.article-hero .container,
.article-cta > .e-con-inner,
.article-cta .container > .e-con-inner,
.cta-band > .e-con-inner,
.cta-band .container > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
}

#portfolio-cta,
#service-cta,
#about-cta,
#article-cta,
#contact-cta {
  grid-template-columns: minmax(0, 1fr) !important;
  justify-items: center !important;
}

#portfolio-cta > .elementor-widget,
#service-cta > .elementor-widget,
#article-cta > .elementor-widget {
  width: min(760px, calc(100vw - (var(--ej-pad) * 2))) !important;
  max-width: 760px !important;
  margin-inline: auto !important;
  justify-self: center !important;
}

#portfolio-cta > .elementor-widget-text-editor,
#service-cta > .elementor-widget-text-editor,
#article-cta > .elementor-widget-text-editor {
  width: min(760px, calc(100vw - (var(--ej-pad) * 2))) !important;
  max-width: 760px !important;
}

#portfolio-cta > .elementor-widget-button,
#service-cta > .elementor-widget-button,
#article-cta > .elementor-widget-button {
  width: auto !important;
}

#about-cta > .container,
#about-cta-container,
#contact-cta > .container,
#contact-cta-container {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  justify-self: center !important;
}

@media (max-width: 900px) {
  .about-hero .hero-copy,
  .service-hero .hero-copy,
  .portfolio-hero .hero-copy,
  .case-hero .hero-copy,
  .contact-hero .hero-copy,
  .blog-hero .blog-hero-copy {
    margin-inline: var(--ej-pad) !important;
  }
}

/* Footer rail: keep the footer background full-bleed, but match the original
   editable content width instead of stretching columns across 1920px. */
.elementor-location-footer .footer-grid,
.elementor-location-footer .copyright {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  flex-basis: auto !important;
  align-self: center !important;
}

.elementor-location-footer .footer-grid > .e-con-inner,
.elementor-location-footer .copyright > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  margin-inline: 0 !important;
}

/* About / Our Philosophy: match the source HTML two-column composition.
   This section intentionally uses compact icon labels, not the large
   vertical value typography used elsewhere. */
#about-philosophy {
  padding-block: clamp(72px, 8vw, 116px) !important;
}

#about-philosophy > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  display: block !important;
  padding: 0 !important;
}

#about-philosophy-container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#about-philosophy-container > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: minmax(0, 490px) minmax(0, 598px) !important;
  gap: 92px !important;
  align-items: center !important;
  padding: 0 !important;
}

#about-philosophy .philosophy-copy > .e-con-inner {
  display: grid !important;
  gap: 18px !important;
  padding: 0 !important;
}

#about-philosophy .eyebrow .elementor-heading-title,
#about-philosophy .eyebrow {
  color: var(--ej-teal-deep) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .32em !important;
  line-height: 1.72 !important;
  text-transform: uppercase !important;
}

#about-philosophy .section-title .elementor-heading-title,
#about-philosophy .section-title {
  color: var(--ej-ink-2) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(36px, 3.8vw, 48px) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  letter-spacing: .04em !important;
}

#about-philosophy .section-copy {
  margin-top: 10px !important;
  color: var(--ej-muted) !important;
  font-size: 17px !important;
  line-height: 2.05 !important;
  letter-spacing: .04em !important;
}

#about-philosophy .philosophy-icons {
  margin-top: 32px !important;
  padding-top: 26px !important;
  border-top: 1px solid var(--ej-border) !important;
}

#about-philosophy .philosophy-icons > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  padding: 0 !important;
}

#about-philosophy .philosophy-icon {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

#about-philosophy .philosophy-icon:not(:last-child) {
  border-inline-end: 1px solid var(--ej-border) !important;
}

#about-philosophy .philosophy-icon > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  gap: 10px !important;
  padding: 0 14px !important;
  text-align: center !important;
}

#about-philosophy .philosophy-icon .elementor-icon {
  width: auto !important;
  height: auto !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: var(--ej-teal-deep) !important;
  font-size: 32px !important;
}

#about-philosophy .philosophy-icon .elementor-heading-title {
  color: var(--ej-muted) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
  letter-spacing: .04em !important;
  writing-mode: horizontal-tb !important;
  white-space: nowrap !important;
}

#about-philosophy .material-photo {
  width: 100% !important;
  height: 560px !important;
  overflow: hidden !important;
  border-radius: 4px !important;
  box-shadow: 0 24px 70px rgba(16, 16, 16, .12) !important;
}

#about-philosophy .material-photo .elementor-widget-container,
#about-philosophy .material-photo img {
  width: 100% !important;
  height: 100% !important;
}

#about-philosophy .material-photo img {
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  min-height: 0 !important;
  border-radius: 4px !important;
}

@media (max-width: 900px) {
  #about-philosophy-container > .e-con-inner {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  #about-philosophy .material-photo {
    height: auto !important;
    aspect-ratio: 1.18 / 1 !important;
  }
}

@media (max-width: 640px) {
  #about-philosophy .philosophy-icons > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px 0 !important;
  }

  #about-philosophy .philosophy-icon:nth-child(2n) {
    border-inline-end: 0 !important;
  }
}

/* Full-loop visual QA pass: align secondary pages with the supplied HTML
   baselines at 1920px and mobile without changing the Elementor v3 tree model. */
:root {
  --ej-teal-soft: #E7FAF7;
  --ej-gold: #B8985A;
  --ej-pearl: #C9B896;
}

.about-hero,
.service-hero,
.portfolio-hero,
.case-hero,
.contact-hero,
.blog-hero {
  min-height: clamp(540px, 62vh, 680px) !important;
  padding-block: 0 !important;
}

.about-hero > .e-con-inner,
.service-hero > .e-con-inner,
.portfolio-hero > .e-con-inner,
.case-hero > .e-con-inner,
.contact-hero > .e-con-inner,
.blog-hero > .e-con-inner {
  min-height: inherit !important;
  display: grid !important;
  align-items: center !important;
  padding-block: 74px 42px !important;
}

.about-hero .hero-copy,
.service-hero .hero-copy,
.portfolio-hero .hero-copy,
.case-hero .hero-copy,
.contact-hero .hero-copy,
.blog-hero .blog-hero-copy {
  margin-inline-start: 0 !important;
  width: min(620px, 100%) !important;
  max-width: 620px !important;
}

.hero-actions .elementor-button {
  border-radius: 4px !important;
}

#portfolio-grid {
  padding-block: clamp(64px, 8vw, 118px) !important;
}

#portfolio-grid-container > .e-con-inner {
  display: grid !important;
  gap: clamp(30px, 5vw, 58px) !important;
  padding: 0 !important;
}

#portfolio-grid .section-heading > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  gap: 12px !important;
  text-align: center !important;
  padding: 0 !important;
}

#portfolio-filter-bar > .e-con-inner {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  padding: 0 !important;
}

#portfolio-filter-bar .elementor-button,
#blog-filter-toolbar .elementor-button {
  min-height: 38px !important;
  padding: 8px 14px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 999px !important;
  background: var(--ej-white) !important;
  color: var(--ej-body) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

#portfolio-filter-bar .filter-button:first-of-type .elementor-button {
  border-color: var(--ej-teal) !important;
  background: var(--ej-teal-soft) !important;
  color: var(--ej-teal-deep) !important;
}

#portfolio-project-grid > .e-con-inner {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.4vw, 32px) !important;
  align-items: start !important;
}

#portfolio-project-grid .portfolio-card:nth-child(3n + 2) {
  margin-block-start: 46px !important;
}

#portfolio-project-grid .portfolio-card,
#portfolio-project-grid .portfolio-card > .e-con-inner {
  position: relative !important;
  display: grid !important;
  gap: 14px !important;
  min-width: 0 !important;
}

#portfolio-project-grid .project-photo {
  position: relative !important;
  aspect-ratio: 4 / 5 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  background: #F6F3EE !important;
  box-shadow: 0 18px 48px rgba(16, 16, 16, .08) !important;
}

#portfolio-project-grid .project-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, transparent 42%, rgba(16, 16, 16, .58));
  pointer-events: none;
}

#portfolio-project-grid .project-photo img {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  aspect-ratio: 4 / 5 !important;
  object-fit: cover !important;
  border-radius: 10px !important;
}

#portfolio-project-grid .portfolio-card .elementor-widget-heading {
  position: absolute !important;
  inset-inline: 18px !important;
  inset-block-end: 52px !important;
  z-index: 2 !important;
  width: auto !important;
}

#portfolio-project-grid .portfolio-card .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(20px, 2.2vw, 28px) !important;
  font-weight: 500 !important;
  line-height: 1.28 !important;
  text-align: left !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
}

#portfolio-project-grid .portfolio-card::after {
  content: "View Project                         案例頁 →";
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: var(--ej-muted);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
}

.photo-gallery .photo-card,
.photo-gallery .photo-card:nth-child(n) {
  height: auto !important;
  max-height: none !important;
}

.photo-gallery .photo-card:nth-child(4n + 1),
.photo-gallery .photo-card:nth-child(4n + 4) {
  height: clamp(520px, 33vw, 638px) !important;
}

.photo-gallery .photo-card:nth-child(4n + 2),
.photo-gallery .photo-card:nth-child(4n + 3) {
  height: clamp(380px, 24vw, 452px) !important;
}

.photo-gallery .photo-card img {
  min-height: 0 !important;
  height: 100% !important;
}

.more-card .more-photo img,
.related-card .related-photo img {
  aspect-ratio: 282 / 314 !important;
  min-height: 314px !important;
}

#blog-filter-toolbar {
  position: sticky !important;
  inset-block-start: 74px !important;
  z-index: 8 !important;
  min-height: 0 !important;
  padding: 0 !important;
  border-block: 1px solid var(--ej-border) !important;
  background: color-mix(in srgb, var(--ej-white), transparent 5%) !important;
  backdrop-filter: blur(18px) !important;
}

#blog-filter-toolbar > .filter-list {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
}

#blog-filter-toolbar > .filter-list > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  min-height: 72px !important;
  padding: 16px 0 !important;
}

#blog-filter-toolbar .filter-list .elementor-widget-heading {
  width: auto !important;
  flex: 0 0 auto !important;
}

#blog-filter-toolbar .filter-list .elementor-widget-heading .elementor-heading-title {
  color: var(--ej-muted) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  white-space: nowrap !important;
}

#blog-filter-toolbar .filter-button {
  width: auto !important;
  flex: 0 0 auto !important;
}

#blog-filter-toolbar .filter-button:first-of-type .elementor-button {
  border-color: var(--ej-teal) !important;
  background: var(--ej-teal-soft) !important;
  color: var(--ej-teal-deep) !important;
}

#blog-articles-layout > .e-con-inner,
#blog-layout-container {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
}

#blog-layout-container > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 958px) minmax(260px, 330px) !important;
  gap: clamp(34px, 6vw, 72px) !important;
  align-items: start !important;
  padding: 0 !important;
}

#blog-post-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 22px !important;
  padding: 0 !important;
}

#blog-post-grid .post-card > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(320px, 440px) minmax(0, 1fr) !important;
  column-gap: 26px !important;
  row-gap: 10px !important;
  align-items: center !important;
  min-height: 345px !important;
  padding: 0 !important;
}

#blog-post-grid .post-photo {
  grid-row: 1 / span 4 !important;
  height: 343px !important;
  min-height: 0 !important;
}

#blog-post-grid .post-photo img {
  height: 100% !important;
  min-height: 0 !important;
  border-radius: 8px 0 0 8px !important;
}

#blog-post-grid .post-meta,
#blog-post-grid .post-card .elementor-widget-heading:not(.post-meta),
#blog-post-grid .post-card .elementor-widget-text-editor,
#blog-post-grid .post-card .elementor-widget-button {
  margin-inline: 0 24px !important;
}

#article-layout {
  padding-block: clamp(56px, 8vw, 104px) !important;
}

#article-layout-container,
#article-layout-container > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
}

#article-layout-container > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 958px) minmax(260px, 330px) !important;
  gap: clamp(34px, 6vw, 72px) !important;
  align-items: start !important;
  padding: 0 !important;
}

#article-body {
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

#article-body > .e-con-inner {
  gap: 20px !important;
  padding: 0 !important;
}

#article-body .elementor-widget-heading .elementor-heading-title {
  color: var(--ej-ink-2) !important;
  font-family: var(--ej-display) !important;
  font-weight: 500 !important;
  letter-spacing: .04em !important;
}

#article-body .article-longform-text,
#article-body .elementor-widget-text-editor {
  color: var(--ej-body) !important;
  font-size: 17px !important;
  line-height: 2.08 !important;
  letter-spacing: .04em !important;
}

#article-related > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
}

#contact-layout-container > .e-con-inner {
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr) !important;
  gap: clamp(34px, 5vw, 72px) !important;
  align-items: start !important;
}

.consult-panel {
  align-self: start !important;
}

.consult-panel .elementor-widget-form,
.consult-panel.elementor-widget-form {
  padding: clamp(24px, 3vw, 38px) !important;
}

.consult-panel .elementor-form-fields-wrapper {
  gap: 12px 16px !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option {
  min-height: 72px !important;
  padding-block: 14px !important;
}

@media (max-width: 900px) {
  .about-hero,
  .service-hero,
  .portfolio-hero,
  .case-hero,
  .contact-hero,
  .blog-hero {
    min-height: clamp(520px, 70svh, 670px) !important;
  }

  .about-hero > .e-con-inner,
  .service-hero > .e-con-inner,
  .portfolio-hero > .e-con-inner,
  .case-hero > .e-con-inner,
  .contact-hero > .e-con-inner,
  .blog-hero > .e-con-inner {
    padding-block: 82px 44px !important;
  }

  #portfolio-project-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #portfolio-project-grid .portfolio-card:nth-child(3n + 2) {
    margin-block-start: 0 !important;
  }

  #portfolio-project-grid .portfolio-card:nth-child(even) {
    margin-block-start: 40px !important;
  }

  #blog-layout-container > .e-con-inner,
  #article-layout-container > .e-con-inner,
  #contact-layout-container > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  #blog-filter-toolbar {
    position: relative !important;
    inset-block-start: auto !important;
  }

  #blog-filter-toolbar > .filter-list > .e-con-inner {
    display: grid !important;
    justify-items: start !important;
    min-height: 0 !important;
    gap: 12px !important;
  }
}

@media (max-width: 640px) {
  #portfolio-project-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  #portfolio-project-grid .portfolio-card:nth-child(n) {
    margin-block-start: 0 !important;
  }

  #portfolio-project-grid .project-photo,
  #portfolio-project-grid .project-photo img {
    aspect-ratio: 350 / 387 !important;
  }

  #portfolio-project-grid .portfolio-card .elementor-widget-heading {
    inset-block-end: 48px !important;
  }

  .photo-gallery .photo-card:nth-child(n) {
    height: 250px !important;
  }

  .photo-gallery .photo-card:nth-child(2),
  .photo-gallery .photo-card:nth-child(6) {
    height: 467px !important;
  }

  .more-card .more-photo img,
  .related-card .related-photo img {
    aspect-ratio: 350 / 382 !important;
    min-height: 382px !important;
  }

  #blog-filter-toolbar > .filter-list {
    width: min(calc(100vw - (var(--ej-pad) * 2)), 350px) !important;
  }

  #blog-filter-toolbar > .filter-list > .e-con-inner {
    padding-block: 16px !important;
  }

  #blog-filter-toolbar .filter-button {
    display: inline-block !important;
  }

  #blog-post-grid .post-card > .e-con-inner {
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
  }

  #blog-post-grid .post-photo {
    grid-row: auto !important;
    height: 230px !important;
  }

  #blog-post-grid .post-meta,
  #blog-post-grid .post-card .elementor-widget-heading:not(.post-meta),
  #blog-post-grid .post-card .elementor-widget-text-editor,
  #blog-post-grid .post-card .elementor-widget-button {
    margin-inline: 24px !important;
  }

  .consult-panel .elementor-col-50 {
    width: 100% !important;
  }

  #home-hero #hero-copy,
  #home-hero .hero-copy {
    margin: 0 !important;
    margin-inline: 0 !important;
  }

  #home-hero > #hero-content #hero-copy {
    margin: 0 !important;
    margin-inline: 0 !important;
  }

  .contact-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(4) .elementor-button,
  #contact-hero .hero-copy .elementor-widget-button .elementor-button {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

/* Full-loop second pass: restore missing About license band and tighten
   remaining rails reported by subagents. */
#about-designer {
  display: grid !important;
  grid-template-columns: minmax(0, 43%) minmax(0, 57%) !important;
  gap: 0 !important;
  min-height: 660px !important;
  padding: 0 !important;
  align-items: stretch !important;
}

#about-designer > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  display: contents !important;
  padding: 0 !important;
}

#about-designer .designer-photo,
#about-designer .designer-photo .elementor-widget-container,
#about-designer .designer-photo img {
  width: 100% !important;
  height: 660px !important;
  min-height: 660px !important;
  border-radius: 0 !important;
}

#about-designer .designer-copy {
  width: min(720px, calc(100% - 112px)) !important;
  align-self: stretch !important;
  justify-self: start !important;
  display: grid !important;
  align-content: center !important;
  padding: clamp(56px, 7vw, 92px) 56px !important;
  border: 0 !important;
  box-shadow: none !important;
}

#about-licenses {
  padding-block: clamp(64px, 8vw, 118px) !important;
}

#about-licenses > .e-con-inner,
#about-licenses-container,
#about-licenses-container > .e-con-inner {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-content)) !important;
  max-width: var(--ej-content) !important;
  margin-inline: auto !important;
  padding: 0 !important;
}

#about-licenses-container > .e-con-inner {
  display: grid !important;
  gap: clamp(30px, 5vw, 58px) !important;
}

#about-licenses .section-heading > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
  gap: 12px !important;
  padding: 0 !important;
}

#about-licenses-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(22px, 4vw, 42px) !important;
  padding: 0 !important;
}

#about-licenses .license-card {
  position: relative !important;
  min-height: 160px !important;
  display: grid !important;
  justify-items: center !important;
  align-content: center !important;
  padding: 34px 28px 28px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 0 !important;
  background: var(--ej-white) !important;
  box-shadow: 0 14px 34px rgba(16, 16, 16, .08) !important;
  text-align: center !important;
  overflow: hidden !important;
}

#about-licenses .license-card::before,
#about-licenses .license-card::after {
  content: "";
  position: absolute;
  width: 34px;
  aspect-ratio: 1;
  border-color: var(--ej-pearl);
  opacity: .82;
}

#about-licenses .license-card::before {
  inset-block-start: 12px;
  inset-inline-start: 12px;
  border-block-start: 1px solid;
  border-inline-start: 1px solid;
}

#about-licenses .license-card::after {
  inset-block-end: 12px;
  inset-inline-end: 12px;
  border-block-end: 1px solid;
  border-inline-end: 1px solid;
}

#about-licenses .license-card > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  gap: 6px !important;
  padding: 0 !important;
}

#about-licenses .license-card .elementor-widget-text-editor {
  margin: 0 !important;
  color: var(--ej-body) !important;
  line-height: 1.9 !important;
  letter-spacing: .08em !important;
}

#about-licenses .license-card .elementor-heading-title {
  color: var(--ej-ink-2) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(20px, 2.2vw, 28px) !important;
  font-weight: 500 !important;
  letter-spacing: .08em !important;
}

#service-process > .e-con-inner,
#service-process .container-wide,
#service-process .process-strip {
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
}

#service-process {
  padding-inline: 0 !important;
}

#service-process .process-strip > .e-con-inner {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

#service-process .process-node {
  display: grid !important;
  text-align: center !important;
}

#service-process .process-node > .e-con-inner {
  display: grid !important;
  justify-items: center !important;
  gap: 10px !important;
}

.article-actions {
  margin-block-start: clamp(32px, 5vw, 56px) !important;
  padding-block-start: clamp(24px, 4vw, 40px) !important;
  border-block-start: 1px solid var(--ej-border) !important;
}

.article-actions > .e-con-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 0 !important;
}

@media (max-width: 900px) {
  #about-designer {
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
  }

  #about-designer .designer-photo,
  #about-designer .designer-photo .elementor-widget-container,
  #about-designer .designer-photo img {
    height: 310px !important;
    min-height: 310px !important;
  }

  #about-designer .designer-copy {
    width: 100% !important;
    padding: 44px var(--ej-pad) 58px !important;
  }

  #about-licenses-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  #service-process .process-strip > .e-con-inner {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  #service-process .process-node > .e-con-inner {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    justify-items: start !important;
    text-align: start !important;
    column-gap: 16px !important;
    row-gap: 8px !important;
  }

  #blog-filter-toolbar > .filter-list > .e-con-inner {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    padding-block: 16px !important;
  }

  #blog-filter-toolbar .filter-list .elementor-widget-heading {
    flex: 0 0 100% !important;
  }

  #blog-filter-toolbar .filter-button {
    flex: 0 0 auto !important;
    width: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    display: inline-flex !important;
  }

.article-actions > .e-con-inner {
    display: grid !important;
    justify-items: start !important;
  }
}

/* Hero rail regression fix.
   Secondary heroes are e-con-full in Elementor, so their copy containers are
   direct children rather than centered inside .e-con-inner. Keep them on the
   same 1360px rail as the header at 1920px. */
.about-hero > .hero-copy,
.service-hero > .hero-copy,
.portfolio-hero > .hero-copy,
.case-hero > .hero-copy,
.contact-hero > .hero-copy,
.blog-hero > .blog-hero-copy {
  margin-inline-start: max(var(--ej-pad), calc((100vw - var(--ej-wide)) / 2)) !important;
  margin-inline-end: 0 !important;
  align-self: center !important;
  justify-self: start !important;
  transform: translateY(13px) !important;
}

.about-hero .hero-copy > .e-con-inner,
.service-hero .hero-copy > .e-con-inner,
.portfolio-hero .hero-copy > .e-con-inner,
.case-hero .hero-copy > .e-con-inner,
.contact-hero .hero-copy > .e-con-inner,
.blog-hero .blog-hero-copy > .e-con-inner {
  display: grid !important;
  grid-template-columns: auto auto !important;
  justify-items: start !important;
  justify-content: start !important;
  column-gap: 14px !important;
  row-gap: 18px !important;
  padding: 0 !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button),
.service-hero .hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button),
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button),
.case-hero .hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button),
.contact-hero .hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button),
.blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget:not(.elementor-widget-button) {
  grid-column: 1 / -1 !important;
}

.about-hero .hero-copy h1,
.service-hero .hero-copy h1,
.portfolio-hero .hero-copy h1,
.case-hero .hero-copy h1,
.contact-hero .hero-copy h1,
.blog-hero .blog-hero-copy h1,
.about-hero .hero-copy .elementor-heading-title.elementor-size-default,
.service-hero .hero-copy .elementor-heading-title.elementor-size-default,
.portfolio-hero .hero-copy .elementor-heading-title.elementor-size-default,
.case-hero .hero-copy .elementor-heading-title.elementor-size-default,
.contact-hero .hero-copy .elementor-heading-title.elementor-size-default,
.blog-hero .blog-hero-copy .elementor-heading-title.elementor-size-default {
  font-size: clamp(42px, 3.23vw, 62px) !important;
  line-height: 1.16 !important;
}

.about-hero .hero-copy .elementor-widget-text-editor,
.service-hero .hero-copy .elementor-widget-text-editor,
.portfolio-hero .hero-copy .elementor-widget-text-editor,
.case-hero .hero-copy .elementor-widget-text-editor,
.contact-hero .hero-copy .elementor-widget-text-editor,
.blog-hero .blog-hero-copy .elementor-widget-text-editor {
  max-width: 500px !important;
  font-size: 17px !important;
  line-height: 1.95 !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.service-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget-button {
  width: auto !important;
  max-width: max-content !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  justify-self: start !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.service-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget-button .elementor-button {
  width: auto !important;
  min-width: 142px !important;
  min-height: 54px !important;
}

.about-hero .hero-kicker .elementor-heading-title,
.service-hero .hero-kicker .elementor-heading-title,
.portfolio-hero .hero-kicker .elementor-heading-title,
.case-hero .hero-kicker .elementor-heading-title,
.contact-hero .hero-kicker .elementor-heading-title,
.blog-hero .hero-kicker .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1.72 !important;
  letter-spacing: .12em !important;
  text-transform: none !important;
}

.about-hero .hero-kicker,
.service-hero .hero-kicker,
.portfolio-hero .hero-kicker,
.case-hero .hero-kicker,
.contact-hero .hero-kicker,
.blog-hero .hero-kicker {
  padding-inline-start: 24px !important;
  border-inline-start: 3px solid var(--ej-teal) !important;
  margin-block-end: 0 !important;
}

.about-hero .hero-copy .hero-kicker .elementor-heading-title.elementor-size-default,
.service-hero .hero-copy .hero-kicker .elementor-heading-title.elementor-size-default,
.portfolio-hero .hero-copy .hero-kicker .elementor-heading-title.elementor-size-default,
.case-hero .hero-copy .hero-kicker .elementor-heading-title.elementor-size-default,
.contact-hero .hero-copy .hero-kicker .elementor-heading-title.elementor-size-default,
.blog-hero .blog-hero-copy .hero-kicker .elementor-heading-title.elementor-size-default {
  color: var(--ej-white) !important;
  font-family: var(--ej-body-font) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  line-height: 1.72 !important;
  letter-spacing: .12em !important;
  text-transform: none !important;
}

.about-hero .hero-copy .hero-kicker,
.service-hero .hero-copy .hero-kicker,
.portfolio-hero .hero-copy .hero-kicker,
.case-hero .hero-copy .hero-kicker,
.contact-hero .hero-copy .hero-kicker,
.blog-hero .blog-hero-copy .hero-kicker {
  width: auto !important;
  max-width: max-content !important;
  min-height: 36px !important;
  display: inline-grid !important;
  align-items: center !important;
}

/* 1920px hero fidelity pass.
   Keep Elementor's containers/widgets, but force the same boxes measured from
   the local HTML reference so wide viewports do not drift. */
#home-hero > #hero-content {
  height: 798px !important;
  min-height: 798px !important;
  display: block !important;
  align-self: center !important;
}

#home-hero > #hero-content > .e-con-inner,
#home-hero #hero-copy {
  display: grid !important;
  align-content: start !important;
  justify-content: start !important;
  justify-items: start !important;
}

#home-hero #hero-copy,
#home-hero .hero-copy {
  width: 560px !important;
  max-width: 560px !important;
  gap: 22px !important;
}

#home-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
#home-hero .hero-copy h1 {
  font-size: 88px !important;
  line-height: 1.12 !important;
  font-weight: 500 !important;
  letter-spacing: .04em !important;
}

#home-hero .hero-copy .elementor-widget-text-editor,
#home-hero .hero-copy p {
  width: 430px !important;
  max-width: 430px !important;
  font-size: 20px !important;
  line-height: 1.9 !important;
}

#home-hero .hero-actions {
  width: 560px !important;
  max-width: 560px !important;
  height: 48px !important;
  margin: 22px 0 0 !important;
  padding: 0 !important;
  gap: 16px !important;
  display: flex !important;
  align-items: stretch !important;
}

#home-hero .hero-actions > .elementor-widget-button {
  width: 135px !important;
  max-width: 135px !important;
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  flex: 0 0 135px !important;
}

#home-hero .hero-actions .elementor-button {
  width: 135px !important;
  min-width: 135px !important;
  height: 48px !important;
  min-height: 48px !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 24.08px !important;
  justify-content: center !important;
  align-items: center !important;
}

.about-hero .hero-copy > .e-con-inner,
.case-hero .hero-copy > .e-con-inner {
  display: flex !important;
  flex-flow: row wrap !important;
  align-content: start !important;
  align-items: flex-start !important;
  column-gap: 14px !important;
  row-gap: 18px !important;
}

.service-hero .hero-copy > .e-con-inner,
.contact-hero .hero-copy > .e-con-inner {
  display: flex !important;
  flex-flow: row wrap !important;
  align-content: start !important;
  align-items: flex-start !important;
  column-gap: 16px !important;
  row-gap: 18px !important;
}

.portfolio-hero .hero-copy > .e-con-inner {
  display: flex !important;
  flex-flow: row wrap !important;
  align-content: start !important;
  align-items: flex-start !important;
  column-gap: 16px !important;
  row-gap: 18px !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
.service-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
.blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker) {
  width: 620px !important;
  max-width: 620px !important;
  flex: 0 0 100% !important;
}

.about-hero .hero-copy > .e-con-inner > .hero-kicker,
.service-hero .hero-copy > .e-con-inner > .hero-kicker,
.case-hero .hero-copy > .e-con-inner > .hero-kicker,
.contact-hero .hero-copy > .e-con-inner > .hero-kicker,
.portfolio-hero .hero-copy > .e-con-inner > .hero-kicker,
.blog-hero .blog-hero-copy > .e-con-inner > .hero-kicker,
.about-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor,
.service-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor,
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor,
.blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget-text-editor {
  flex: 0 0 100% !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.service-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-button,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button {
  flex: 0 0 auto !important;
}

.about-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.service-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
.contact-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button {
  width: 142px !important;
  min-width: 142px !important;
  min-height: 54px !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 27.52px !important;
}

.contact-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(4) .elementor-button {
  width: 149px !important;
  min-width: 149px !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button {
  min-width: 142px !important;
  width: 142px !important;
  min-height: 54px !important;
  height: 54px !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 27.52px !important;
}

/* Contact form fidelity.
   The converted Elementor tree has the right-side panel carrying duplicated
   intro nodes before the Form widget. Hide those nodes and restyle the
   remaining heading/form to match the local HTML contact panel. */
#contact-layout-container {
  display: grid !important;
  grid-template-columns: 551px 731px !important;
  column-gap: 78px !important;
  align-items: start !important;
  width: 1360px !important;
  max-width: 1360px !important;
  padding: 118px 0 0 !important;
}

#contact-layout-container > .e-con-inner {
  display: contents !important;
}

#contact-intro {
  width: 551px !important;
  max-width: 551px !important;
  padding: 0 !important;
  display: grid !important;
  gap: 26px !important;
}

#contact-photo,
#contact-photo img {
  width: 551px !important;
  height: 520px !important;
  object-fit: cover !important;
  border-radius: 10px !important;
}

.consult-panel {
  width: 731px !important;
  max-width: 731px !important;
  min-height: 0 !important;
  align-self: start !important;
  padding: 0 !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 10px !important;
  background: var(--ej-white) !important;
  box-shadow: 0 28px 70px rgba(44, 38, 29, .10) !important;
  overflow: hidden !important;
}

.consult-panel > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  display: block !important;
}

.consult-panel > .e-con-inner > :nth-child(-n+4) {
  display: none !important;
}

.consult-panel > .e-con-inner > :nth-child(5) {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 73px 42px 107px !important;
  border-bottom: 1px solid var(--ej-border) !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--ej-teal-soft), transparent 18%), var(--ej-white) 64%),
    var(--ej-white) !important;
}

.consult-panel > .e-con-inner > :nth-child(5)::before {
  content: "PROJECT BRIEF";
  position: absolute;
  left: 42px;
  top: 42px;
  color: var(--ej-muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 20.64px;
  letter-spacing: .12em;
}

.consult-panel > .e-con-inner > :nth-child(5)::after {
  content: "此表單為前端需求整理介面，不會自動送出資料；填寫後可複製摘要，再透過 Line 傳送給易介團隊。";
  position: absolute;
  left: 42px;
  top: 146px;
  width: 645px;
  max-width: calc(100% - 84px);
  color: var(--ej-muted);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.72;
  letter-spacing: .04em;
}

.consult-panel > .e-con-inner > :nth-child(5) .elementor-heading-title {
  color: var(--ej-ink-2) !important;
  font-family: var(--ej-display) !important;
  font-size: 42px !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  letter-spacing: .04em !important;
}

.consult-panel .elementor-widget-form,
.consult-panel.elementor-widget-form {
  width: 100% !important;
  margin: 0 !important;
  padding: 42px !important;
  border: 0 !important;
  background: transparent !important;
}

.consult-panel .elementor-form {
  width: 100% !important;
}

.consult-panel .elementor-form-fields-wrapper {
  display: flex !important;
  gap: 18px !important;
  margin: 0 !important;
  width: 100% !important;
}

.consult-panel .elementor-field-group {
  padding: 0 !important;
  margin: 0 !important;
}

.consult-panel .elementor-col-50 {
  width: calc(50% - 9px) !important;
}

.consult-panel .elementor-field-group-project_type {
  width: 100% !important;
}

.consult-panel .elementor-field-group-project_type > .elementor-field-label {
  display: none !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-subgroup {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
  width: 100% !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 44px minmax(0, 1fr) !important;
  align-items: center !important;
  min-height: 116px !important;
  padding: 16px 16px 16px 72px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 10px !important;
  background: var(--ej-white) !important;
  color: var(--ej-ink-2) !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option input[type="radio"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-height: 1px !important;
  padding: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option::before {
  width: 44px !important;
  height: 44px !important;
  inset-inline-start: 16px !important;
  background: var(--ej-soft) !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option::after {
  width: 18px !important;
  height: 18px !important;
  inset-inline-start: 29px !important;
  background: transparent !important;
  border: 2px solid var(--ej-teal-deep) !important;
  border-radius: 4px !important;
  opacity: 1 !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:has(input:checked),
.consult-panel .elementor-field-group-project_type .elementor-field-option:hover {
  border-color: var(--ej-teal) !important;
  background: color-mix(in srgb, var(--ej-teal-soft), transparent 24%) !important;
  transform: none !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option label {
  display: block !important;
  grid-column: 2 !important;
  width: 100% !important;
  color: var(--ej-ink-2) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.5 !important;
  letter-spacing: .04em !important;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option label::after {
  display: block;
  margin-top: 5px;
  color: var(--ej-muted);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: .02em;
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:nth-child(1) label::after {
  content: "豪宅、新成屋、小坪數或生活機能重整。";
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:nth-child(2) label::after {
  content: "格局、管線、收納與材質重新整合。";
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:nth-child(3) label::after {
  content: "提前規劃格局、機能、管線與材質方向。";
}

.consult-panel .elementor-field-group-project_type .elementor-field-option:nth-child(4) label::after {
  content: "診所、餐飲、咖啡廳、旗艦店或辦公空間。";
}

.consult-panel .elementor-field-label {
  color: var(--ej-ink-2) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 22px !important;
  letter-spacing: .10em !important;
  margin-bottom: 8px !important;
}

.consult-panel .elementor-field-textual,
.consult-panel select {
  min-height: 48px !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 6px !important;
  background: var(--ej-soft) !important;
  color: var(--ej-ink-2) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
  padding: 12px 14px !important;
}

.consult-panel textarea.elementor-field-textual {
  min-height: 132px !important;
}

.consult-panel .e-form__buttons .elementor-button {
  width: auto !important;
  min-width: 142px !important;
  min-height: 54px !important;
  border-radius: 4px !important;
  background: var(--ej-ink-2) !important;
  padding: 12px 22px !important;
}

.consult-panel .elementor-field-type-submit,
.consult-panel .e-form__buttons {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
}

.consult-panel .e-form__buttons .elementor-button,
.consult-panel .e-form__buttons .elementor-button[type="submit"] {
  flex: 0 0 auto !important;
  width: 142px !important;
  max-width: 142px !important;
  height: 54px !important;
  max-height: 54px !important;
}

/* Mobile loop pass 1.
   Desktop fidelity rules above intentionally lock exact 1920px dimensions.
   Reset those locks on phone viewports so the Elementor conversion follows the
   local HTML mobile composition instead of clipping at desktop widths. */
@media (max-width: 900px) {
  #ej-site-header {
    padding: 14px var(--ej-pad) !important;
  }

  #ej-site-header > .e-con-inner {
    width: 100% !important;
    max-width: none !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 44px !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 0 !important;
  }

  #ej-site-header .elementor-widget-image {
    grid-column: 1 !important;
    justify-self: start !important;
    width: auto !important;
    max-width: 190px !important;
  }

  #ej-site-header .elementor-widget-nav-menu {
    grid-column: 2 !important;
    justify-self: end !important;
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
  }

  #ej-site-header .elementor-nav-menu--main,
  #ej-site-header .elementor-widget-button {
    display: none !important;
  }

  #ej-site-header .elementor-menu-toggle {
    display: grid !important;
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    place-items: center !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown {
    position: fixed !important;
    inset-block-start: 74px !important;
    inset-inline: var(--ej-pad) !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: calc(100vw - (var(--ej-pad) * 2)) !important;
    margin: 0 !important;
    padding: 14px !important;
    background: #ffffff !important;
    border: 1px solid var(--ej-border) !important;
    border-radius: 10px !important;
    box-shadow: 0 24px 60px rgba(23, 31, 37, .12) !important;
    z-index: 9998 !important;
  }

  #ej-site-header .elementor-menu-toggle.elementor-active + .elementor-nav-menu--dropdown,
  #ej-site-header .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu--dropdown {
    display: block !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown .elementor-nav-menu {
    display: grid !important;
    width: 100% !important;
    gap: 0 !important;
    justify-content: stretch !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown .menu-item,
  #ej-site-header .elementor-nav-menu--dropdown .elementor-item {
    width: 100% !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown .elementor-item {
    display: flex !important;
    justify-content: flex-start !important;
    min-height: 0 !important;
    padding: 13px 4px !important;
    border-bottom: 1px solid var(--ej-border) !important;
    color: var(--ej-ink) !important;
    background: transparent !important;
    font-size: 16px !important;
    line-height: 1.72 !important;
    font-weight: 500 !important;
    letter-spacing: .16em !important;
    white-space: nowrap !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown .menu-item:last-child .elementor-item {
    border-bottom: 0 !important;
  }

  #ej-site-header .elementor-nav-menu--dropdown .elementor-item::after {
    display: none !important;
  }

  #home-hero,
  .about-hero,
  .service-hero,
  .portfolio-hero,
  .case-hero,
  .contact-hero,
  .blog-hero {
    overflow: clip !important;
  }

  #home-hero > #hero-content {
    left: var(--ej-pad) !important;
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 120px 0 58px !important;
    align-self: start !important;
  }

  #home-hero #hero-copy,
  #home-hero .hero-copy,
  #home-hero .hero-actions {
    margin-inline: 0 !important;
  }

  #home-hero #hero-copy,
  #home-hero .hero-copy,
  .about-hero > .hero-copy,
  .service-hero > .hero-copy,
  .portfolio-hero > .hero-copy,
  .case-hero > .hero-copy,
  .contact-hero > .hero-copy,
  .blog-hero > .blog-hero-copy {
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    max-width: none !important;
    margin-inline: var(--ej-pad) !important;
    transform: none !important;
  }

  #home-hero {
    min-height: 720px !important;
    height: 720px !important;
  }

  .about-hero {
    min-height: 611px !important;
    height: 611px !important;
  }

  .service-hero {
    min-height: 696px !important;
    height: 696px !important;
  }

  .portfolio-hero {
    min-height: 544px !important;
    height: 544px !important;
  }

  .blog-hero {
    min-height: 500px !important;
    height: 500px !important;
  }

  .contact-hero {
    min-height: 650px !important;
    height: 650px !important;
  }

  .about-hero > .hero-copy,
  .service-hero > .hero-copy,
  .portfolio-hero > .hero-copy,
  .case-hero > .hero-copy,
  .contact-hero > .hero-copy,
  .blog-hero > .blog-hero-copy {
    transform: translateY(18px) !important;
  }

  #home-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  #home-hero .hero-copy h1 {
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(48px, 14vw, 56px) !important;
    line-height: 1.12 !important;
  }

  .about-hero .hero-copy h1,
  .service-hero .hero-copy h1,
  .portfolio-hero .hero-copy h1,
  .case-hero .hero-copy h1,
  .contact-hero .hero-copy h1,
  .blog-hero .blog-hero-copy h1,
  .about-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .service-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .contact-hero .hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .blog-hero .blog-hero-copy > .e-con-inner > .elementor-widget-heading:not(.hero-kicker),
  .about-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .service-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .portfolio-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .case-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .contact-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .blog-hero .blog-hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: 100% !important;
    font-size: clamp(34px, 10vw, 39px) !important;
    line-height: 1.16 !important;
  }

  #home-hero .hero-copy .elementor-widget-text-editor,
  #home-hero .hero-copy p,
  .about-hero .hero-copy .elementor-widget-text-editor,
  .service-hero .hero-copy .elementor-widget-text-editor,
  .portfolio-hero .hero-copy .elementor-widget-text-editor,
  .case-hero .hero-copy .elementor-widget-text-editor,
  .contact-hero .hero-copy .elementor-widget-text-editor,
  .blog-hero .blog-hero-copy .elementor-widget-text-editor {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 15px !important;
    line-height: 1.95 !important;
  }

  #home-hero .hero-copy .elementor-widget-text-editor,
  #home-hero .hero-copy p {
    font-size: 16px !important;
    line-height: 1.9 !important;
  }

  #home-hero .hero-actions {
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    max-width: calc(100vw - (var(--ej-pad) * 2)) !important;
    height: auto !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    justify-items: start !important;
    gap: 16px !important;
  }

  #home-hero .hero-actions > .elementor-widget-button {
    width: 135px !important;
    max-width: 135px !important;
    height: 48px !important;
    flex: none !important;
  }

  .about-hero .hero-copy > .e-con-inner,
  .service-hero .hero-copy > .e-con-inner,
  .portfolio-hero .hero-copy > .e-con-inner,
  .case-hero .hero-copy > .e-con-inner,
  .contact-hero .hero-copy > .e-con-inner,
  .blog-hero .blog-hero-copy > .e-con-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  .about-hero .hero-copy > .e-con-inner > .elementor-widget-button,
  .service-hero .hero-copy > .e-con-inner > .elementor-widget-button,
  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button,
  .case-hero .hero-copy > .e-con-inner > .elementor-widget-button,
  .contact-hero .hero-copy > .e-con-inner > .elementor-widget-button {
    width: 100% !important;
    max-width: 100% !important;
  }

  .about-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
  .service-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
  .case-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
  .contact-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .about-hero .elementor-widget-button .elementor-button,
  .service-hero .elementor-widget-button .elementor-button,
  .portfolio-hero .elementor-widget-button .elementor-button,
  .case-hero .elementor-widget-button .elementor-button,
  .contact-hero .elementor-widget-button .elementor-button {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #contact-layout-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    max-width: none !important;
    padding: 56px 0 0 !important;
    margin-inline: auto !important;
    gap: 26px !important;
  }

  #contact-layout-container > .e-con-inner {
    display: contents !important;
  }

  #contact-intro,
  #contact-photo,
  #contact-photo img,
  .consult-panel {
    width: 100% !important;
    max-width: 100% !important;
  }

  #contact-photo,
  #contact-photo img {
    height: 520px !important;
  }

  .consult-panel > .e-con-inner > :nth-child(5) {
    padding: 66px 24px 128px !important;
  }

  .consult-panel > .e-con-inner > :nth-child(5)::before {
    left: 24px;
    top: 28px;
  }

  .consult-panel > .e-con-inner > :nth-child(5)::after {
    left: 24px;
    top: 128px;
    width: calc(100% - 48px);
    max-width: calc(100% - 48px);
    font-size: 14px;
    line-height: 1.8;
  }

  .consult-panel > .e-con-inner > :nth-child(5) .elementor-heading-title {
    font-size: 34px !important;
    line-height: 1.25 !important;
  }

  .consult-panel .elementor-widget-form,
  .consult-panel.elementor-widget-form {
    padding: 24px !important;
  }

  .consult-panel .elementor-form-fields-wrapper {
    gap: 18px !important;
  }

  .consult-panel .elementor-field-group-project_type .elementor-field-subgroup {
    grid-template-columns: 1fr !important;
  }

  .consult-panel .elementor-col-50 {
    width: 100% !important;
  }

  .conversion-section,
  .section-soft,
  .bottom-cta,
  .cta-band,
  .photo-gallery,
  .more-works,
  #portfolio-gallery,
  #portfolio-more,
  #service-cta,
  #portfolio-cta,
  #article-cta,
  #consultation {
    scroll-margin-top: 96px !important;
  }

  #portfolio-filter-bar,
  #blog-filter-toolbar {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  #portfolio-filter-bar > .e-con-inner,
  #blog-filter-toolbar > .e-con-inner,
  #portfolio-filter-bar .filter-list,
  #blog-filter-toolbar .filter-list,
  #portfolio-filter-bar .filter-list > .e-con-inner,
  #blog-filter-toolbar .filter-list > .e-con-inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    width: max-content !important;
    max-width: none !important;
  }

  #portfolio-filter-bar .elementor-button,
  #blog-filter-toolbar .elementor-button {
    white-space: nowrap !important;
  }

  #blog-filter-toolbar {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding: 24px var(--ej-pad) 28px !important;
  }

  #blog-filter-toolbar > .e-con-inner,
  #blog-filter-toolbar .filter-list,
  #blog-filter-toolbar .filter-list > .e-con-inner {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 350px !important;
    margin-inline: auto !important;
  }

  #blog-filter-toolbar .elementor-widget-heading {
    width: 100% !important;
    flex: 0 0 100% !important;
  }

  #blog-filter-toolbar .elementor-widget-heading .elementor-heading-title {
    font-size: 12px !important;
    line-height: 1.5 !important;
    letter-spacing: .12em !important;
  }

  #blog-filter-toolbar .filter-button {
    width: auto !important;
    flex: 0 0 auto !important;
  }

  .consult-panel .elementor-field-group {
    width: 100% !important;
    max-width: 100% !important;
    padding-inline: 0 !important;
  }

  .consult-panel .elementor-field,
  .consult-panel .elementor-select-wrapper,
  .consult-panel textarea {
    width: 100% !important;
    max-width: 100% !important;
  }

  .consult-panel .elementor-field-type-radio .elementor-field-subgroup,
  .consult-panel .elementor-field-type-checkbox .elementor-field-subgroup {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    width: 100% !important;
  }

  .consult-panel .elementor-field-type-radio .elementor-field-option,
  .consult-panel .elementor-field-type-checkbox .elementor-field-option {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* 2026-07-03 CPT portfolio final repair.
   The CPT rebuild uses the original portfolio/detail class structure inside
   Elementor containers. Keep these overrides last so older conversion rules do
   not hide hero-inner or flatten the detail grids. */
.portfolio-hero .hero-inner,
.case-hero .hero-inner {
  display: grid !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  padding-block: clamp(120px, 13vh, 154px) clamp(86px, 10vh, 118px) !important;
  position: relative !important;
  z-index: 2 !important;
  background: transparent !important;
}

.portfolio-hero .hero-inner > .e-con-inner,
.case-hero .hero-inner > .e-con-inner {
  display: contents !important;
}

.portfolio-hero .hero-copy,
.case-hero .hero-copy {
  display: grid !important;
  gap: 18px !important;
  width: min(660px, 100%) !important;
  max-width: 660px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--ej-white) !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  background: transparent !important;
}

.portfolio-hero > .hero-copy {
  width: min(660px, calc(100vw - (var(--ej-pad) * 2))) !important;
  max-width: 660px !important;
  margin-inline-start: max(var(--ej-pad), calc((100vw - var(--ej-wide)) / 2)) !important;
  margin-inline-end: auto !important;
  justify-self: start !important;
  align-self: center !important;
}

.portfolio-hero .hero-copy > .e-con-inner,
.case-hero .hero-copy > .e-con-inner {
  display: grid !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

.portfolio-hero .hero-kicker,
.case-hero .hero-kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 18px !important;
  margin: 0 0 16px !important;
}

.portfolio-hero .hero-kicker::before,
.case-hero .hero-kicker::before {
  content: "" !important;
  display: block !important;
  width: 4px !important;
  height: 62px !important;
  background: var(--ej-teal) !important;
}

.portfolio-hero .hero-kicker .elementor-heading-title,
.case-hero .hero-kicker .elementor-heading-title {
  color: var(--ej-white) !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  letter-spacing: .18em !important;
}

.portfolio-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
.case-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title {
  margin: 0 !important;
  color: var(--ej-white) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(42px, 6vw, 76px) !important;
  font-weight: 500 !important;
  line-height: 1.08 !important;
  letter-spacing: .05em !important;
  text-align: left !important;
  white-space: normal !important;
  overflow: visible !important;
}

.portfolio-hero .hero-copy .elementor-widget-text-editor,
.case-hero .hero-copy .elementor-widget-text-editor {
  width: min(560px, 100%) !important;
  max-width: 560px !important;
  margin: 0 !important;
  color: rgba(255, 255, 255, .84) !important;
  font-size: 18px !important;
  line-height: 2 !important;
  letter-spacing: .06em !important;
}

.portfolio-hero .hero-actions > .e-con-inner,
.case-hero .hero-actions > .e-con-inner,
.portfolio-hero .hero-actions,
.case-hero .hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  margin-block-start: 12px !important;
}

.portfolio-hero .hero-actions .elementor-button,
.case-hero .hero-actions .elementor-button {
  min-width: 230px !important;
  min-height: 58px !important;
  padding: 16px 28px !important;
  border-radius: 999px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

#portfolio-project-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.4vw, 32px) !important;
  align-items: start !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

#portfolio-project-grid .project-card,
#portfolio-project-grid .project-card > .e-con-inner {
  position: relative !important;
  display: grid !important;
  gap: 14px !important;
  min-width: 0 !important;
  background: transparent !important;
}

#portfolio-project-grid .project-card:nth-child(3n + 2) {
  margin-block-start: 46px !important;
}

#portfolio-project-grid .project-media {
  position: relative !important;
  aspect-ratio: 4 / 5 !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  background: #f6f3ee !important;
  box-shadow: 0 18px 48px rgba(16, 16, 16, .08) !important;
}

#portfolio-project-grid .project-media::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background: linear-gradient(180deg, transparent 42%, rgba(16, 16, 16, .58)) !important;
  pointer-events: none !important;
}

#portfolio-project-grid .project-media .elementor-widget-image,
#portfolio-project-grid .project-media .elementor-widget-image .elementor-widget-container,
#portfolio-project-grid .project-media .elementor-widget-image a,
#portfolio-project-grid .project-media .elementor-widget-image img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

#portfolio-project-grid .project-media img {
  aspect-ratio: 4 / 5 !important;
  object-fit: cover !important;
  transition: transform .8s var(--ej-ease), filter .8s var(--ej-ease) !important;
}

#portfolio-project-grid .project-card:hover .project-media img {
  transform: scale(1.035) !important;
  filter: saturate(1.03) contrast(1.02) !important;
}

#portfolio-project-grid .project-meta {
  position: absolute !important;
  inset: auto 18px 18px !important;
  z-index: 2 !important;
  width: auto !important;
  display: grid !important;
  gap: 4px !important;
  color: var(--ej-white) !important;
}

#portfolio-project-grid .project-meta .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(20px, 2.2vw, 28px) !important;
  font-weight: 500 !important;
  line-height: 1.28 !important;
  text-align: left !important;
}

#portfolio-project-grid .project-meta .elementor-widget-text-editor {
  color: var(--ej-teal) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

#portfolio-project-grid .project-caption,
#portfolio-project-grid .project-caption > .e-con-inner {
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  color: var(--ej-muted) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
}

.case-info-section,
.case-gallery-section,
.case-more-section {
  overflow: visible !important;
}

.case-info-section {
  padding-block: clamp(72px, 8vw, 110px) clamp(54px, 7vw, 88px) !important;
}

.case-gallery-section,
.case-more-section {
  padding-block: clamp(70px, 8vw, 108px) !important;
}

.case-info-section .case-layout > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, .62fr) minmax(280px, .38fr) !important;
  gap: clamp(28px, 5vw, 74px) !important;
  align-items: start !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  padding: 0 !important;
}

.case-main-image {
  overflow: hidden !important;
  border-radius: 10px !important;
  background: #f6f3ee !important;
  box-shadow: 0 24px 70px rgba(16, 16, 16, .1) !important;
}

.case-main-image .elementor-widget-container,
.case-main-image img {
  display: block !important;
  width: 100% !important;
}

.case-main-image img {
  aspect-ratio: 4 / 5 !important;
  height: auto !important;
  object-fit: cover !important;
}

.case-panel {
  position: sticky !important;
  inset-block-start: 112px !important;
  padding: clamp(24px, 4vw, 42px) !important;
  border: 1px solid var(--ej-border) !important;
  border-radius: 10px !important;
  background: #faf8f3 !important;
  box-shadow: none !important;
}

.case-panel > .e-con-inner {
  display: grid !important;
  gap: 16px !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

.case-panel .elementor-heading-title {
  color: var(--ej-ink) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(28px, 4vw, 46px) !important;
  font-weight: 500 !important;
  line-height: 1.22 !important;
  letter-spacing: .04em !important;
}

.case-panel .elementor-widget-text-editor {
  color: var(--ej-muted) !important;
  line-height: 2 !important;
  letter-spacing: .045em !important;
}

.case-info {
  display: grid !important;
  gap: 12px !important;
  margin-block: 12px !important;
  padding-block: 22px !important;
  border-block: 1px solid var(--ej-border) !important;
}

.case-info .elementor-widget-text-editor .elementor-widget-container {
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  color: var(--ej-muted) !important;
  font-size: 14px !important;
  letter-spacing: .08em !important;
}

.case-info b {
  color: var(--ej-ink) !important;
  font-weight: 700 !important;
}

.case-gallery-section .section-head > .e-con-inner,
.case-more-section .section-head > .e-con-inner {
  display: flex !important;
  justify-content: space-between !important;
  align-items: end !important;
  gap: 24px !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  padding: 0 0 clamp(26px, 4vw, 44px) !important;
}

.case-gallery-section .photo-gallery,
.case-gallery-section .photo-gallery > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: clamp(14px, 2vw, 22px) !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  padding: 0 !important;
  background: transparent !important;
}

.case-gallery-section .photo-card {
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  padding: 0 !important;
  min-height: 280px !important;
  border-radius: 10px !important;
  background: #f6f3ee !important;
  box-shadow: 0 18px 48px rgba(16, 16, 16, .08) !important;
}

.case-gallery-section .photo-card:nth-child(4n + 1),
.case-gallery-section .photo-card:nth-child(4n) {
  grid-column: span 7 !important;
  height: clamp(520px, 33vw, 638px) !important;
}

.case-gallery-section .photo-card:nth-child(4n + 2),
.case-gallery-section .photo-card:nth-child(4n + 3) {
  grid-column: span 5 !important;
  height: clamp(380px, 24vw, 452px) !important;
}

.case-gallery-section .photo-card .elementor-widget-container,
.case-gallery-section .photo-card img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.case-gallery-section .photo-card img {
  object-fit: cover !important;
}

.case-gallery-section .photo-card::after {
  content: attr(data-index) !important;
  position: absolute !important;
  inset: auto 18px 18px auto !important;
  display: grid !important;
  place-items: center !important;
  width: 42px !important;
  aspect-ratio: 1 !important;
  border: 1px solid rgba(255, 255, 255, .34) !important;
  border-radius: 50% !important;
  background: rgba(16, 16, 16, .34) !important;
  color: var(--ej-white) !important;
  font-size: 12px !important;
  letter-spacing: .08em !important;
  backdrop-filter: blur(10px) !important;
}

.case-more-section .more-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: min(calc(100vw - (var(--ej-pad) * 2)), var(--ej-wide)) !important;
  max-width: var(--ej-wide) !important;
  margin-inline: auto !important;
  padding: 0 !important;
}

@media (max-width: 1120px) {
  #portfolio-project-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #portfolio-project-grid .project-card:nth-child(3n + 2) {
    margin-block-start: 0 !important;
  }

  #portfolio-project-grid .project-card:nth-child(even) {
    margin-block-start: 36px !important;
  }

  .case-info-section .case-layout > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .case-panel {
    position: static !important;
  }

  .case-gallery-section .photo-card:nth-child(n) {
    grid-column: span 6 !important;
  }
}

@media (max-width: 620px) {
  .portfolio-hero .hero-inner,
  .case-hero .hero-inner {
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    padding-block: 116px 86px !important;
  }

  .portfolio-hero > .hero-copy {
    width: calc(100vw - (var(--ej-pad) * 2)) !important;
    max-width: none !important;
    margin-inline: var(--ej-pad) !important;
  }

  .portfolio-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title,
  .case-hero .hero-copy .elementor-widget-heading:not(.hero-kicker) .elementor-heading-title {
    font-size: clamp(34px, 10vw, 48px) !important;
  }

  .portfolio-hero .hero-actions,
  .case-hero .hero-actions,
  .portfolio-hero .hero-actions > .e-con-inner,
  .case-hero .hero-actions > .e-con-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }

  .portfolio-hero .hero-actions .elementor-button,
  .case-hero .hero-actions .elementor-button {
    width: 100% !important;
  }

  #portfolio-project-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  #portfolio-project-grid .project-card:nth-child(n) {
    margin-block-start: 0 !important;
  }

  .case-gallery-section .section-head > .e-con-inner,
  .case-more-section .section-head > .e-con-inner {
    display: grid !important;
    align-items: start !important;
  }

  .case-gallery-section .photo-gallery,
  .case-gallery-section .photo-gallery > .e-con-inner,
  .case-more-section .more-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .case-gallery-section .photo-card:nth-child(n) {
    grid-column: auto !important;
    height: 250px !important;
    min-height: 250px !important;
  }
}

/* CPT portfolio card typography reset: older conversion rules positioned every
   heading inside .portfolio-card absolutely. Only the meta wrapper belongs on
   top of the image; its child headings and the caption row stay in normal flow. */
#portfolio-project-grid .portfolio-card::after {
  content: none !important;
  display: none !important;
}

#portfolio-project-grid .project-media {
  padding: 0 !important;
}

#portfolio-project-grid .project-media .project-photo {
  width: 100% !important;
  height: 100% !important;
}

#portfolio-project-grid .project-media .project-photo .elementor-widget-container,
#portfolio-project-grid .project-media .project-photo a,
#portfolio-project-grid .project-media .project-photo img {
  width: 100% !important;
  height: 100% !important;
}

#portfolio-project-grid .project-meta {
  inset: auto 18px 18px !important;
  height: auto !important;
}

#portfolio-project-grid .project-meta .elementor-widget-heading,
#portfolio-project-grid .project-caption .elementor-widget-heading {
  position: static !important;
  inset: auto !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#portfolio-project-grid .project-meta .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--ej-teal) !important;
  font-family: var(--ej-body-font, inherit) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

#portfolio-project-grid .project-meta .elementor-widget-heading:last-child .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(20px, 2.2vw, 28px) !important;
  font-weight: 500 !important;
  line-height: 1.28 !important;
  letter-spacing: .04em !important;
}

#portfolio-project-grid .project-caption .elementor-heading-title {
  color: var(--ej-muted) !important;
  font-family: var(--ej-body-font, inherit) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.6 !important;
  letter-spacing: .12em !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:first-child {
  display: inline-flex !important;
  align-items: center !important;
  gap: 18px !important;
  width: auto !important;
  max-width: max-content !important;
  margin: 0 0 16px !important;
}

.case-hero .hero-copy > .e-con-inner {
  grid-template-columns: auto auto !important;
  justify-content: start !important;
  align-items: start !important;
  column-gap: 16px !important;
  row-gap: 18px !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:first-child,
.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:nth-child(2),
.case-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor {
  grid-column: 1 / -1 !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(4) {
  grid-column: 1 !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(5) {
  grid-column: 2 !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:first-child::before {
  content: "" !important;
  display: block !important;
  width: 4px !important;
  height: 62px !important;
  background: var(--ej-teal) !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-body-font, inherit) !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  letter-spacing: .18em !important;
  text-transform: none !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-heading:nth-child(2) .elementor-heading-title {
  color: var(--ej-white) !important;
  font-family: var(--ej-display) !important;
  font-size: clamp(42px, 6vw, 76px) !important;
  font-weight: 500 !important;
  line-height: 1.08 !important;
  letter-spacing: .05em !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(4) .elementor-button {
  min-width: 230px !important;
  min-height: 58px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 28px !important;
  border: 1px solid var(--ej-teal) !important;
  border-radius: 999px !important;
  background: var(--ej-teal) !important;
  box-shadow: 0 20px 38px rgba(50, 199, 188, .24) !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

.case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(5) .elementor-button {
  min-width: 230px !important;
  min-height: 58px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 28px !important;
  border: 1px solid rgba(255, 255, 255, .58) !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

@media (max-width: 620px) {
  .case-hero .hero-copy > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(4),
  .case-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-child(5) {
    grid-column: 1 !important;
  }
}

.case-hero .hero-actions,
.case-hero .hero-actions > .e-con-inner {
  grid-column: 1 / -1 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 16px !important;
  width: min(560px, 100%) !important;
  max-width: 560px !important;
}

.case-hero .hero-actions .elementor-widget-button {
  width: auto !important;
  max-width: none !important;
  flex: 0 0 auto !important;
}

.case-hero .hero-actions .elementor-widget-button:first-of-type .elementor-button {
  min-width: 230px !important;
  min-height: 58px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 28px !important;
  border: 1px solid var(--ej-teal) !important;
  border-radius: 999px !important;
  background: var(--ej-teal) !important;
  background-color: var(--ej-teal) !important;
  box-shadow: 0 20px 38px rgba(50, 199, 188, .24) !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

.case-hero .hero-actions .elementor-widget-button:last-of-type .elementor-button {
  min-width: 230px !important;
  min-height: 58px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 28px !important;
  border: 1px solid rgba(255, 255, 255, .58) !important;
  border-radius: 999px !important;
  background: transparent !important;
  background-color: transparent !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
}

@media (max-width: 620px) {
  .case-hero .hero-actions,
  .case-hero .hero-actions > .e-con-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }

  .case-hero .hero-actions .elementor-widget-button,
  .case-hero .hero-actions .elementor-button {
    width: 100% !important;
  }
}

/* Hero CTA normalization: About hero is the visual source of truth. */
.portfolio-hero .hero-actions,
.portfolio-hero .hero-actions > .e-con-inner,
.case-hero .hero-actions,
.case-hero .hero-actions > .e-con-inner {
  grid-column: 1 / -1 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  width: auto !important;
  max-width: 100% !important;
  margin-block-start: 12px !important;
}

.portfolio-hero .hero-actions .elementor-widget-button,
.case-hero .hero-actions .elementor-widget-button {
  width: auto !important;
  max-width: none !important;
  flex: 0 0 auto !important;
}

.portfolio-hero .hero-actions .elementor-widget-button .elementor-button,
.case-hero .hero-actions .elementor-widget-button .elementor-button {
  width: auto !important;
  min-width: 0 !important;
  min-height: 54px !important;
  height: 54px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  letter-spacing: 1.28px !important;
  box-shadow: none !important;
}

.portfolio-hero .hero-actions .elementor-widget-button:first-of-type .elementor-button,
.case-hero .hero-actions .elementor-widget-button:first-of-type .elementor-button {
  border: 1px solid rgba(0, 0, 0, 0) !important;
  background: var(--ej-teal) !important;
  background-color: var(--ej-teal) !important;
}

.portfolio-hero .hero-actions .elementor-widget-button:last-of-type .elementor-button,
.case-hero .hero-actions .elementor-widget-button:last-of-type .elementor-button {
  border: 1px solid rgba(255, 255, 255, .58) !important;
  background: rgba(16, 16, 16, .1) !important;
  background-color: rgba(16, 16, 16, .1) !important;
}

@media (max-width: 620px) {
  .portfolio-hero .hero-actions,
  .portfolio-hero .hero-actions > .e-con-inner,
  .case-hero .hero-actions,
  .case-hero .hero-actions > .e-con-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }

  .portfolio-hero .hero-actions .elementor-widget-button,
  .case-hero .hero-actions .elementor-widget-button,
  .portfolio-hero .hero-actions .elementor-widget-button .elementor-button,
  .case-hero .hero-actions .elementor-widget-button .elementor-button {
    width: 100% !important;
  }
}

/* Final Hero CTA standardization against About page measured styles. */
.portfolio-hero .hero-copy > .e-con-inner {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  grid-template-columns: none !important;
  justify-content: start !important;
  column-gap: 14px !important;
  row-gap: 18px !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-heading,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-text-editor {
  grid-column: auto !important;
  flex: 0 0 100% !important;
  width: 100% !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(1) {
  grid-column: auto !important;
  flex: 0 0 auto !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(2) {
  grid-column: auto !important;
  flex: 0 0 auto !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(1) .elementor-button,
.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(2) .elementor-button,
.case-hero .hero-actions .elementor-widget-button:first-of-type .elementor-button,
.case-hero .hero-actions .elementor-widget-button:last-of-type .elementor-button {
  width: 142px !important;
  min-width: 0 !important;
  max-width: 142px !important;
  min-height: 54px !important;
  height: 54px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  color: var(--ej-white) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.72 !important;
  letter-spacing: 1.28px !important;
  box-shadow: none !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(1) .elementor-button,
.case-hero .hero-actions .elementor-widget-button:first-of-type .elementor-button {
  border: 1px solid rgba(0, 0, 0, 0) !important;
  background: var(--ej-teal) !important;
  background-color: var(--ej-teal) !important;
}

.portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(2) .elementor-button,
.case-hero .hero-actions .elementor-widget-button:last-of-type .elementor-button {
  border: 1px solid rgba(255, 255, 255, .58) !important;
  background: rgba(16, 16, 16, .1) !important;
  background-color: rgba(16, 16, 16, .1) !important;
}

.case-hero .hero-actions,
.case-hero .hero-actions > .e-con-inner {
  grid-column: 1 / -1 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 14px !important;
  width: auto !important;
  max-width: 100% !important;
}

.case-hero .hero-actions .elementor-widget-button {
  width: auto !important;
  max-width: none !important;
  flex: 0 0 auto !important;
}

@media (max-width: 620px) {
  .portfolio-hero .hero-copy > .e-con-inner,
  .case-hero .hero-actions,
  .case-hero .hero-actions > .e-con-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }

  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(1),
  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button:nth-of-type(2),
  .case-hero .hero-actions .elementor-widget-button {
    grid-column: 1 !important;
    width: 100% !important;
  }

  .portfolio-hero .hero-copy > .e-con-inner > .elementor-widget-button .elementor-button,
  .case-hero .hero-actions .elementor-widget-button .elementor-button {
    width: 100% !important;
  }
}
