:root{
  --ns-blue:#0b5ed7;
  --ns-blue-600:#0a58ca;
  --ns-light-blue:#64b5ff;
  --ns-ink:#0b1220;
  --ns-muted:#6c757d;
  --ns-bg:#0a1020;
  --ns-card:#0f1a33;
  --ns-border:rgba(255,255,255,.12);
  --ns-radius:16px;
  --ns-shadow:0 18px 50px rgba(2,8,23,.22);
}

html{font-size:16px;}
html{scroll-behavior:smooth;}
body.ns-body{
  color:#0b1220;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(100,181,255,.22), transparent 60%),
    radial-gradient(900px 500px at 85% 0%, rgba(11,94,215,.15), transparent 55%),
    #ffffff;
}

.ns-skip-link{
  position:absolute;
  left:-999px;
  top:1rem;
  z-index:9999;
  padding:.6rem .9rem;
  border-radius:999px;
  background:#fff;
  box-shadow:var(--ns-shadow);
}
.ns-skip-link:focus{left:1rem;}

.ns-topbar{
  background:linear-gradient(90deg, #050a14 0%, #0a1633 50%, #071028 100%);
}
.ns-topbar-link{
  color:rgba(255,255,255,.85);
  text-decoration:none;
}
.ns-topbar-link:hover{color:#fff;}

.ns-navbar{
  border-bottom:1px solid rgba(15,23,42,.10);
  position:sticky;
  top:0;
  z-index:1100;
}
.ns-navbar-white{
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
}
.ns-navbar .navbar-brand{
  padding:.5rem 1rem;
  display:flex;
  align-items:center;
  background:#000000;
  border-radius:12px;
}
.ns-navbar .nav-link{
  color:#0b1220 !important;
  font-weight:600;
  padding:1rem 1.25rem;
  border-radius:999px;
}
.ns-navbar .nav-link:hover{
  background:linear-gradient(135deg, rgba(11,94,215,.08), rgba(100,181,255,.10));
  color:#0b5ed7 !important;
}
.ns-navbar .nav-link.active{
  background:linear-gradient(135deg, rgba(11,94,215,.12), rgba(100,181,255,.16));
  color:#0b5ed7 !important;
}
.ns-navbar .navbar-toggler{border-color:rgba(15,23,42,.15);}
.ns-navbar .navbar-toggler:focus{box-shadow:0 0 0 .2rem rgba(11,94,215,.15);}
.ns-nav-center{justify-content:center;}
@media (min-width: 992px){
  .ns-navbar .navbar-nav.gap-lg-3{
    gap:2.5rem !important;
  }
}
.ns-dropdown-services{
  width:min(720px, 92vw);
  border-radius:16px;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 20px 60px rgba(2,8,23,.14);
  z-index:2000;
}
.ns-dropdown-services .dropdown-item{
  border-radius:12px;
  padding:.55rem .65rem;
  white-space:normal;
}
.ns-dropdown-services .dropdown-item:hover{
  background:linear-gradient(135deg, rgba(11,94,215,.08), rgba(100,181,255,.10));
}

/* Dropdown hover behavior is handled via JS (Bootstrap API) for correct Popper positioning. */
.ns-logo{height:80px;width:auto;}
@media (max-width: 991.98px){
  .ns-logo{height:65px;}
}
@media (max-width: 575.98px){
  .ns-logo{height:55px;}
}
.ns-logo-footer{height:34px;}

.ns-btn-primary{
  font-weight:600;
  background:linear-gradient(135deg, var(--ns-blue) 0%, #2d8cff 60%, var(--ns-light-blue) 100%);
  border:0;
  box-shadow:0 10px 25px rgba(11,94,215,.25);
}
.ns-btn-primary:hover{filter:brightness(1.03);}
.ns-btn-soft{
  border-radius:999px;
  border-color:rgba(255,255,255,.35);
}

.ns-section{
  padding:4.5rem 0;
  position:relative;
}
@media (max-width: 575.98px){
  .ns-section{padding:3.25rem 0;}
}
/* Default white sections get subtle top border for separation */
.ns-section:not(.ns-section-alt):not(.ns-section-dark):not(.ns-section-white):not(.ns-section-light):not(.ns-section-why){
  border-top:1px solid rgba(15,23,42,.04);
}

.ns-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg, #071028 0%, #0b1f46 45%, #071028 100%);
  color:#fff;
}
.ns-hero::before{
  content:"";
  position:absolute;
  inset:-40% -30% auto -30%;
  height:520px;
  background:radial-gradient(circle at 40% 40%, rgba(100,181,255,.35), transparent 60%);
  transform:rotate(12deg);
}
.ns-hero .container{position:relative;}
.ns-hero-badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.4rem .7rem;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
}
.ns-hero-title{
  letter-spacing:-.02em;
  font-weight:800;
  line-height:1.05;
}
@media (max-width: 575.98px){
  .ns-hero-title{
    font-size:clamp(1.75rem, 5vw, 2.5rem);
  }
}
.ns-hero-sub{
  color:rgba(255,255,255,.85);
  max-width:52ch;
}
@media (max-width: 575.98px){
  .ns-hero-sub{
    font-size:1rem;
  }
}

.ns-card{
  border:1px solid rgba(15,23,42,.12);
  border-radius:var(--ns-radius);
  box-shadow:0 10px 30px rgba(2,8,23,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.ns-card:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 55px rgba(2,8,23,.12);
  border-color:rgba(11,94,215,.25);
}
.ns-card-icon{
  width:48px;
  height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(11,94,215,.14), rgba(100,181,255,.18));
  color:var(--ns-blue);
}

.ns-kicker{
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(11,94,215,.9);
  font-size:.8rem;
}

.ns-footer{
  background:linear-gradient(180deg, #050a14 0%, #071028 45%, #050a14 100%);
  color:#fff;
}
.ns-footer-link{
  color:rgba(255,255,255,.78);
  text-decoration:none;
}
.ns-footer-link:hover{color:#fff;text-decoration:underline;}

.ns-form-card{
  border-radius:20px;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 16px 60px rgba(2,8,23,.12);
}
.ns-form-card-modal{
  background:#ffffff;
  padding:0;
}
.ns-form-card-modal .ns-steps{
  margin-top:.5rem;
}
.ns-form-card-modal .form-label{
  font-weight:600;
  color:#334155;
  margin-bottom:.5rem;
  font-size:.9rem;
}
.ns-form-card-modal .form-control,
.ns-form-card-modal .form-select{
  border:1.5px solid rgba(15,23,42,.12);
  border-radius:12px;
  padding:.75rem 1rem;
  transition:border-color .18s ease, box-shadow .18s ease;
  font-size:.95rem;
}
.ns-form-card-modal .form-control:focus,
.ns-form-card-modal .form-select:focus{
  border-color:rgba(11,94,215,.35);
  box-shadow:0 0 0 .2rem rgba(11,94,215,.08);
  outline:0;
}
.ns-form-card-modal .form-control:hover,
.ns-form-card-modal .form-select:hover{
  border-color:rgba(11,94,215,.20);
}

.ns-steps{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
}
.ns-step{
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.45rem .7rem;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.12);
  color:#334155;
  background:#fff;
}
.ns-step.is-active{
  border-color:rgba(11,94,215,.30);
  background:linear-gradient(135deg, rgba(11,94,215,.10), rgba(100,181,255,.14));
  color:#0b5ed7;
  font-weight:700;
}
.ns-step-num{
  width:26px;height:26px;border-radius:999px;
  display:grid;place-items:center;
  background:rgba(11,94,215,.12);
  color:#0b5ed7;
  font-weight:800;
  font-size:.85rem;
}

.ns-hidden{display:none !important;}

/* Alternate theme blocks */
.ns-section-alt{
  background:linear-gradient(135deg, rgba(11,94,215,.04), rgba(100,181,255,.08));
  border-top:1px solid rgba(15,23,42,.06);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.ns-section-white{
  background:#ffffff;
  border-top:1px solid rgba(15,23,42,.08);
  position:relative;
}
.ns-section-white::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(11,94,215,.12), transparent);
}
.ns-section-light{
  background:linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.05);
}
.ns-section-why{
  background:linear-gradient(135deg, rgba(11,94,215,.02), rgba(100,181,255,.04));
  margin-top:3rem;
  border-top:2px solid rgba(11,94,215,.08);
  position:relative;
}
.ns-section-why::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:120px;
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(11,94,215,.25), transparent);
}
@media (max-width: 575.98px){
  .ns-section-why{
    margin-top:2rem;
  }
}
.ns-section-dark{
  background:linear-gradient(135deg, #071028 0%, #0b1f46 55%, #071028 100%);
  color:#fff;
}
.ns-section-dark .text-muted{color:rgba(255,255,255,.72) !important;}

/* Glass panels overlay (for sections like your screenshot) */
.ns-glass-panels{
  position:relative;
  overflow:hidden;
}
.ns-glass-panels::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("/assets/home/glass-panels.svg");
  background-size:cover;
  background-position:center;
  opacity:.38;
  pointer-events:none;
}
.ns-glass-panels > .container{position:relative; z-index:1;}

