/** Shopify CDN: Minification failed

Line 27:0 All "@import" rules must come first

**/
/* ============================================================
   LOEWEN I.T. — Custom CSS Override
   Loaded after base.css via theme.liquid injection.
   All Loewen brand styles live here.
   Never edit base.css or Trade component files directly.
   ============================================================ */

/* ── Brand tokens ─────────────────────────────────────────── */
:root {
  --loewen-navy:     #0D1B2A;
  --loewen-blue:     #1565C0;
  --loewen-steel:    #1E3A5F;
  --loewen-light:    #E8EEF4;
  --loewen-offwhite: #F5F8FC;
  --loewen-dark:     #111827;
  --loewen-mid:      #374151;
  --loewen-white:    #FFFFFF;
  --loewen-blue-hover: #1976D2;
}

/* ── Google Fonts: Inter ──────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --font-body-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-heading-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ── Global typography ────────────────────────────────────── */
body {
  letter-spacing: 0;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: var(--loewen-offwhite);
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4 {
  letter-spacing: -0.02em;
  line-height: 1.2;
  font-weight: 700;
}

p { line-height: 1.7; }

/* ── Section spacing ──────────────────────────────────────── */
.shopify-section { margin: 0; }

/* ── Header overrides ─────────────────────────────────────── */
.header-wrapper {
  background-color: var(--loewen-navy) !important;
  border-bottom: 2px solid var(--loewen-blue) !important;
}

.header {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

/* Wordmark text when no logo image is uploaded */
.header__heading-link span.h2 {
  font-family: var(--font-heading-family);
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--loewen-blue) !important;
}

/* Nav links */
.header__menu-item .link,
.list-menu__item--link {
  color: rgba(255,255,255,0.85) !important;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  text-decoration: none;
}

.header__menu-item .link:hover,
.list-menu__item--link:hover {
  color: var(--loewen-blue) !important;
  opacity: 1;
}

/* ── Dual CTA buttons in header ───────────────────────────── */
.loewen-header-ctas {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: 24px;
  flex-shrink: 0;
}

@media screen and (max-width: 989px) {
  .loewen-header-ctas { display: none; }
}

/* ── Shared button base for Loewen CTAs ───────────────────── */
.loewen-btn-primary,
.loewen-btn-secondary {
  display: inline-block;
  font-family: var(--font-heading-family);
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 11px 22px;
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  border: 2px solid transparent;
}

.loewen-btn-primary {
  background-color: var(--loewen-blue);
  color: var(--loewen-white) !important;
  border-color: var(--loewen-blue);
}

.loewen-btn-primary:hover {
  background-color: var(--loewen-blue-hover);
  border-color: var(--loewen-blue-hover);
  color: var(--loewen-white) !important;
}

/* On dark backgrounds */
.loewen-btn-secondary {
  background-color: transparent;
  color: var(--loewen-white) !important;
  border-color: rgba(255,255,255,0.6);
}

.loewen-btn-secondary:hover {
  background-color: rgba(255,255,255,0.08);
  border-color: var(--loewen-white);
  color: var(--loewen-white) !important;
}

/* On light backgrounds */
.loewen-btn-secondary--light {
  color: var(--loewen-blue) !important;
  border-color: var(--loewen-blue);
}

.loewen-btn-secondary--light:hover {
  background-color: rgba(21,101,192,0.06);
  color: var(--loewen-blue) !important;
}

/* Large CTA variant */
.loewen-btn-primary--lg,
.loewen-btn-secondary--lg {
  font-size: 1.3rem;
  padding: 15px 32px;
}

/* ── Shopify native button overrides ──────────────────────── */
.button, .button--primary {
  background-color: var(--loewen-blue) !important;
  color: var(--loewen-white) !important;
  border-radius: 0 !important;
  border: 2px solid var(--loewen-blue) !important;
  font-family: var(--font-heading-family);
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 14px 28px;
  transition: background-color 0.15s ease;
}

.button:hover, .button--primary:hover {
  background-color: var(--loewen-blue-hover) !important;
  border-color: var(--loewen-blue-hover) !important;
}

.button--secondary {
  background-color: transparent !important;
  color: var(--loewen-blue) !important;
  border: 2px solid var(--loewen-blue) !important;
  border-radius: 0 !important;
}

.button--secondary:hover {
  background-color: rgba(21,101,192,0.06) !important;
}

/* ── Loewen section label (uppercase tracked caption) ─────── */
.loewen-label {
  display: block;
  font-family: var(--font-heading-family);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--loewen-blue);
  margin-bottom: 12px;
}

