/** Shopify CDN: Minification failed

Line 106:13 Expected identifier but found whitespace
Line 106:14 Unexpected "linear-gradient("

**/
  .es { --font-head: "Red Hat Text", sans-serif;
  --font-heading:  "Playfair Display", serif;
  --font-head: "Red Hat Text", sans-serif;
  --gold: #D4AF37; --bg: rgba(0 0 0 / 1); --bg1: #111; --border: #1e1e1e; --muted: #888;
  font-family: var(--font-body); font-weight: 400; background: rgba(0 0 0 / 1); color: #fff;
  overflow-x: clip; }
.es * { box-sizing: border-box; }
.es a { color: inherit; text-decoration: none; }
.es img { display: block; max-width: 100%; }
.es h1, .es h2, .es h3 { font-family: var(--font-heading) !important; font-weight: 700; }
.es p, .es span, .es a { font-family: var(--font-body); }
/* uppercase ornamental labels + hero subhead use the serif */
.es-trust-item span, .es-hero-rt span, .es-btn, .es-hero-sub { font-family: var(--font-head) !important; }
.es-h1, .es-h1 span { font-family: var(--font-heading) !important; }
.es-g { background: linear-gradient(to right, #bd6400, #ffeb82, #bd6400); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* scroll reveal */
.es-reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); transition-delay: calc(var(--i, 0) * 80ms); }
.es-reveal.in { opacity: 1; transform: none; }

/* shared button */
.es-btn { display: inline-flex; align-items: center; gap: 12px; justify-content: center;
    border-color: transparent;
    background: linear-gradient(to right, #bd6400, #ffeb82, #bd6400) !important;
    color: #000 !important;
  font-family: var(--font-head); font-weight: 700;
  letter-spacing: 2.4px; text-transform: uppercase; border-radius: 6px;
  transition: transform .25s, box-shadow .25s; }
.es-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(212,175,55,.45); color: #000; }
.es-btn:active { transform: translateY(0) scale(.98); }
.es-btn svg { width: 18px; height: 18px; }
.es-btn--lg { padding: 19px 34px; font-size: 13px; }
.es-btn--sm { padding: 15px 30px; font-size: 11px; letter-spacing: 2.5px; }

/* ============================================================
   HERO — Full-width image background with text overlay
   ============================================================ */
.es-hero { position: relative; width: 100%; max-width: none; margin: 0; padding: 0;
  aspect-ratio: 16 / 9; overflow: hidden; background: rgba(0 0 0 / 1); isolation: isolate; border-bottom: 1px solid rgba(212, 175, 55, .18);}

.es-hero-bg { position: absolute; inset: 0; z-index: 0; }
.es-hero-bg img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.es-hero-scrim { position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg, rgba(8,8,8,.92) 0%, rgba(8,8,8,.78) 26%, rgba(8,8,8,.32) 50%, rgba(8,8,8,.06) 74%, rgba(8,8,8,.22) 100%),
    linear-gradient(180deg, rgba(8,8,8,0) 70%, rgba(11,11,11,.55) 100%); }

.es-hero-text { position: relative; z-index: 2; height: 100%;
  display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
  padding: 0 48px 0 max(48px, 4.5vw);
  animation: esHeroIn .8s cubic-bezier(.2,.7,.2,1) .1s backwards; }
.es-hero-text > * { max-width: 860px; }
.es-hero-actions { width: auto; }
.es-hero-actions .es-btn { flex: 0 0 auto; }

/* headline — each line kept single-line via nowrap */
.es-h1 { margin: 0 0 22px; line-height: 1.02; letter-spacing: 0;}
.es-h1-line { display: block; overflow: hidden; padding: .08em 0; }
.es-h1-line > span { display: block; white-space: nowrap; font-weight: 700;
  font-size: clamp(38px, 4.8vw, 66px); text-transform: uppercase;
  animation: esLineRise 1s cubic-bezier(.16,.84,.3,1) backwards; }
