/*
Theme Name: Juver Colas
Theme URI: https://juvercolas.com
Author: Juver Colas
Author URI: https://juvercolas.com
Description: Custom theme by Juver Colas
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: juver-colas
Copyright: © 2025 Juver Colas
*/

::-webkit-scrollbar {
    width: 10px;
}
::-webkit-scrollbar-track {
    background: #12120F;
}
::-webkit-scrollbar-thumb {
    background: #1f1b11;
}
::-webkit-scrollbar-thumb:hover {
    background: #262012;
}
:root {
    --mx-accent: #c8a876;
    --mx-accent2: #e8c89a;
    --mx-dark: #0a0a0c;
    --mx-mid: #111116;
	--ntfy-form-width: 600px;
	--riel-accent-color: #FFCC00;
  }
html {
  scroll-behavior: smooth !important;
}

/* Add a "Momentum" feel to the body */
body {
  overflow-x: hidden;
	margin: 0px;
	background-color: #0a0a0c !important;
	background-image:
		linear-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0,0,0,0.04) 1px, transparent 1px) !important;
	background-size: 200px 200px !important;
  -webkit-overflow-scrolling: touch; /* For smooth mobile scrolling */
}
/* Remove those transitions that cause the "snapping" */
[class*="scroll-"], 
.elementor-element {
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
  will-change: transform;
}
body{
	margin: 0px;
}
body p{
	margin: 0px !important;
}
p, label, span{
	font-family: "Manrope", sans-serif;
}
.accent-text{
	color: var(--riel-accent-color);
}
header .elementor-sticky.elementor-sticky--effects{
	background-color: #12120fa8 !important;
	backdrop-filter: blur(15px) !important;
	border-bottom: 1px solid #FFCC00;
}
header .elementor-sticky.elementor-sticky--effects .menu-btn{
	backdrop-filter: blur(0px) !important;
	background-color: transparent !important;
}
.home-service-item{
	transition: 0.3s !important;
	backdrop-filter: blur(10px);
}
.home-service-item:hover{
	width: 175% !important;
}
.home-service-item::after{
	content:"";
	width: 100%;
	height: 4px;
	background-color: #FFCC00;
	position: absolute;
	left: -100%;
	bottom:0;
	transition: 1s;
	z-index: 10;
}
.home-service-item:hover::after{
	left: 0%;
}
.gold-o-container {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    line-height: 1;
}
.diamond-overlay {
    position: absolute;
    font-size: 0.4em; 
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    color: #FFCC00;
  }
#jv-hero-slider-section {
    --jv-primary: #FFCC00;
    padding: 0px;
    font-family: sans-serif;
    overflow: hidden; /* Contains the clip-path logic */
  }

  /* Target Swiper specifically within our ID to avoid global leaks */
  #jv-hero-slider-section .jv-main-swiper {
    width: 100%;
    overflow: visible !important; 
    clip-path: inset(-100vw -100vw -100vw 0);
  }
#jv-hero-slider-section .swiper-wrapper{
	height: 450px !important;
}
  .jv-slide-item {
    background: #f9f9f9; 
    height: 100%;
    display: flex !important;
    align-items: flex-end !important;
    padding: 0px;
    box-sizing: border-box;
    transition: opacity 0.4s ease;
	 background-position: center;
	  background-size: cover;
	  border: 1px solid var( --jv-primary);
  }

  /* Dim the partial slide */
  #jv-hero-slider-section .swiper-slide-next {
    opacity: 1;
  }
.jv-slide-inner-content{
	display: flex !important;
	flex-direction: column !important;
    align-items: flex-start !important;
	justify-content: end !important;
    padding: 40px;
    box-sizing: border-box;
	height: 100%;
	background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 30%, rgba(255, 255, 255, 1) 80%);
}
.jv-slide-inner-content h2 {
	font-size: 30px;
	margin-bottom: 10px;
	font-weight: 400;
	color: #303030;
	font-family: "Playfair Display" !important;
}
.jv-slide-inner-content p {
	font-size: 16px;
	font-weight: 400;
	color: #303030;
	font-family: "Manrope", sans-serif !important;
}
html.lenis, html.lenis body {
  height: auto;
}