.loewen-label--muted { color: rgba(255,255,255,0.55); }

/* ── Section wrappers ─────────────────────────────────────── */
.loewen-section { width: 100%; }

.loewen-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}

@media screen and (max-width: 749px) {
  .loewen-inner { padding: 0 20px; }
}

/* ── Announcement bar ─────────────────────────────────────── */
.announcement-bar {
  background-color: var(--loewen-steel) !important;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.announcement-bar__message {
  color: rgba(255,255,255,0.85) !important;
  font-size: 1.3rem;
  letter-spacing: 0.03em;
}

/* ── Hero section (image-banner) ──────────────────────────── */
.banner__box { background: transparent !important; }

.banner__heading {
  letter-spacing: -0.025em !important;
  line-height: 1.15 !important;
}

/* Caption label above hero heading */
.caption-with-letter-spacing {
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--loewen-blue) !important;
  opacity: 1 !important;
}

/* ── Fork cards section (2-up conversion fork) ────────────── */
.loewen-fork {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background-color: var(--loewen-blue);
}

@media screen and (max-width: 749px) {
  .loewen-fork { grid-template-columns: 1fr; }
}

.loewen-fork__card {
  background-color: var(--loewen-navy);
  padding: 60px 48px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: background-color 0.2s ease;
}

.loewen-fork__card:hover { background-color: #0f2236; }

@media screen and (max-width: 749px) {
  .loewen-fork__card { padding: 40px 24px; }
}

.loewen-fork__icon {
  width: 36px;
  height: 36px;
  margin-bottom: 20px;
  color: var(--loewen-blue);
  flex-shrink: 0;
}

.loewen-fork__heading {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--loewen-white);
  margin: 0 0 16px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.loewen-fork__body {
  font-size: 1.5rem;
  color: rgba(255,255,255,0.72);
  line-height: 1.65;
  margin: 0 0 32px;
  flex-grow: 1;
}

.loewen-fork__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-heading-family);
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--loewen-blue) !important;
  text-decoration: none;
  border-bottom: 1px solid rgba(21,101,192,0.35);
  padding-bottom: 2px;
  transition: border-color 0.15s ease;
}

.loewen-fork__cta:hover {
  border-color: var(--loewen-blue);
  color: var(--loewen-blue) !important;
}

.loewen-fork__cta-arrow { transition: transform 0.15s ease; }
.loewen-fork__cta:hover .loewen-fork__cta-arrow { transform: translateX(4px); }

/* ── Feature grid (4-up) ──────────────────────────────────── */
.loewen-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  padding: 72px 0;
}

@media screen and (max-width: 989px) {
  .loewen-features {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
    padding: 56px 0;
  }
}

@media screen and (max-width: 749px) {
  .loewen-features {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 48px 0;
  }
}

.loewen-feature__icon {
  width: 26px;
  height: 26px;
  color: var(--loewen-blue);
  margin-bottom: 16px;
  display: block;
}

.loewen-feature__title {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--loewen-white);
  margin: 0 0 10px;
}

.loewen-feature__body {
  font-size: 1.45rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.6;
  margin: 0;
}

/* ── Stats band ───────────────────────────────────────────── */
.loewen-stats-band {
  background-color: var(--loewen-steel);
  padding: 56px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.loewen-stats-band .loewen-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}