/* Parallax breadcrumb/hero for inner pages */
.ns-hero-parallax{
  background-color:transparent !important;
}
.ns-hero.ns-hero-parallax::before{display:none;}
.ns-hero.ns-hero-parallax .breadcrumb-item + .breadcrumb-item::before{color:rgba(255,255,255,.35);}

/* Full-width slider */
.ns-slider{
  position:relative;
  overflow:hidden;
}
.ns-slider .carousel-item{
  min-height:clamp(600px, 80vh, 850px);
  display:flex;
  align-items:center;
  color:#fff;
}
@media (max-width: 575.98px){
  .ns-slider .carousel-item{min-height:clamp(520px, 78vh, 640px);}
}
.ns-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
}
.ns-slide-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:hidden;
  z-index:0;
}
.ns-slide-video video{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transform:scale(1.02);
}
@media (max-width: 991.98px){
  .ns-slide-video video{
    object-position:center;
  }
}
.ns-slide-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(7,16,40,.82) 0%, rgba(7,16,40,.55) 48%, rgba(7,16,40,.35) 100%);
  z-index:1;
}
@media (max-width: 991.98px){
  .ns-slide-overlay{
    background:linear-gradient(180deg, rgba(7,16,40,.78) 0%, rgba(7,16,40,.62) 55%, rgba(7,16,40,.55) 100%);
  }
}
.ns-slider .carousel-item > .container{
  position:relative;
  z-index:2;
}
.carousel-fade .carousel-item{
  opacity:0;
  transition:opacity .9s ease;
}
.carousel-fade .carousel-item.active{
  opacity:1;
}
.ns-slider .carousel-control-prev,
.ns-slider .carousel-control-next{
  width:9%;
  opacity:.9;
}
.ns-slider .carousel-indicators [data-bs-target]{
  width:22px;height:6px;border-radius:999px;
}