.lenis.lenis-smooth {
  scroll-behavior: auto !important;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}
.jv-slide-inner-content a {
	font-size: 16px;
	font-weight: 400;
	color: #303030;
	font-family: "Manrope", sans-serif !important;
	padding: 10px 15px;
	border-radius: 0px;
	border: 1px solid #303030;
	background-color: transparent;
	margin-top:10px;
	transition: 0.3s;
}
.jv-slide-inner-content a:hover{
	background-color: #303030;
	border: 1px solid #303030;
	color: #fff;
}

.jv-cta-button {
	display: inline-block;
	margin-top: 20px;
	color: #303030;
	text-decoration: none;
	font-weight: bold;
}

/* Footer Styling */
.jv-slider-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 20px;
	border-top: 1px solid #e0e0e0;
	padding-top: 25px;
}

.jv-progress-track {
	flex-grow: 1;
	height: 2px;
	background: #F4DA9F;
	margin-right: 50px;
	position: relative;
}

.jv-progress-fill {
	position: absolute;
	width: 25%; 
	height: 100%;
	background: var(--jv-primary);
	transition: width 0.3s ease;
}

.jv-nav-controls {
	display: flex;
	gap: 20px;
}

.jv-btn-prev, .jv-btn-next {
	width: 55px;
	height: 55px;
	border: 1px solid var(--jv-primary) !important;
	border-radius: 50%;
	display: flex;
	align-items: center;      
	justify-content: center;
	cursor: pointer;
	font-size: 22px;
	transition: all 0.3s ease;
	color: var(--jv-primary);
}

.jv-btn-prev:hover, .jv-btn-next:hover {
	background: var(--jv-primary);
	color: #12120F;
}
.elementor-button .elementor-button-icon svg path{
	transition: 0.2s;
}
.elementor-button:hover .elementor-button-icon svg path{
	stroke: #303030 !important;
	fill: #303030 !important;
}
.banner-fleet{
	transition: 0.4s !important;
}
.banner-fleet:hover{
	background-size: 107% !important;
}
.banner-fleet::after{
	content:"";
	width: 100%;
	height: 4px;
	background-color: #FFCC00;
	position: absolute;
	left: -100%;
	bottom:0;
	transition: 1s;
}
.banner-fleet:hover::after{
	left: 0%;
}

.menu-btn{
	display: flex;
	flex-direction: row;
	gap: 60px;
	align-items: center;
	justify-content: center;
	padding: 10px 20px;
	border: 1px solid #fff;
	backdrop-filter: blur(10px);
	cursor: pointer;
	z-index: 999;
}
.menu-btn .menu-btn-icon{
	width: 22px;
	height: 22px;
	transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1);
}
.menu-btn .menu-btn-text{
	height: 20px;
	overflow: hidden;
	display: flex;
	gap: 0px;
	flex-direction: column;
	font-family: "Manrope",sans-serif !important;
}
.menu-btn .menu-btn-text p{
	margin: 0px;
	line-height: 20px;
	color: #fff;
	font-size: 16px;
	height: 40px;
	transform: translateY(0);
	transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1);
	font-family: "Manrope",sans-serif !important;
}
.menu-btn.menu-active .menu-btn-icon{
	transform: rotate(225deg);
}
.menu-btn.menu-active .menu-btn-text p{
	transform: translateY(-20px);
}
.menu-list-container{
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 998;
	width: 100vw;
	height: 100vh;
	display: flex;
	flex-direction: column;
	gap:0px;
	justify-content: center;
	align-items: center;
	background-color: #303030 !important;
	pointer-events: none;
	clip-path: circle(0% at 92% 52px);
	transition: clip-path 0.8s cubic-bezier(0.77, 0, 0.175, 1);
}
.menu-list-container.menu-active{
	clip-path: circle(150% at 92% 52px);
	pointer-events: all;
}
.menu-list-container .menu-list-item{
	padding: 0px;
	height: 60px;
	color: #fff;
	font-size: 28px;
	font-family: "Manrope", sans-serif !important;
	font-weight: 400;
	opacity: 0; 
	transform: translateY(30px); 
	transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1);
}
.menu-list-container.menu-active .menu-list-item{
	opacity: 1; 
	transform: translateY(0);
}
.menu-list-container .menu-list-item:hover{
	font-size: 32px;
}
.menu-list-container.menu-active .menu-list-item{
	transition: font-size 0.2s linear !important;
}
.menu-list-container.menu-active .menu-list-item:nth-child(1) { transition-delay: 0.4s; }
.menu-list-container.menu-active .menu-list-item:nth-child(2) { transition-delay: 0.5s; }
.menu-list-container.menu-active .menu-list-item:nth-child(3) { transition-delay: 0.6s; }
.menu-list-container.menu-active .menu-list-item:nth-child(4) { transition-delay: 0.7s; }
.menu-list-container.menu-active .menu-list-item:nth-child(5) { transition-delay: 0.8s; }
.menu-list-container.menu-active .menu-list-item:nth-child(6) { transition-delay: 0.9s; }
.menu-list-container.menu-active .menu-list-item:nth-child(7) { transition-delay: 1s; }
.menu-list-container.menu-active .menu-list-item:nth-child(8) { transition-delay: 1.1s; }
.menu-list-container.menu-active .menu-list-item:nth-child(9) { transition-delay: 1.2s; }
.menu-list-container.menu-active .menu-list-item:nth-child(10) { transition-delay: 1.3s; }


