.elementor-918 .elementor-element.elementor-element-9557e9c{--display:flex;position:relative;top:-10px;right:10px;}.elementor-918 .elementor-element.elementor-element-a0be92b{--display:flex;}@media(max-width:767px){.elementor-918 .elementor-element.elementor-element-9557e9c{position:relative;top:-10px;right:10px;}}/* Start custom CSS for html, class: .elementor-element-899ae6b *//* =========================================
   ProFix Edmonton - Customer Portal (LatePoint)
   Apply ONLY on the customer cabinet page
   Replace PAGE_ID_HERE with actual page ID
========================================= */
/* ===== Remove horizontal scroll bar safely ===== */

/* Hide any accidental horizontal overflow from full-width containers */
body.page-id-PAGE_ID_HERE,
html {
  overflow-x: hidden !important;
}

/* Prevent .pfx-login-page or its children from stretching beyond viewport width */
.pfx-login-page,
.pfx-login-shell {
  max-width: 100vw !important;
  overflow-x: hidden !important;
  box-sizing: border-box;
}

/* Adjust inner padding to avoid sub-pixel overflow */
.pfx-login-shell {
  padding-left: clamp(16px, 4vw, 60px);
  padding-right: clamp(16px, 4vw, 60px);
}

/* Mobile fallback */
@media (max-width: 900px) {
  .pfx-login-page {
    overflow-x: hidden !important;
  }
}

:root {
  --pf-blue: #1565A5;
  --pf-orange: #D97A2F;
  --pf-ink: #1c2430;
}

/* ---------- PAGE SCOPING & RESET ---------- */

body.page-id-PAGE_ID_HERE,
body.page-id-PAGE_ID_HERE html {
  margin: 0;
  padding: 0;
  height: 100%;
}

/* Hide theme chrome on this page */
body.page-id-PAGE_ID_HERE .site-header,
body.page-id-PAGE_ID_HERE .elementor-location-header,
body.page-id-PAGE_ID_HERE .site-footer,
body.page-id-PAGE_ID_HERE header,
body.page-id-PAGE_ID_HERE footer {
  display: none !important;
}

/* Flatten theme wrappers */
body.page-id-PAGE_ID_HERE #page,
body.page-id-PAGE_ID_HERE #content,
body.page-id-PAGE_ID_HERE .site,
body.page-id-PAGE_ID_HERE .site-main,
body.page-id-PAGE_ID_HERE .content-area,
body.page-id-PAGE_ID_HERE .entry-content,
body.page-id-PAGE_ID_HERE main {
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

/* Desktop: lock viewport, no scroll (we'll allow scroll on small screens later) */
body.page-id-PAGE_ID_HERE {
  overflow: hidden;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ---------- FULLSCREEN BACKGROUND ---------- */

.pfx-login-page {
  position: relative;
  width: 100vw;
  height: 100vh; /* full screen */
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  background:
    radial-gradient(circle at top left, rgba(21,101,165,0.22), transparent 70%),
    radial-gradient(circle at bottom right, rgba(217,122,47,0.16), transparent 70%),
    linear-gradient(135deg, var(--pf-ink) 0%, var(--pf-blue) 55%, var(--pf-ink) 100%);
}

/* ---------- MAIN GRID LAYOUT (DESKTOP) ---------- */

.pfx-login-shell {
  max-width: 1320px;
  width: 100%;
  height: 82vh; /* breathing room inside fullscreen */
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(380px, 1fr);
  gap: 70px;
  align-items: center;
  padding: 0 5vw;
  box-sizing: border-box;
}

/* ---------- LEFT PANEL ---------- */

.pfx-login-left {
  color: #ffffff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
}

.pfx-login-logo {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 10px 22px;
  border-radius: 999px;
  background: var(--pf-ink);
  box-shadow: 0 16px 40px rgba(0,0,0,0.55);
  text-decoration: none;
  transition: all 0.25s ease;
}

.pfx-login-logo:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 60px rgba(0,0,0,0.75);
}

.pfx-logo-main {
  font-size: 22px;
  font-weight: 800;
  color: #ffffff;
}

.pfx-logo-sub {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pf-orange);
}