.loewen-stat {
  text-align: center;
  padding: 0 60px;
  flex-shrink: 0;
}

.loewen-stat + .loewen-stat {
  border-left: 1px solid rgba(255,255,255,0.15);
}

.loewen-stat__number {
  display: block;
  font-family: var(--font-heading-family);
  font-size: 3.8rem;
  font-weight: 700;
  color: var(--loewen-blue);
  letter-spacing: -0.03em;
  line-height: 1;
}

.loewen-stat__label {
  display: block;
  font-size: 1.3rem;
  color: rgba(255,255,255,0.6);
  margin-top: 10px;
  letter-spacing: 0.03em;
  line-height: 1.4;
}

@media screen and (max-width: 749px) {
  .loewen-stat { padding: 20px 0; width: 100%; }
  .loewen-stat + .loewen-stat { border-left: none; border-top: 1px solid rgba(255,255,255,0.12); }
  .loewen-stat__number { font-size: 3rem; }
}

/* ── CTA close section ────────────────────────────────────── */
.loewen-cta-close {
  background-color: var(--loewen-navy);
  padding: 80px 0;
  border-left: 4px solid var(--loewen-blue);
}

.loewen-cta-close .loewen-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 60px;
  align-items: center;
}

@media screen and (max-width: 989px) {
  .loewen-cta-close .loewen-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

.loewen-cta-close__heading {
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--loewen-white);
  margin: 0 0 16px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.loewen-cta-close__body {
  font-size: 1.55rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.65;
  margin: 0;
}

.loewen-cta-close__buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex-shrink: 0;
  min-width: 220px;
}

/* ── Multicolumn overrides ────────────────────────────────── */
.multicolumn-card { border-radius: 0; border: none; }

.multicolumn-card__info h3 {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 10px;
}

/* ── Rich text ────────────────────────────────────────────── */
.rich-text { max-width: 760px; margin: 0 auto; }
.rich-text__heading { letter-spacing: -0.025em; }

/* ── Image-with-text ──────────────────────────────────────── */
.image-with-text__content {
  padding: 48px !important;
}

@media screen and (max-width: 749px) {
  .image-with-text__content { padding: 32px 24px !important; }
}

/* ── Footer ───────────────────────────────────────────────── */
.footer {
  background-color: var(--loewen-navy) !important;
  border-top: 2px solid var(--loewen-blue);
  margin-top: 0 !important;
}

.footer__content-bottom {
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  padding-top: 20px;
}

.footer-block__heading {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--loewen-white) !important;
  margin-bottom: 16px;
}

.footer-block__details-content a,
.footer-block__details-content .link {
  color: rgba(255,255,255,0.6) !important;
  font-size: 1.4rem;
  text-decoration: none;
  transition: color 0.15s ease;
}

.footer-block__details-content a:hover,
.footer-block__details-content .link:hover {
  color: var(--loewen-white) !important;
}

.footer .rte p {
  color: rgba(255,255,255,0.6);
  font-size: 1.4rem;
  line-height: 1.65;
}

/* ── Mobile sticky CTA bar ────────────────────────────────── */
.loewen-mobile-cta-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background-color: var(--loewen-navy);
  border-top: 2px solid var(--loewen-blue);
  padding: 10px 16px;
  padding-bottom: calc(10px + env(safe-area-inset-bottom));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

@media screen and (min-width: 990px) {
  .loewen-mobile-cta-bar { display: none !important; }
}

.loewen-mobile-cta-bar a {
  text-align: center;
  font-size: 1.1rem;
  padding: 12px 6px;
}

@media screen and (max-width: 989px) {
  #MainContent { padding-bottom: 80px; }
}

/* ── Scrolled header ──────────────────────────────────────── */
.scrolled-past-header .header-wrapper {
  background-color: rgba(13, 27, 42, 0.97) !important;
  box-shadow: 0 2px 20px rgba(0,0,0,0.25);
}