.marquee-wrapper {
  width: 100%;
  overflow: hidden;
  user-select: none;
  display: flex;
}

.marquee-track {
  display: flex;
  width: max-content;
  animation: scroll-loop 250s linear infinite;
}

.marquee-items {
  display: flex;
  flex-shrink: 0;
  white-space: nowrap;
}
.marquee-items p{
	color: #fff;
	font-family: "Manrope", sans-serif;
	font-weight: 700;
	font-size: 100px;
	letter-spacing: -5px;
}
.marquee-items span{
	color: #FFCC00;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(5px); }
    to { opacity: 1; transform: translateY(0); }
}

#header-account-icon{
	width: 42px;
	height: 42px;
	padding: 10px;
	border: 1px solid #fff;
	border-radius: 100px;
	backdrop-filter: blur(10px);
	cursor: pointer;
}
.acf-form{
	font-family: "Manrope", sans-serif !important;
}
.acf-form label{
	color: #fff;
	font-weight: 400;
	font-size: 16px;
}
.acf-form .acf-field{
	border-bottom: none !important;
}
.acf-form .acf-field input{
	border: none;
	border-bottom: 1px solid #fff;
	padding: 0px;
	border-radius: 0px;
}



 /* ── HERO ── */
  #mx-hero {
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    overflow: hidden;
    background: radial-gradient(ellipse 80% 60% at 50% 70%, #1a1408 0%, var(--mx-dark) 70%);
  }

  #mx-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
      90deg,
      transparent,
      transparent 120px,
      rgba(255,255,255,0.015) 120px,
      rgba(255,255,255,0.015) 121px
    );
  }

  .mx-hero-eyebrow {
    font-size: 0.7rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--mx-accent);
    margin-bottom: 1.2rem;
    opacity: 0;
    animation: mx-fadeUp 1s 0.3s forwards;
  }

  #mx-hero h1 {
    font-size: clamp(3rem, 7vw, 6rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1;
    opacity: 0;
    animation: mx-fadeUp 1s 0.5s forwards;
  }

  #mx-hero h1 span { color: var(--mx-accent); }

  .mx-hero-sub {
    margin-top: 1.2rem;
    font-size: 1rem;
    color: #666;
    letter-spacing: 0.06em;
    opacity: 0;
    animation: mx-fadeUp 1s 0.7s forwards;
  }

  .mx-scroll-cue {
    position: absolute;
    bottom: 2.5rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #444;
    opacity: 0;
    animation: mx-fadeUp 1s 1.2s forwards;
  }

  .mx-scroll-line {
    width: 1px;
    height: 40px;
    background: linear-gradient(to bottom, var(--mx-accent), transparent);
    animation: mx-lineGrow 2s 1.5s ease-in-out infinite;
  }

  @keyframes mx-lineGrow {
    0%, 100% { transform: scaleY(1); opacity: 0.4; }
    50% { transform: scaleY(1.3); opacity: 1; }
  }

  @keyframes mx-fadeUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* ── SCROLL SCENE ── */
  #mx-scroll-scene {
    position: relative;
    height: 500vh;
    background: var(--mx-dark);
  }

  #mx-sticky-wrap {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: hidden;
  }

  #mx-three-canvas {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
  }

  #mx-scene-glow {
    position: absolute;
    width: 70vw;
    height: 50vh;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(200,168,118,0.08) 0%, transparent 70%);
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
    pointer-events: none;
    transition: opacity 1s;
  }

  .mx-copy-panel {
    position: absolute;
    top: 50%;
    max-width: 300px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.7s ease, transform 0.7s ease;
    z-index: 10;
  }

  .mx-copy-panel.mx-left  { left: 5vw;  transform: translateY(-50%) translateX(-24px); }
  .mx-copy-panel.mx-right { right: 5vw; transform: translateY(-50%) translateX(24px); text-align: right; }

  .mx-copy-panel.mx-visible { opacity: 1; }
  .mx-copy-panel.mx-left.mx-visible  { transform: translateY(-50%) translateX(0); }
  .mx-copy-panel.mx-right.mx-visible { transform: translateY(-50%) translateX(0); }

  .mx-copy-panel .mx-tag {
    display: inline-block;
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--mx-accent);
    border: 1px solid rgba(200,168,118,0.3);
    padding: 0.25rem 0.7rem;
    border-radius: 2px;
    margin-bottom: 0.9rem;
  }

  .mx-copy-panel h2 {
    font-size: clamp(1.5rem, 2.5vw, 2.4rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
  }

  .mx-copy-panel p {
    margin-top: 0.75rem;
    font-size: 0.85rem;
    color: #666;
    line-height: 1.7;
  }

  .mx-copy-panel .mx-stat {
    margin-top: 1.2rem;
    display: flex;
    gap: 1.5rem;
  }

  .mx-copy-panel.mx-right .mx-stat { justify-content: flex-end; }

  .mx-stat-item .mx-num {
    display: block;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--mx-accent);
    letter-spacing: -0.03em;
  }

  .mx-stat-item .mx-label {
    display: block;
    font-size: 0.65rem;
    color: #555;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-top: 0.1rem;
  }

  /* loading overlay */
  #mx-loader {
    position: fixed;
    inset: 0;
    background: var(--mx-dark);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    transition: opacity 0.8s ease;
  }

  #mx-loader.mx-hidden { opacity: 0; pointer-events: none; }

  .mx-loader-ring {
    width: 48px;
    height: 48px;
    border: 2px solid #222;
    border-top-color: var(--mx-accent);
    border-radius: 50%;
    animation: mx-spin 0.9s linear infinite;
    margin-bottom: 1.2rem;
  }

  @keyframes mx-spin { to { transform: rotate(360deg); } }

  .mx-loader-text {
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #444;
  }

  #mx-prog-bar {
    position: fixed;
    top: 0; left: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--mx-accent), var(--mx-accent2));
    width: 0%;
    z-index: 200;
    transition: width 0.1s;
    box-shadow: 0 0 8px rgba(200,168,118,0.6);
  }

  #mx-nav-dots {
    position: fixed;
    right: 1.8rem;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    z-index: 100;
    opacity: 0;
    transition: opacity 0.4s;
  }

  #mx-nav-dots.mx-show { opacity: 1; }

  .mx-ndot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #333;
    cursor: pointer;
    transition: background 0.3s, transform 0.3s, height 0.3s;
  }

  .mx-ndot.mx-active {
    background: var(--mx-accent);
    transform: scale(1.4);
    height: 14px;
    border-radius: 3px;
  }

  #mx-spec-bar {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 3rem;
    z-index: 10;
    opacity: 0;
    transition: opacity 0.6s;
  }

  #mx-spec-bar.mx-show { opacity: 1; }

  .mx-spec-item { text-align: center; }
  .mx-spec-item .mx-sv { font-size: 1.3rem; font-weight: 700; color: var(--mx-accent); letter-spacing: -0.02em; }
  .mx-spec-item .mx-sl { font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: #444; margin-top: 0.2rem; }

  /* ── OUTRO ── */
  #mx-outro {
    height: 80vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    background: var(--mx-dark);
    position: relative;
    overflow: hidden;
  }

  #mx-outro::before {
    content: 'MAXIMA';
    position: absolute;
    font-size: 20vw;
    font-weight: 900;
    letter-spacing: -0.05em;
    color: rgba(255,255,255,0.02);
    pointer-events: none;
    white-space: nowrap;
  }

  #mx-outro h2 {
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    text-align: center;
  }

  #mx-outro h2 span { color: var(--mx-accent); }

  .mx-cta-row { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

  .mx-btn-primary, .mx-btn-outline {
    padding: 0.9rem 2.4rem;
    border-radius: 4px;
    font-size: 0.82rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s;
    cursor: pointer;
    border: none;
  }

  .mx-btn-primary {
    background: var(--mx-accent);
    color: #000;
  }

  .mx-btn-primary:hover { background: var(--mx-accent2); }

  .mx-btn-outline {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255,255,255,0.2);
  }

  .mx-btn-outline:hover { border-color: var(--mx-accent); color: var(--mx-accent); }