/* Dots for non-hero carousels (e.g., Services) */
.ns-carousel-indicators{
  position:static;
  margin:1.25rem 0 0;
  justify-content:center;
  gap:10px;
}
.ns-carousel-indicators [data-bs-target]{
  width:22px;
  height:6px;
  border-radius:999px;
  background-color:rgba(11,94,215,.25);
  opacity:1;
}
.ns-carousel-indicators .active{
  background-color:var(--ns-blue);
}

/* Reveal animations */
[data-ns-reveal]{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .7s ease, transform .7s ease;
  will-change:opacity, transform;
}
[data-ns-reveal].is-in{
  opacity:1;
  transform:translateY(0);
}
[data-ns-reveal][data-ns-delay="1"]{transition-delay:.08s;}
[data-ns-reveal][data-ns-delay="2"]{transition-delay:.16s;}
[data-ns-reveal][data-ns-delay="3"]{transition-delay:.24s;}

/* Parallax background section */
.ns-parallax{
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}
@media (max-width: 991.98px){
  .ns-parallax{background-attachment:scroll;}
}
.ns-parallax::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(7,16,40,.85), rgba(11,94,215,.40));
}
.ns-parallax > .container{position:relative;}

/* How we work (process) */
.ns-process{
  position:relative;
}
.ns-process::before{
  content:"";
  position:absolute;
  left:20px;
  top:10px;
  bottom:10px;
  width:2px;
  background:linear-gradient(180deg, rgba(11,94,215,.25), rgba(100,181,255,.35));
}
@media (min-width: 992px){
  .ns-process::before{left:28px;}
}
.ns-process-item{
  position:relative;
  padding-left:64px;
}
.ns-process-badge{
  position:absolute;
  left:0;
  top:0;
  width:40px;height:40px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(11,94,215,.14), rgba(100,181,255,.22));
  color:#0b5ed7;
  border:1px solid rgba(11,94,215,.18);
  box-shadow:0 10px 25px rgba(2,8,23,.10);
  font-weight:900;
}