.pfx-login-title {
  font-size: clamp(34px, 4vw, 46px);
  font-weight: 700;
  margin-top: 14px;
  color: #ffffff;
}

.pfx-login-subtitle {
  font-size: 15px;
  color: #e6f0ff;
  max-width: 520px;
}

.pfx-login-points {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: grid;
  gap: 8px;
  font-size: 13px;
  color: #f3f7ff;
}

.pfx-login-points li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.pfx-login-points i {
  margin-top: 3px;
  font-size: 11px;
  color: var(--pf-orange);
}

/* ---------- RIGHT PANEL (LOGIN CARD) ---------- */

.pfx-login-right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 100%;
}

.pfx-login-card {
  width: 100%;
  max-width: 460px;
  background: #ffffff;
  border-radius: 26px;
  padding: 26px 26px 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.35);
  box-sizing: border-box;
}

/* LatePoint container clean-up */
.pfx-login-card .latepoint-w,
.pfx-login-card .latepoint-box,
.pfx-login-card .latepoint-customer-dashboard-w {
  margin: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 18px !important;
  border: none !important;
  background: transparent !important;
}

/* Inputs */
.pfx-login-card input[type="text"],
.pfx-login-card input[type="email"],
.pfx-login-card input[type="tel"],
.pfx-login-card input[type="password"] {
  width: 100% !important;
  border-radius: 10px !important;
  border: 1px solid rgba(12,36,64,0.24) !important;
  background: #f7f9fc !important;
  padding: 12px 12px !important;
  font-size: 14px !important;
  color: #1c2430 !important;
  box-sizing: border-box;
}

.pfx-login-card input::placeholder {
  color: #9aa7bd !important;
}

/* Primary button */
.pfx-login-card .latepoint-btn,
.pfx-login-card .os-btn {
  border-radius: 999px !important;
  background: var(--pf-blue) !important;
  color: #ffffff !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 12px 22px !important;
  font-size: 14px !important;
  width: 100% !important;
  box-shadow: 0 18px 40px rgba(21,101,165,0.5) !important;
  transition: all 0.22s ease !important;
}

.pfx-login-card .latepoint-btn:hover,
.pfx-login-card .os-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 26px 60px rgba(21,101,165,0.85) !important;
}

/* Google button */
.pfx-login-card .os-google-login-btn,
.pfx-login-card .latepoint-google-login-btn {
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #222 !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,0.18) !important;
}
.pfx-login-card .os-google-login-btn:hover,
.pfx-login-card .latepoint-google-login-btn:hover {
  transform: translateY(-1px);
}

/* Helper text */
.pfx-login-help {
  margin-top: 10px;
  font-size: 11px;
  text-align: center;
  color: #8b97ac;
}
.pfx-login-help a {
  color: var(--pf-orange);
  font-weight: 500;
}

/* =========================================
   RESPONSIVE - MOBILE & TABLET
========================================= */

@media (max-width: 900px) {
  /* Allow scroll on small screens */
  body.page-id-PAGE_ID_HERE {
    overflow-y: auto;
  }

  .pfx-login-page {
    height: auto;                /* no forced crop */
    min-height: 100vh;
    padding: 20px 0;
    display: block;
  }

  .pfx-login-shell {
    max-width: 480px;
    width: 100%;
    margin: 0 auto;
    height: auto;
    padding: 0 16px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  /* Center left content */
  .pfx-login-left {
    align-items: center;
    text-align: center;
    gap: 10px;
  }

  .pfx-login-logo {
    margin: 0 auto 6px;
  }

  .pfx-login-subtitle {
    max-width: 100%;
  }

  .pfx-login-points {
    align-items: flex-start;
    text-align: left;
    width: 100%;
  }

  /* Center login card */
  .pfx-login-right {
    width: 100%;
    justify-content: center;
    align-items: flex-start;
  }

  .pfx-login-card {
    max-width: 100%;
    margin-top: 8px;
  }
}

@media (max-width: 480px) {
  .pfx-login-shell {
    padding: 0 12px;
  }
  .pfx-login-title {
    font-size: 30px;
  }
}/* End custom CSS */