@keyframes scroll-loop {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.car-display-wrap {
      position: relative;
      flex-shrink: 0;
    }

    .car-display-wrap svg {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      overflow: visible;
    }

    .car-display-indicator,
    .car-display-node {
      position: absolute;
      border-radius: 50%;
      top: 0;
      left: 0;
    }

    .car-display-indicator {
      background: 
#FFCC00;
      box-shadow: 0 0 0 8px rgba(255,204,0,0.15), 0 4px 20px rgba(255,204,0,0.35);
      pointer-events: none;
      z-index: 0;
    }

    .car-display-node {
      cursor: pointer;
      border: 2px solid rgba(255,255,255,0.15);
      background: 
#1a1a1a;
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 2;
      transition: border-color 0.3s;
    }

    .car-display-node:hover,
    .car-display-node.car-display-active { border-color: 
#FFCC00 }

    .car-display-dot {
      border-radius: 50%;
      background: rgba(255,255,255,0.2);
      transition: background 0.3s;
      pointer-events: none;
    }

    .car-display-node.car-display-active .car-display-dot { background: 
#FFCC00 }

    .car-display-label {
      position: absolute;
      top: 0;
      left: 0;
      white-space: nowrap;
      pointer-events: none;
      z-index: 3;
      color: rgba(255,255,255,0.4);
      font-family: system-ui, sans-serif;
      font-weight: 500;
      transition: color 0.3s;
    }

    .car-display-label.car-display-active { color: 
#FFCC00 }
#car-display-img-wrap{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    position: relative;
/*     min-height: 100vh; */
}
#car-display-img-wrap .car-display-img-model{
    height: 280px;
    width: auto;
    object-fit: contain;
    object-position: center bottom;
    display: none;
    position: relative;
}
#car-display-img-wrap::before{
    content: "";
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translatex(-50%);
    width: 90%;
    height: 30px;
    border-top-left-radius: 60px; 
    border-top-right-radius: 60px;
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
    background-color: rgba(0,0,0,0.5);
    filter: blur(5px);
}
#car-display-img-wrap .car-display-img-model.active-model{
    display: block;
}
.banner-scroll-indicator{
	width: 2px;
	height: 20px;
	background: linear-gradient(to bottom, rgba(255,204,0,1), rgba(255,204,0,0.3));
	animation: scrollPulse 2s ease infinite;
}
.fleet-fade-el {
    transition: opacity 0.3s ease-in-out !important;
    opacity: 1;
}