/* ── Background utilities ─────────────────────────────────── */
.loewen-bg-navy     { background-color: var(--loewen-navy); }
.loewen-bg-steel    { background-color: var(--loewen-steel); }
.loewen-bg-offwhite { background-color: var(--loewen-offwhite); }
.loewen-bg-white    { background-color: var(--loewen-white); }
.loewen-bg-light    { background-color: var(--loewen-light); }

/* ── Text colour utilities ────────────────────────────────── */
.loewen-text-white { color: var(--loewen-white) !important; }
.loewen-text-blue  { color: var(--loewen-blue) !important; }
.loewen-text-mid   { color: var(--loewen-mid) !important; }
.loewen-text-muted { color: rgba(255,255,255,0.6) !important; }

/* ── Blue left-accent callout box ─────────────────────────── */
.loewen-callout {
  border-left: 4px solid var(--loewen-blue);
  padding: 24px 28px;
  background-color: var(--loewen-light);
  margin: 24px 0;
}

.loewen-callout--dark {
  background-color: rgba(255,255,255,0.05);
  border-left-color: var(--loewen-blue);
}

/* ── Focus ────────────────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--loewen-blue);
  outline-offset: 2px;
}

/* ── Horizontal rule ──────────────────────────────────────── */
hr.loewen-rule {
  border: none;
  border-top: 1px solid rgba(0,0,0,0.07);
  margin: 0;
}

hr.loewen-rule--blue { border-top: 2px solid var(--loewen-blue); }