/* Testimonials */
.ns-testimonial{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  border-radius:18px;
}
.ns-testimonial-quote{
  color:rgba(255,255,255,.86);
  line-height:1.8;
}
.ns-testimonial-name{font-weight:800;}
.ns-testimonial-role{color:rgba(255,255,255,.70);}

/* FAQ Accordion (Dark Theme) */
.ns-accordion-dark .ns-accordion-item-dark{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  border-radius:18px;
  margin-bottom:1rem;
  overflow:hidden;
}
.ns-accordion-dark .ns-accordion-item-dark:last-child{
  margin-bottom:0;
}
.ns-accordion-dark .ns-accordion-button-dark{
  background:transparent;
  border:0;
  color:rgba(255,255,255,.90);
  font-weight:600;
  padding:1.25rem 1.5rem;
  box-shadow:none;
}
.ns-accordion-dark .ns-accordion-button-dark:not(.collapsed){
  background:rgba(255,255,255,.08);
  color:#fff;
}
.ns-accordion-dark .ns-accordion-button-dark:focus{
  box-shadow:0 0 0 .2rem rgba(255,255,255,.15);
  border-color:transparent;
}
.ns-accordion-dark .ns-accordion-button-dark::after{
  filter:brightness(0) invert(1);
  opacity:.75;
}
.ns-accordion-dark .ns-accordion-button-dark:not(.collapsed)::after{
  opacity:1;
}
.ns-accordion-dark .ns-accordion-body-dark{
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.80);
  padding:1.25rem 1.5rem;
  line-height:1.7;
}

/* Services cards (image + icon like your example) */
.ns-service-card{
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 14px 45px rgba(2,8,23,.08);
  transition:transform .18s ease, box-shadow .18s ease;
}
.ns-service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 60px rgba(2,8,23,.12);
}
.ns-service-media{
  display:block;
  position:relative;
  overflow:hidden;
}
.ns-service-img{
  width:100%;
 /* height:210px;*/
  object-fit:cover;
  display:block;
  filter:saturate(1.02);
  transition:transform .4s ease;
}
.ns-service-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,0) 40%, rgba(255,255,255,.65) 100%);
}
.ns-service-card:hover .ns-service-img{transform:scale(1.03);}
.ns-service-body{
  position:relative;
  padding:2.35rem 1.5rem 1.25rem 1.5rem;
}
.ns-service-icon{
  position:absolute;
  left:1.5rem;
  top:-22px;
  width:54px;
  height:54px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(11,94,215,.14), rgba(100,181,255,.22));
  color:#0b5ed7;
  border:1px solid rgba(11,94,215,.18);
  box-shadow:0 10px 25px rgba(2,8,23,.10);
}
.ns-service-icon i{font-size:26px; line-height:1;}
.ns-service-title{
  font-size:1.25rem;
  font-weight:800;
  letter-spacing:-.01em;
  margin-bottom:.5rem;
}
.ns-service-text{
  color:#6b7280;
  line-height:1.7;
}
.ns-service-cta{
  padding:0 1.5rem 1.5rem 1.5rem;
}