.fleet-hidden {
    opacity: 0 !important;
}
.fleet-model{
	width: 100%;
	height: 400px !important;
	object-fit: contain;
	object-position: center center;
}
.fleet-info{
	display: flex;
	flex-direction:column;
	gap: 20px;
	width:100%;
}
.fleet-info h3{
	font-family: "Playfair Display";
	font-size: 36px;
	font-weight: 400;
	color: #fff;
	margin: 0px;
}
.fleet-info p{
	font-family: "Manrope", sans-serif;
	font-size: 18px;
	font-weight: 400;
	color: #fff;
	margin: 0px;
}
.fleet-info .fleet-perks{
	display: flex;
	flex-direction:row;
	flex-wrap: wrap;
	gap: 5px;
}
.fleet-info .fleet-perks span{
	padding: 2px 10px;
	border-radius: 50px;
	color: #000;
	background-color: #F4DA9F;
	font-family: "Manrope", sans-serif;
	font-weight: 400;
	font-size: 14px;
}
.w-c-riel{
	position: relative;
	border-radius: 15px !important;
	background: rgba(255, 255, 255, 0.02);
	backdrop-filter: blur(5px) saturate(180%);
	-webkit-backdrop-filter: blur(5px) saturate(180%);
	border: 1px solid transparent;
	background-clip: padding-box, border-box;
/* 	background-image: 
                linear-gradient(rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.03)), 
                linear-gradient(135deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0) 40%, rgba(0,0,0,0.8) 100%); */
	box-shadow: 
                0 30px 60px rgba(0,0,0,0.8), 
                inset 0 0 0 1px rgba(255,255,255,0.1),
                inset 2px 2px 4px rgba(255,255,255,0.2),
                inset -2px -2px 4px rgba(0,0,0,0.4);
}
.w-c-riel::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0; bottom: 0;
	border-radius: 12px;
	background: linear-gradient(
		135deg, 
		rgba(255,255,255,0.1) 0%, 
		rgba(255,255,255,0.02) 15%, 
		transparent 40%
	);
	pointer-events: none;
}
.w-c-riel::after {
	content: "";
	position: absolute;
	top: -2px; left: -2px; right: -2px; bottom: -2px;
	border-radius: 17px;
	z-index: -1;
	background: linear-gradient(135deg, transparent 70%, rgba(0, 153, 255, 0.1), rgba(255, 0, 102, 0.1));
	filter: blur(2px);
}
.flex{
	display: flex !important;
	gap: 20px;
}
.flex-row{
	flex-direction: row !important;
	width: 100%;
	gap: 20px;
}
.flex-column{
	flex-direction: column !important;
	width: 100%;
	gap: 5px;
}
.flex-column.hidden{
	display:  none !important;
}
.flex-column .w-25{
	width:25%;
}
.flex-column .w-30{
	width:30%;
}
.flex-column .w-33{
	width:33.3333%;
}
.flex-column .w-40{
	width:40%;
}
.flex-column .w-50{
	width:50%;
}
.flex-column .w-60{
	width:60%;
}
.flex-column .w-70{
	width:70%;
}
.flex-column .w-75{
	width:75%;
}
.flex-column h4{
	margin: 0;
	font-size: 26px;
}
.flex-column label{
	font-size: 14px;
	color: rgba(255,255,255,0.7) !important;
/* 	font-style: italic; */
}
.flex-column label, .flex-column input, .flex-column textarea, .flex-column select, .flex-column h4{
	width: 100%;
	color: white;
	background: transparent;
	font-family: "Manrope", sans-serif;
}
.flex-column label:focus, .flex-column input:focus, .flex-column textarea:focus, .flex-column select:focus, .flex-column *:focus{
	outline: none !important;
}
.flex-column input, .flex-column select{
	height: 35px;
	border: none;
	border-bottom: 1px solid white;
	border-radius: 0px;
	font-size: 16px;
}
.flex-column input[type="date"]::-webkit-calendar-picker-indicator, .flex-column input[type="time"]::-webkit-calendar-picker-indicator{
	filter: invert(1);
}
.flex-column select option{
	color: black;
}
.flex-column textarea{
	field-sizing: content;
	min-height: 50px;
	max-height: 150px;
	min-width:100%;
	max-width: 100%;
	border: none;
	border-bottom: 1px solid white;
	border-radius: 0px;
	font-size: 16px;
}
#add-stop-btn{
	font-size: 16px !important;
	padding: 10px 20px;
	border: 1px solid white;
	color: white;
	display: inline !important;
	width: fit-content !important;