/* Banner caption — context-specific colour overrides */
.loewen-banner-caption { color: #FFFFFF !important; }

/* On dark/navy backgrounds (default hero) */
/*.color-scheme-4 .loewen-banner-caption,
.color-scheme-5 .loewen-banner-caption { color: var(--loewen-blue); }*/

/* On light backgrounds — force dark */
/*.color-scheme-1 .loewen-banner-caption,
.color-scheme-2 .loewen-banner-caption { color: var(--loewen-blue); }*/

.banner__box .button--secondary,
.banner__box .button[aria-pressed] {
  color: #FFFFFF !important;
  border-color: #FFFFFF !important;
}
/* Hide page title only for notitle template */
.template-page-notitle .page-title,
.template-page-notitle .page__title,
.template-page-notitle h1.main-page-title,
.template-page-notitle .main-page__title {
  display: none !important;
}
/* Widen product pages with no media and ensure centering */
@media screen and (min-width: 990px) {
  .product--no-media {
    max-width: 80rem !important;
    margin: 0 auto !important; /* Ensure it stays centered */
  }
}

/* Hide media column for products using notitle template */
.template-product-notitle .product__media-wrapper,
.template-product-notitle .grid__item.product__media-wrapper {
  display: none !important;
}

/* Make the product info take full width when media is hidden */
.template-product-notitle .product__info-wrapper {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
}

/* Center the content nicely */
.template-product-notitle .product__info-container {
  max-width: 80rem !important;
  margin: 0 auto !important;
}

/* Force all parent containers to allow full width on notitle template */
.template-product-notitle .product__info-wrapper,
.template-product-notitle .product__column,
.template-product-notitle .product__info-container > * {
  width: 100% !important;
  max-width: none !important;
}

/* Then set the specific max-width we want */
.template-product-notitle .product__info-container {
  max-width: 90rem !important;
  margin: 0 auto !important;
}

.template-product-notitle .product-form {
  max-width: 52.5rem !important;
  margin: 0 auto !important;
  width: 100% !important;
}

/* Center price */
.template-product-notitle .price {
  font-size: 2.5rem !important;
  text-align: center;
}

/* Center taxes included text */
.template-product-notitle .product__tax {
  text-align: center;
  width: 100%;
}

/* Center the variant-selects wrapper */
.template-product-notitle variant-selects {
  display: flex;
  justify-content: center;
  width: 100%;
}

/* Center variant picker fieldsets and display buttons horizontally */
.template-product-notitle fieldset.js.product-form__input {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

/* Center the legend/label - make it full width so buttons go below */
.template-product-notitle .product-form__input legend,
.template-product-notitle .form__label {
  text-align: center;
  width: 100%;
  margin-bottom: 1rem;
  flex-basis: 100%;
}


/* Keep buttons horizontal with spacing */
.template-product-notitle fieldset.product-form__input--pill {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}


/* Display service level buttons side by side with spacing */
.template-product-notitle .product-form__input--pill {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

/* Center the entire quantity form container */
.template-product-notitle #Quantity-Form-template--17180824305870__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.5rem;
}

/* Center the price-per-item container */
.template-product-notitle .price-per-item__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Center quantity label */
.template-product-notitle .quantity__label {
  text-align: center;
  width: 100%;
  margin-bottom: 0.5rem;
}

/* Center the quantity input itself */
.template-product-notitle quantity-input.quantity {
  margin: 0 auto;
}

/* Force buttons to 44rem width and center them */
.template-product-notitle .product-form__buttons {
  max-width: 36rem !important;
  width: 36rem !important;
  margin: 0 auto !important;
}

.template-product-notitle .product-form__submit,
.template-product-notitle .shopify-payment-button__button {
  width: 100% !important;
}

/* Reduce spacing between buttons */
.template-product-notitle .product-form__buttons > * {
  margin-bottom: 1rem;
}

/* Replace "Quantity" text with "No. of seats" */
.template-product-notitle .quantity__label {
  font-size: 0; /* Hide original text */
}

.template-product-notitle .quantity__label::before {
  content: "No. of seats";
  font-size: 1.4rem; /* Restore font size */
  text-align: center;
  width: 100%;
  display: block;
  margin-bottom: 0.5rem;
}

/* Remove all borders from tables in product description */
.product__description table,
.product__description table td,
.product__description table tr,
.product__description table th,
.product__description table tbody {
  border: none !important;
  border-collapse: collapse !important;
}

/* Remove any outline or box styling */
.product__description table {
  outline: none !important;
  box-shadow: none !important;
}

/* ── noquant template: hide media column, full-width centred content ── */
.template-product-noquant .product__media-wrapper,
.template-product-noquant .grid__item.product__media-wrapper {
  display: none !important;
}

.template-product-noquant .product__info-wrapper {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
}

.template-product-noquant .product__info-container {
  max-width: 80rem !important;
  margin: 0 auto !important;
}

.template-product-noquant .product__info-wrapper,
.template-product-noquant .product__column,
.template-product-noquant .product__info-container > * {
  width: 100% !important;
  max-width: none !important;
}

.template-product-noquant .product__info-container {
  max-width: 90rem !important;
  margin: 0 auto !important;
}

.template-product-noquant .product-form {
  max-width: 52.5rem !important;
  margin: 0 auto !important;
  width: 100% !important;
}

.template-product-noquant .price {
  font-size: 2.5rem !important;
  text-align: center;
}

.template-product-noquant .product__tax {
  text-align: center;
  width: 100%;
}

.template-product-noquant variant-selects {
  display: flex;
  justify-content: center;
  width: 100%;
}

.template-product-noquant fieldset.js.product-form__input {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.template-product-noquant .product-form__input legend,
.template-product-noquant .form__label {
  text-align: center;
  width: 100%;
  margin-bottom: 1rem;
  flex-basis: 100%;
}

.template-product-noquant fieldset.product-form__input--pill {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}

.template-product-noquant .product-form__input--pill {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.template-product-noquant .product-form__buttons {
  max-width: 36rem !important;
  width: 36rem !important;
  margin: 0 auto !important;
}

.template-product-noquant .product-form__submit,
.template-product-noquant .shopify-payment-button__button {
  width: 100% !important;
}

.template-product-noquant .product-form__buttons > * {
  margin-bottom: 1rem;
}