/* Navbar CTA button: bigger, less rounded, stronger hover */
.ns-quote-btn{
  padding:.85rem 1.25rem;
  border-radius:14px;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow:0 16px 40px rgba(11,94,215,.22);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.ns-quote-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 22px 55px rgba(11,94,215,.28);
  filter:brightness(1.03);
}
.ns-quote-btn:active{transform:translateY(0);}

/* Why Nexus redesign */
.ns-why-card{
  background:#fff;
}
.ns-stat-tile{
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  padding:.9rem .9rem;
  background:rgba(255,255,255,.65);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.ns-stat-tile:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 45px rgba(2,8,23,.10);
  border-color:rgba(11,94,215,.22);
}
.ns-stat-num{
  font-weight:900;
  letter-spacing:-.02em;
  color:#0b5ed7;
  font-size:1.25rem;
  line-height:1.1;
}
.ns-stat-label{
  color:#64748b;
  font-size:.85rem;
  margin-top:.25rem;
}
.ns-cta-card{
  border-color:rgba(11,94,215,.22);
  background:linear-gradient(135deg, rgba(11,94,215,.06), rgba(100,181,255,.12));
}

/* Premium bluish hover effects (Home: Why Nexus cards) */
.ns-premium-cards .ns-card{
  position:relative;
  overflow:hidden;
  will-change:transform;
}

/* Gradient border (only on hover/focus) */
.ns-premium-cards .ns-card::before{
  content:"";
  position:absolute;
  inset:0;
  padding:1px;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(11,94,215,.55), rgba(100,181,255,.55), rgba(11,94,215,.22));
  opacity:0;
  transition:opacity .22s ease;
  pointer-events:none;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

/* Soft glow + shimmer */
.ns-premium-cards .ns-card::after{
  content:"";
  position:absolute;
  inset:-40% -35%;
  background:
    radial-gradient(circle at 25% 35%, rgba(100,181,255,.28), transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(11,94,215,.18), transparent 58%);
  opacity:0;
  transform:translate3d(-2%, -1%, 0) scale(1.02);
  transition:opacity .22s ease, transform .35s ease;
  pointer-events:none;
}

.ns-premium-cards .ns-card:hover,
.ns-premium-cards .ns-card:focus-within{
  transform:translateY(-6px);
  box-shadow:0 28px 80px rgba(2,8,23,.14);
  border-color:rgba(11,94,215,.25);
}
.ns-premium-cards .ns-card:hover::before,
.ns-premium-cards .ns-card:focus-within::before{opacity:1;}
.ns-premium-cards .ns-card:hover::after,
.ns-premium-cards .ns-card:focus-within::after{
  opacity:1;
  transform:translate3d(0, 0, 0) scale(1.06);
  animation:nsCardShimmer 2.2s ease-in-out infinite;
}

/* Micro-interactions inside the cards */
.ns-premium-cards .ns-card:hover .ns-card-icon,
.ns-premium-cards .ns-card:focus-within .ns-card-icon{
  transform:translateY(-1px);
  box-shadow:0 14px 35px rgba(11,94,215,.18);
}
.ns-premium-cards .ns-card:hover .ns-stat-tile,
.ns-premium-cards .ns-card:focus-within .ns-stat-tile{
  border-color:rgba(11,94,215,.22);
  box-shadow:0 18px 45px rgba(2,8,23,.10);
}

