.elementor-kit-42{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-42 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}.site-footer{padding-inline-end:0px;padding-inline-start:0px;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* =========================================================
   AESTHETICA-LIKE PORTFOLIO GRID — CLEAN + EDITABLE
   + FULL WIDTH OPTION
   + STYLE-SAFE SELECTORS (ignores injected <style>/<span>/<div>)
   + FIXED 6-BLOCK GAP (stable with infinite scroll)
   ========================================================= */


/* =========================================================
   GLOBAL SITE PADDING — all pages except Start/Portfolio (ID=19)
   (Makes every other page look like your Legal pages)
   ========================================================= */

/* Desktop */
body:not(.page-id-19) main,
body:not(.page-id-19) .site-main,
body:not(.page-id-19) .site-content,
body:not(.page-id-19) .content-area,
body:not(.page-id-19) .entry-content,
body:not(.page-id-19) .wp-site-blocks{
  padding-left: 25px !important;
  padding-right: 25px !important;
  box-sizing: border-box;
}

/* Tablet */
@media (max-width: 1024px){
  body:not(.page-id-19) main,
  body:not(.page-id-19) .site-main,
  body:not(.page-id-19) .site-content,
  body:not(.page-id-19) .content-area,
  body:not(.page-id-19) .entry-content,
  body:not(.page-id-19) .wp-site-blocks{
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* Mobile */
@media (max-width: 767px){
  body:not(.page-id-19) main,
  body:not(.page-id-19) .site-main,
  body:not(.page-id-19) .site-content,
  body:not(.page-id-19) .content-area,
  body:not(.page-id-19) .entry-content,
  body:not(.page-id-19) .wp-site-blocks{
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

/* Safety: prevent overflow caused by global resets */
body:not(.page-id-19){
  overflow-x: hidden;
}


/* =========================================================
   0) AE GRID — EASY CONTROLS + OUTER EDGES (GRID PAGE ONLY)
   ========================================================= */

.ae-grid{
  max-width: none !important;
  width: 100% !important;
  box-sizing: border-box;

  /* Controls */
  --ae-col-gap: 25px;
  --ae-col-gap-tablet: 15px;
  --ae-col-gap-mobile: 15px;

  --ae-row-gap: 25px;
  --ae-row-gap-tablet: 14px;
  --ae-row-gap-mobile: 15px;

  /* Space BETWEEN blocks of 6 (desktop/tablet) */
  --ae-block-gap: 150px;
  --ae-block-gap-tablet: 100px;

  /* reserved space for the title line (prevents overlap) */
  --ae-title-space: 15px;

  /* Outer edges */
  padding-left: var(--ae-col-gap) !important;
  padding-right: var(--ae-col-gap) !important;
}

@media (max-width: 1024px){
  .ae-grid{
    padding-left: var(--ae-col-gap-tablet) !important;
    padding-right: var(--ae-col-gap-tablet) !important;
  }
}

@media (max-width: 767px){
  .ae-grid{
    padding-left: var(--ae-col-gap-mobile) !important;
    padding-right: var(--ae-col-gap-mobile) !important;
  }
}


/* =========================================================
   1) GRID: width + gaps + MANUAL SPANS
   ========================================================= */

.ae-grid .elementor-loop-container.elementor-grid{
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: var(--ae-row-gap) var(--ae-col-gap) !important;
  align-items: end;
}

/* Default span */
.ae-grid .elementor-loop-container .e-loop-item{
  grid-column: span 4;
}

/* ACF width classes */
.ae-grid .elementor-loop-container .e-loop-item.tile-span-2{ grid-column: span 2; }
.ae-grid .elementor-loop-container .e-loop-item.tile-span-3{ grid-column: span 3; }
.ae-grid .elementor-loop-container .e-loop-item.tile-span-4{ grid-column: span 4; }
.ae-grid .elementor-loop-container .e-loop-item.tile-span-6{ grid-column: span 6; }

/* Tablet */
@media (max-width: 1024px){
  .ae-grid .elementor-loop-container.elementor-grid{
    gap: var(--ae-row-gap-tablet) var(--ae-col-gap-tablet) !important;
  }
}

/* Mobile */
@media (max-width: 767px){
  .ae-grid .elementor-loop-container.elementor-grid{
    grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
    gap: var(--ae-row-gap-mobile) var(--ae-col-gap-mobile) !important;
    align-items: start !important;
  }
  .ae-grid .elementor-loop-container .e-loop-item{
    grid-column: 1 / -1 !important;
  }
}


/* =========================================================
   2) MID-AXIS ALIGNMENT
   1–3 bottom aligned, 4–6 top aligned
   ROBUST: counts ONLY .e-loop-item (ignores injected nodes)
   ========================================================= */

.ae-grid .elementor-loop-container > .e-loop-item{
  align-self: end;
}

/* Items 4–6, 10–12, ... */
.ae-grid .elementor-loop-container > :nth-child(6n + 4 of .e-loop-item),
.ae-grid .elementor-loop-container > :nth-child(6n + 5 of .e-loop-item),
.ae-grid .elementor-loop-container > :nth-child(6n + 6 of .e-loop-item){
  align-self: start;
}


/* =========================================================
   3) BLOCK GAP via SPACER ELEMENT (robust with uneven heights)
   ========================================================= */

/* No "Block-gap" margins on items */
.ae-grid .elementor-loop-container > .e-loop-item{
  margin: 0 !important;
}

/* Elementor Load More UI must not break the grid */
.ae-grid .elementor-loop-container > .e-load-more-spinner,
.ae-grid .elementor-loop-container > .e-load-more-anchor,
.ae-grid .elementor-loop-container > .e-load-more-message{
  grid-column: 1 / -1 !important;
}

/* Spacer element inserted by JS */
.ae-grid .elementor-loop-container > .ae-gap-spacer{
  grid-column: 1 / -1 !important;
  height: var(--ae-block-gap);   /* Desktop */
  pointer-events: none;
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1024px){
  .ae-grid .elementor-loop-container > .ae-gap-spacer{
    height: var(--ae-block-gap-tablet);
  }
}

/* Mobile */
@media (max-width: 767px){
  .ae-grid .elementor-loop-container > .ae-gap-spacer{
    height: 0;
  }
}


/* =========================================================
   4) TITLE PINNED TO IMAGE EDGE + NO OVERLAP
   ROBUST: nth-child(... of .e-loop-item)
   ========================================================= */

.ae-grid .e-loop-item .loop-tile .e-con-inner{
  position: relative;
  box-sizing: border-box;

  /* default group: title ABOVE -> reserve space on TOP */
  padding-top: calc(var(--ae-title-space) + 6px);
  padding-bottom: 0;
}

/* bottom group: items 4–6 etc. */
.ae-grid .elementor-loop-container > :nth-child(6n + 4 of .e-loop-item) .loop-tile .e-con-inner,
.ae-grid .elementor-loop-container > :nth-child(6n + 5 of .e-loop-item) .loop-tile .e-con-inner,
.ae-grid .elementor-loop-container > :nth-child(6n + 6 of .e-loop-item) .loop-tile .e-con-inner{
  padding-top: 0;
  padding-bottom: calc(var(--ae-title-space) + 6px);
}

/* Title above image (default group) */
.ae-grid .e-loop-item .ae-title{
  position: absolute !important;
  left: 0;
  right: 0;
  top: 0;
  transform: translateY(-100%) !important;
  z-index: 2;

  font-family: Inter, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: .02em;

  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
  align-items: baseline;

  margin: 0 !important;
  padding: 0 0 6px 0 !important;
  color: #000 !important;
}

/* Title below image (items 4–6 etc.) */
.ae-grid .elementor-loop-container > :nth-child(6n + 4 of .e-loop-item) .ae-title,
.ae-grid .elementor-loop-container > :nth-child(6n + 5 of .e-loop-item) .ae-title,
.ae-grid .elementor-loop-container > :nth-child(6n + 6 of .e-loop-item) .ae-title{
  top: auto !important;
  bottom: 0 !important;
  transform: translateY(100%) !important;
  padding: 6px 0 0 0 !important;
}

/* Kill Elementor heading spacing */
.ae-grid .ae-title .elementor-widget-heading{
  display: inline-flex !important;
  margin: 0 !important;
}
.ae-grid .ae-title .elementor-heading-title{
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  color: #000 !important;
}
.ae-grid .ae-title a{
  color: #000 !important;
  text-decoration: none !important;
}

/* Name bold + separator */
.ae-grid .ae-title-name .elementor-heading-title{ font-weight: 600 !important; }
.ae-grid .ae-title-name .elementor-heading-title::after{
  content: none !important;
  display: inline-block;
  padding: 0 1px;
  font-weight: 400;
}
.ae-grid .ae-title-desc .elementor-heading-title{ font-weight: 400 !important; }

/* Tablet title size */
@media (max-width: 1024px){
  .ae-grid .ae-title .elementor-heading-title{
    font-size: 11px !important;
    letter-spacing: .015em !important;
  }
}


/* =========================================================
   5) IMAGE: no distortion
   ========================================================= */

.ae-grid .e-loop-item .elementor-widget-image img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}


/* =========================================================
   6) MOBILE: title in normal flow + no reserved padding
   ========================================================= */

@media (max-width: 767px){
  .ae-grid .elementor-loop-container > .e-loop-item{
    align-self: start !important;
  }

  .ae-grid .e-loop-item .loop-tile .e-con-inner{
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .ae-grid .e-loop-item .ae-title{
    position: static !important;
    transform: none !important;
    padding: 0 !important;
    margin: 0 0 8px 0 !important;
    flex-wrap: wrap !important;
  }

  .ae-grid .elementor-loop-container > :nth-child(6n + 4 of .e-loop-item) .ae-title,
  .ae-grid .elementor-loop-container > :nth-child(6n + 5 of .e-loop-item) .ae-title,
  .ae-grid .elementor-loop-container > :nth-child(6n + 6 of .e-loop-item) .ae-title{
    position: static !important;
    transform: none !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
  }

  /* Optional: disable clicks on mobile */
  .ae-grid .ae-img a{
    pointer-events: none;
    cursor: default;
  }
}


/* =========================================================
   7) HOVER (JS-compatible: uses --tx/--ty/--s)
   ========================================================= */

.ae-grid .ae-img{
  overflow: hidden;
  position: relative;
  line-height: 0;
}

.ae-grid .ae-img a{ display:block; }

.ae-grid .ae-img img{
  display: block;
  width: 100%;
  height: auto;

  /* Defaults for JS-driven variables */
  --tx: 0px;
  --ty: 0px;
  --s: 1;

  transform: translate3d(var(--tx), var(--ty), 0) scale(var(--s));
  transform-origin: center center;

  /* JS animates scale/position itself (rAF),
     we keep only opacity transition here */
  transition: opacity .6s ease;
  will-change: transform, opacity;
}

.ae-grid .e-loop-item:hover .ae-img img{
  opacity: .92;
}

/* Mobile: no hover/zoom */
@media (max-width: 767px){
  .ae-grid .ae-img img{
    --tx: 0px !important;
    --ty: 0px !important;
    --s: 1 !important;
    transform: none !important;
    transition: none !important;
    opacity: 1 !important;
    will-change: auto;
  }
  .ae-grid .e-loop-item:hover .ae-img img{ opacity: 1 !important; }
}



/* =========================================================
   FIX: remove Elementor "boxed container" inner gutters
   ========================================================= */

.ae-grid .e-loop-item .loop-tile.e-con-boxed{ width: 100% !important; }

.ae-grid .e-loop-item .loop-tile.e-con-boxed > .e-con-inner{
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.ae-grid .e-loop-item .loop-tile{
  --container-default-padding-left: 0px !important;
  --container-default-padding-right: 0px !important;
}


/* =========================================================
   FIX: kill Elementor outer horizontal padding
   ONLY inside the grid area (so other pages stay readable)
   ========================================================= */

.ae-grid .elementor-section,
.ae-grid .elementor-container,
.ae-grid .e-con,
.ae-grid .e-con-inner,
.ae-grid .elementor-widget-wrap{
  padding-left: 0 !important;
  padding-right: 0 !important;
}


/* =========================================================
   AE LIGHTBOX — SINGLE IMAGE (STABLE)
   ========================================================= */

:root{
  /* Title pinned to viewport */
  --ae-lb-title-top: 25px;
  --ae-lb-title-left: 25px;

  /* Inner alignment (matches grid side spacing) */
  --ae-lb-inner-pad: 25px;

  /* Controls pinned to viewport bottom */
  --ae-lb-controls-bottom: 25px;

  /* Base breathing room for image area */
  --ae-lb-frame-top: 25px;
  --ae-lb-frame-bottom: 25px;

  /* Tablet base breathing room */
  --ae-lb-frame-top-tablet: 15px;
  --ae-lb-frame-bottom-tablet: 15px;

  /* Extra gaps matching edge thickness */
  --ae-lb-title-gap: var(--ae-lb-title-top);
  --ae-lb-controls-gap: var(--ae-lb-controls-bottom);

  /* Tablet: match tablet edge thickness */
  --ae-lb-title-gap-tablet: var(--ae-lb-frame-top-tablet);
  --ae-lb-controls-gap-tablet: var(--ae-lb-frame-bottom-tablet);

  --ae-lb-z: 999999;
}

/* Tablet frame */
@media (max-width: 1024px){
  .ae-lightbox__inner{
    padding:
      calc(var(--ae-lb-frame-top-tablet) + var(--ae-lb-inner-pad) + var(--ae-lb-title-gap-tablet))
      var(--ae-lb-inner-pad)
      calc(var(--ae-lb-frame-bottom-tablet) + var(--ae-lb-inner-pad) + var(--ae-lb-controls-gap-tablet));
  }
}

/* No lightbox on mobile */
@media (max-width: 767px){
  .ae-lightbox{ display:none !important; }
}/* End custom CSS */