/* 	flex: 0 1 auto !important; */
/* 	flex-basis: content; */
}
.autocomplete-wrapper svg{
	position: absolute;
	right: 0;
	bottom:0;
	width: 28px;
	height: 28px;
	padding: 5px;
	background-color: #333;
}
.autocomplete-wrapper input{
/* 	width: 100%; */
}
form .flex-row .flex-column #price-total{
	border: none !important;
	font-size: 40px;
}
#submit-btn{
	background-color: #FFCC00;
}
#submit-btn span{
	font-family: "Manrope", sans-serif;
	font-weight: 600;
	color: #000;
}
.gap-10{
	gap: 10px;
}
.gap-20{
	gap: 20px;
}
.gap-40{
	gap: 40px;
}
.gap-60{
	gap: 16px;
}
.gap-80{
	gap: 80px;
}
.gap-100{
	gap: 100px;
}
/* All Sides */
.m-0 { margin: 0 !important; }
.m-1 { margin: 0.25rem !important; } /* 4px */
.m-2 { margin: 0.5rem !important; }  /* 8px */
.m-3 { margin: 1rem !important; }    /* 16px */
.m-4 { margin: 1.5rem !important; }  /* 24px */
.m-5 { margin: 3rem !important; }    /* 48px */
.m-auto { margin: auto !important; }