@keyframes nsCardShimmer{
  0%   {filter:hue-rotate(0deg);   transform:translate3d(-1%, -1%, 0) scale(1.06);}
  50%  {filter:hue-rotate(10deg);  transform:translate3d( 1%,  0%, 0) scale(1.08);}
  100% {filter:hue-rotate(0deg);   transform:translate3d(-1%, -1%, 0) scale(1.06);}
}

@media (prefers-reduced-motion: reduce){
  .ns-premium-cards .ns-card,
  .ns-premium-cards .ns-card::before,
  .ns-premium-cards .ns-card::after{
    transition:none !important;
    animation:none !important;
  }
  .ns-premium-cards .ns-card:hover,
  .ns-premium-cards .ns-card:focus-within{
    transform:none;
  }
}

/* Quote Modal - Centered & Enhanced UI */
#quoteModal .modal-dialog{
  margin:1rem auto;
  max-width:900px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:calc(100vh - 2rem);
}
#quoteModal .modal-content{
  border-radius:24px;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 32px 100px rgba(2,8,23,.25);
  overflow:hidden;
  background:#ffffff;
}
#quoteModal .modal-header{
  padding:2rem 2rem 1rem;
  background:linear-gradient(135deg, rgba(11,94,215,.04), rgba(100,181,255,.08));
  border-bottom:1px solid rgba(15,23,42,.06);
  position:relative;
}
#quoteModal .modal-header::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(11,94,215,.12), transparent);
}
#quoteModal .modal-title{
  font-size:1.5rem;
  font-weight:800;
  letter-spacing:-.01em;
  color:#0b1220;
  display:flex;
  align-items:center;
  gap:.5rem;
}
#quoteModal .modal-title::before{
  content:"";
  width:4px;
  height:28px;
  border-radius:2px;
  background:linear-gradient(180deg, var(--ns-blue), var(--ns-light-blue));
}
#quoteModal .btn-close{
  opacity:.6;
  padding:.5rem;
  margin:-.5rem -.5rem -.5rem auto;
  border-radius:8px;
  transition:opacity .18s ease, background .18s ease;
}
#quoteModal .btn-close:hover{
  opacity:1;
  background:rgba(15,23,42,.08);
}
#quoteModal .modal-body{
  padding:2rem;
  max-height:calc(100vh - 250px);
  overflow-y:auto;
}
#quoteModal .modal-body::-webkit-scrollbar{
  width:8px;
}
#quoteModal .modal-body::-webkit-scrollbar-track{
  background:rgba(15,23,42,.04);
  border-radius:4px;
}
#quoteModal .modal-body::-webkit-scrollbar-thumb{
  background:rgba(11,94,215,.25);
  border-radius:4px;
}
#quoteModal .modal-body::-webkit-scrollbar-thumb:hover{
  background:rgba(11,94,215,.35);
}
@media (max-width: 991.98px){
  #quoteModal .modal-dialog{
    max-width:95%;
    margin:.75rem auto;
    min-height:calc(100vh - 1.5rem);
  }
  #quoteModal .modal-header{
    padding:1.5rem 1.5rem .75rem;
  }
  #quoteModal .modal-body{
    padding:1.5rem;
    max-height:calc(100vh - 180px);
  }
}
@media (max-width: 575.98px){
  #quoteModal .modal-dialog{
    margin:.5rem auto;
    max-width:100%;
    min-height:calc(100vh - 1rem);
  }
  #quoteModal .modal-header{
    padding:1.25rem 1rem .5rem;
  }
  #quoteModal .modal-title{
    font-size:1.25rem;
  }
  #quoteModal .modal-body{
    padding:1.25rem 1rem;
    max-height:calc(100vh - 140px);
  }
}