.es-h1-line:nth-child(1) > span { animation-delay: .18s; }
.es-h1-line:nth-child(2) > span { animation-delay: .30s; }
.es-h1-line:nth-child(3) > span { animation-delay: .42s; }
.es-w { color: #fff; }

.es-hero-sub { font-size: 16.5px; line-height: 1.75; color: #cdcdcd; max-width: 480px;
  margin: 0 0 26px; animation: esHeroIn .8s cubic-bezier(.2,.7,.2,1) .58s backwards; }

.es-hero-actions { display: flex; align-items: center; gap: 22px; flex-wrap: wrap;
  margin-bottom: 22px; animation: esHeroIn .8s cubic-bezier(.2,.7,.2,1) .70s backwards; }

.es-hero-rt { display: inline-flex; align-items: center; gap: 10px; margin: 0;
  font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  color: #b9b9b9; animation: esHeroIn .8s cubic-bezier(.2,.7,.2,1) .82s backwards; }
.es-hero-rt svg { width: 18px; height: 18px; color: var(--gold); }

@keyframes esHeroIn { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }
@keyframes esLineRise { from { transform: translateY(108%); } to { transform: translateY(0); } }

/* ============================================================ */

/* shared section */
.es-block { padding: 84px 56px; max-width: 1320px; margin: 0 auto; }
.es-head { text-align: center; margin-bottom: 46px; }
.es-crown { display: inline-block; color: var(--gold); margin-bottom: 12px; }
.es-crown svg { width: 30px; height: 30px; }
.es-h2 { font-size: clamp(28px, 3.6vw, 44px); letter-spacing: 2px; text-transform: uppercase; margin: 0; }
.es-h2--center { text-align: center; margin-bottom: 38px; }
.es-swipe { display: none; }

/* NEED CARDS — full-width, big, bare floating gold icons */
.es-need { max-width: none; padding: 72px max(40px, 4vw) 48px; }
.es-need-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 22px; }
.es-card { background: rgba(0 0 0 / 1); border: 1px solid rgba(212,175,55,.32);
  border-radius: 10px; padding: 46px 24px 44px; text-align: center;
  display: flex; flex-direction: column; align-items: center; min-height: 400px;
  transition: transform .3s, border-color .3s, background .3s, box-shadow .3s; }
/* .es-card:hover { transform: translateY(-6px); border-color: rgba(212,175,55,.7); */
  background: linear-gradient(165deg, rgba(212,175,55,.06), #0d0d0d);
  box-shadow: 0 26px 60px rgba(0,0,0,.45); }
section#apply { padding: 5px 30px; }
.es-card-ic { display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 28px;
  transition: transform .35s cubic-bezier(.2,.7,.2,1); }
/* .es-card:hover .es-card-ic { transform: translateY(-4px) scale(1.06); } */
.es-card-ic svg { width: 60px; height: 60px; color: var(--gold);
  filter: drop-shadow(0 8px 22px rgba(212,175,55,.42)); }
.es-card-ic img { width: 143px; height: 143px; object-fit: contain;
  filter: drop-shadow(0 12px 30px rgba(212,175,55,.34)); }
.es-card h3 { font-size: 18px; letter-spacing: 1.6px; text-transform: uppercase; color: #fff; margin: 0 0 14px; line-height: 1.25; }
.es-card p { font-size: 13.5px; line-height: 1.65; color: #9a9a9a; margin: 0; max-width: 240px; }

/* WORK GALLERY — full-bleed uniform band, vivid, no face crops */
.es-work { text-align: center; max-width: none; padding: 56px max(40px, 4vw) 72px; }
.es-gallery { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px;
  width: 100vw; margin: 0 0 36px; margin-left: calc(50% - 50vw); padding: 0 10px; }
.es-shot { position: relative; margin: 0; aspect-ratio: 9 / 16; border-radius: 12px;
  overflow: hidden; border: 1px solid rgba(212,175,55,.18); }
.es-shot::after { content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, rgba(11,11,11,.22) 0%, transparent 36%);
  opacity: .6; transition: opacity .45s; }
.es-shot img { width: 100%; height: 100%; object-fit: cover;
  object-position: center 18%;
  transition: transform .65s cubic-bezier(.2,.7,.2,1); }
.es-shot:hover { border-color: rgba(212,175,55,.6); }
.es-shot:hover::after { opacity: .2; }
.es-shot:hover img { transform: scale(1.06); }

/* WHY — full width, plain icon + text, explicit stack: icon → title → details */
.es-why { max-width: none; padding: 84px max(40px, 4vw); }
.es-why-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 30px; }
.es-why-item { display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 8px 14px 0; position: relative; }
.es-why-item + .es-why-item::before { content: ''; position: absolute; left: -15px; top: 6px;
  bottom: 6px; width: 1px; background: var(--border); }
.es-why-ic { color: var(--gold); margin: 0 0 22px; line-height: 0; }
.es-why-ic svg { width: 54px; height: 54px; filter: drop-shadow(0 8px 20px rgba(212,175,55,.4)); }
.es-why-item h3 { font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; margin: 0 0 12px;
  background: linear-gradient(to right, #bd6400, #ffeb82, #bd6400);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.es-why-item p { font-size: 13px; line-height: 1.65; color: #aaa; margin: 0; max-width: 220px; }

/* TRUSTED — full width, plain icon + label, white (matches reference) */
.es-trust { max-width: none; padding: 64px max(40px, 4vw) 110px; }
.es-trust-head { display: flex; align-items: center; gap: 30px; justify-content: center; margin-bottom: 56px; }
.es-line { flex: 1; max-width: 240px; height: 1px; background: linear-gradient(to right, transparent, rgba(255,255,255,.32), transparent); }
.es-trust-title { font-size: clamp(24px, 3vw, 38px); letter-spacing: 2px; text-transform: uppercase; margin: 0; white-space: nowrap; }
.es-trust-grid { display: grid; grid-template-columns: repeat(9, 1fr); gap: 20px; }
.es-trust-item { display: flex; flex-direction: column; align-items: center; gap: 14px;
  padding: 8px 4px; color: #e6e6e6;
  transition: transform .3s ease, color .3s ease; }
.es-trust-item:hover { color: #fff; transform: translateY(-4px); }
.es-trust-item svg { width: 46px; height: 46px; color: #fff;
  filter: drop-shadow(0 4px 14px rgba(255,255,255,.10)); transition: transform .3s ease; }
.es-trust-item img { width: 50px; height: 50px; object-fit: contain;
  filter: drop-shadow(0 4px 14px rgba(255,255,255,.18)); transition: transform .3s ease; }
.es-trust-item:hover svg,
.es-trust-item:hover img { transform: scale(1.13); }
.es-trust-item span { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; text-align: center; }

/* ===== TABLET ===== */
@media (max-width: 1024px) {
  /* Stack image on top, text below — shows full image, no crop, on small screens */
  .es-hero { aspect-ratio: auto; display: flex; flex-direction: column; }
  .es-hero-bg { position: relative; width: 100%; aspect-ratio: 16 / 9;
    border-bottom: 1px solid rgba(212,175,55,.14); }
  .es-hero-bg img { position: relative; }
  .es-hero-scrim { background: linear-gradient(180deg, rgba(8,8,8,0) 60%, rgba(11,11,11,.55) 100%); }
  .es-hero-text { height: auto; padding: 48px 32px 36px; }
  .es-hero-text > * { max-width: 100%; }
  .es-need-grid { grid-template-columns: repeat(3, 1fr); }
  .es-gallery { grid-template-columns: repeat(3, 1fr); }
  .es-shot { aspect-ratio: 9 / 15; }
  .es-why-grid { grid-template-columns: repeat(3, 1fr); gap: 38px 24px; }
  .es-why-item::before { display: none; }
  .es-trust-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
}

/* ===== MOBILE — crafted layout ===== */
@media (max-width: 680px) {
  .es-block { padding: 64px 18px; }

  /* HERO: stacked image (full) above text on phones */
  .es-hero-text { padding: 32px 22px 28px; }
  .es-h1 { margin-bottom: 18px; }
  .es-h1-line > span { font-size: clamp(28px, 8vw, 46px); }
  .es-hero-sub { font-size: 16.5px; margin-bottom: 22px; }
  .es-hero-actions { gap: 14px; margin-bottom: 18px; }
  .es-hero-actions .es-btn { width: 100%; }
  .es-hero-rt { font-size: 10px; letter-spacing: 2px; }

  /* SECTION HEADS */
  .es-h2 { font-size: 30px; }
  .es-h2--center { margin-bottom: 26px; }
  .es-head { margin-bottom: 22px; }
  .es-swipe { display: block; font-size: 10px; font-weight: 600; letter-spacing: 2px;
    text-transform: uppercase; color: var(--gold); margin: 14px 0 0; }
  .es-swipe span { display: inline-block; animation: esNudge 1.3s ease-in-out infinite; }
  @keyframes esNudge { 0%,100% { transform: translateX(0); } 50% { transform: translateX(5px); } }

  /* NEED: auto-scrolling carousel (JS-driven, seamless loop) */
  .es-need { padding: 64px 0; }
  .es-need-grid { display: flex; gap: 14px; overflow-x: auto; overflow-y: hidden;
    -webkit-overflow-scrolling: touch; padding: 4px 0 8px 18px; margin: 0;
    scrollbar-width: none; scroll-snap-type: none; }
  .es-need-grid::-webkit-scrollbar { display: none; }
  .es-card { flex: 0 0 76%; padding: 22px 24px 22px;
    min-height: 100%; }
  .es-card-ic { margin-bottom: 10px; }
  .es-card-ic svg { width: 54px; height: 54px; }
  .es-card-ic img { width: 70px; height: 70px; }
  .es-card h3 { font-size: 19px; }
  .es-card p { font-size: 14px; }

  /* GALLERY: clean 2-col band, full-bleed, equal heights */
  .es-work { padding: 56px 0; }
  .es-gallery { grid-template-columns: 1fr 1fr; gap: 8px; padding: 0 12px; margin-bottom: 28px; }
  .es-shot { aspect-ratio: 9 / 14; border-radius: 12px; }
  .es-work .es-btn { width: 100%; max-width: 80%; margin: 0 auto; }

  /* WHY: 2-col cards */
  .es-why { padding: 56px 18px; }
  .es-why-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .es-why-item { background: var(--bg1); border: 1px solid var(--border); border-radius: 10px;
    padding: 26px 16px; }
  .es-why-ic svg { width: 46px; height: 46px; }
  .es-why-item h3 { font-size: 14px; }
  .es-why-item p { font-size: 12.5px; }

  /* TRUSTED: 3x3 plain icons + labels */
  .es-trust { padding: 56px 22px 80px; }
  .es-trust-head { gap: 12px; margin-bottom: 32px; }
  .es-line { max-width: 50px; }
  .es-trust-title { font-size: 23px; }
  .es-trust-grid { grid-template-columns: repeat(3, 1fr); gap: 24px 10px; }
  .es-trust-item { padding: 0; gap: 10px; }
  .es-trust-item svg { width: 38px; height: 38px; }
}

@media (max-width: 360px) {
  .es-card { flex-basis: 82%; }
  .es-h1-line > span { font-size: 34px; }
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
  .es-reveal { opacity: 1; transform: none; transition: none; }
  .es-hero-text, .es-hero-sub, .es-hero-actions, .es-hero-rt,
  .es-h1-line > span { animation: none; }
}

@media (max-width: 680px) {

  .es-need-grid {

    display: flex;
    gap: 14px;
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 8px 18px;
    margin: 0;
    scrollbar-width: none;
    scroll-snap-type: none;
    scroll-behavior: auto;
    will-change: scroll-position;
  }

}