/* Top */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 0.25rem !important; }
.mt-2 { margin-top: 0.5rem !important; }
.mt-3 { margin-top: 1rem !important; }
.mt-4 { margin-top: 1.5rem !important; }
.mt-5 { margin-top: 3rem !important; }

/* Bottom */
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 0.25rem !important; }
.mb-2 { margin-bottom: 0.5rem !important; }
.mb-3 { margin-bottom: 1rem !important; }
.mb-4 { margin-bottom: 1.5rem !important; }
.mb-5 { margin-bottom: 3rem !important; }

/* Left & Right */
.ml-1 { margin-left: 0.25rem !important; }
.ml-2 { margin-left: 0.5rem !important; }
.ml-3 { margin-left: 1rem !important; }
.mr-1 { margin-right: 0.25rem !important; }
.mr-2 { margin-right: 0.5rem !important; }
.mr-3 { margin-right: 1rem !important; }

/* X & Y Axis */
.mx-1 { margin-left: 0.25rem !important; margin-right: 0.25rem !important; }
.mx-2 { margin-left: 0.5rem !important; margin-right: 0.5rem !important; }
.mx-3 { margin-left: 1rem !important; margin-right: 1rem !important; }
.mx-auto { margin-left: auto !important; margin-right: auto !important; }
.my-1 { margin-top: 0.25rem !important; margin-bottom: 0.25rem !important; }
.my-2 { margin-top: 0.5rem !important; margin-bottom: 0.5rem !important; }
.my-3 { margin-top: 1rem !important; margin-bottom: 1rem !important; }

/* All Sides */
.p-0 { padding: 0 !important; }
.p-1 { padding: 0.25rem !important; }
.p-2 { padding: 0.5rem !important; }
.p-3 { padding: 1rem !important; }
.p-4 { padding: 1.5rem !important; }
.p-5 { padding: 3rem !important; }

/* Top */
.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: 0.25rem !important; }
.pt-2 { padding-top: 0.5rem !important; }
.pt-3 { padding-top: 1rem !important; }
.pt-4 { padding-top: 1.5rem !important; }
.pt-5 { padding-top: 3rem !important; }

/* Bottom */
.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: 0.25rem !important; }
.pb-2 { padding-bottom: 0.5rem !important; }
.pb-3 { padding-bottom: 1rem !important; }
.pb-4 { padding-bottom: 1.5rem !important; }
.pb-5 { padding-bottom: 3rem !important; }

/* Left & Right */
.pl-1 { padding-left: 0.25rem !important; }
.pl-2 { padding-left: 0.5rem !important; }
.pl-3 { padding-left: 1rem !important; }
.pr-1 { padding-right: 0.25rem !important; }
.pr-2 { padding-right: 0.5rem !important; }
.pr-3 { padding-right: 1rem !important; }

/* X & Y Axis */
.px-1 { padding-left: 0.25rem !important; padding-right: 0.25rem !important; }
.px-2 { padding-left: 0.5rem !important; padding-right: 0.5rem !important; }
.px-3 { padding-left: 1rem !important; padding-right: 1rem !important; }
.py-1 { padding-top: 0.25rem !important; padding-bottom: 0.25rem !important; }
.py-2 { padding-top: 0.5rem !important; padding-bottom: 0.5rem !important; }
.py-3 { padding-top: 1rem !important; padding-bottom: 1rem !important; }

#map{
	height: 400px;
	width: 100%;
}

#map-labels .map-label .pin{
	display: inline-block;
	background-color: #FFCC00;
	height: 24px;
	width: 24px;
	border-radius: 100px;
	text-align: center;
}

#map-label-pickup-text, #map-label-dropoff-text, #route-info{
	color: white;
}

.autocomplete-wrapper {
	position: relative;
}
.location-suggestions {
	position: absolute;
	top: 100%; left: 0; right: 0;
	background: #fff;
	border: 1px solid #ddd;
	border-top: none;
	border-radius: 0 0 6px 6px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	list-style: none;
	margin: 0; padding: 0;
	z-index: 99999;
	max-height: 220px;
	overflow-y: auto;
	display: none;
}
.location-suggestions li {
	padding: 9px 12px;
	cursor: pointer;
	font-size: 14px;
	border-bottom: 1px solid #f0f0f0;
	line-height: 1.4;
}
.location-suggestions li:last-child { border-bottom: none; }
.location-suggestions li:hover,
.location-suggestions li.active { background-color: #f5f5f5; }
.location-suggestions li span.ntfy-main { display: block; font-weight: 500; }
.location-suggestions li span.ntfy-sub  { display: block; font-size: 12px; color: #888; }

/* Preset Buttons */
.sign-preset-btn {
	flex: 1;
	height: 35px;
	border-radius: 0px;
	border: 1px solid #ddd;
	cursor: pointer;
	transition: transform 0.1s, border-color 0.2s;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	font-weight: bold;
	text-transform: uppercase;
}

.sign-preset-btn:hover { transform: scale(1.05); border-color: #999; }
.sign-preset-btn.active { border-color: #FFCC00; box-shadow: 0 0 5px rgba(0,123,255,0.5); }

.sign-controls-row {
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
	gap: 15px;
}

.sign-color-unit { flex: 1; font-size: 12px; color: #666; }

.sign-color-input {
	width: 100%;
	height: 30px;
	cursor: pointer;
	border: none !important;
	border-radius: 0px;
	display: block;
	margin-top: 5px;
	padding: 0;
}

/* The Sign Box */
.sign-preview-display {
	width: 500px;
	aspect-ratio: 23/16;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;
	border-radius: 0px;
	padding: 20px;
	box-sizing: border-box;
	background-color: #ffffff;
	box-shadow: inset 0 0 10px rgba(0,0,0,0.05);
}

#signDisplayText {
    display: block;
    width: 100%;
    line-height: 1.1;
    font-weight: 900;
    text-transform: uppercase;
    text-align: center;
    white-space: normal;
    word-break: keep-all;
    overflow-wrap: normal; /* ← was break-word, which overrides keep-all */
}

#payment-element {
    padding: 0px;
}



.booking-notice {
    padding: 16px 20px;
    border-radius: 4px;
    margin-bottom: 24px;
    font-weight: 500;
}
.booking-success {
    background: rgba(0, 200, 100, 0.15);
    border: 1px solid #00c864;
    color: #00c864;
}
.booking-error {
    background: rgba(255, 68, 68, 0.15);
    border: 1px solid #ff4444;
    color: #ff4444;
}


#greeting-message-container{
	display: none;
}



@keyframes scrollPulse {
  0%, 100% {
    opacity: 0.3;
    transform: scaleY(1);
  }
  50% {
    opacity: 1;
    transform: scaleY(1.1);
  }
}
  