/* ============================================================
   PT DAI — Design System
   Modern technology / corporate redesign
   Built on top of Bootstrap 5 grid + components
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  /* ---- Color tokens ---- */
  --primary:    #1f479c;
  --ink:        #1f479c;   /* global primary blue */
  --navy-950:   #1f479c;
  --navy-900:   #1f479c;
  --navy-800:   #1f479c;
  --navy-700:   #1f479c;
  --navy-600:   #1f479c;

  --teal-600:   #117d8d;
  --teal-500:   #18a0b0;
  --teal-400:   #4ec7d1;
  --teal-200:   #c6eef2;

  --lime:       #c6f24e;
  --lime-soft:  #e4ffaa;
  --lime-dim:   rgba(198,242,78,.14);

  --surface:      #ffffff;
  --surface-alt:  #eef3fb;
  --surface-card: #ffffff;
  --line:         #dbe4f0;
  --line-dark:    rgba(255,255,255,.12);

  --text:        #0b2230;
  --text-soft:   #51707a;
  --text-faint:  #88a0a7;
  --text-onDark: #eef8f9;
  --text-onDark-soft: #9bc1c7;

  --shadow-sm:  0 6px 18px -8px rgba(10,42,82,.18);
  --shadow-md:  0 18px 40px -16px rgba(10,42,82,.22);
  --shadow-lg:  0 28px 70px -24px rgba(10,42,82,.35);

  --radius-lg:  22px;
  --radius-md:  16px;
  --radius-sm:  10px;
  --container:  1200px;

  --ease: cubic-bezier(.22,1,.36,1);
}

/* ============================================================
   Base
   ============================================================ */
*{ box-sizing: border-box; }

html{ scroll-behavior: smooth; }

body{
  font-family: 'Inter', sans-serif;
  background: var(--surface);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1,h2,h3,h4,
.font-display{
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.02em;
}

a{ text-decoration: none; }

.container{ max-width: var(--container); }

::selection{ background: var(--lime); color: var(--ink); }

/* Skip link for keyboard users */
.skip-link{
  position: absolute; left: -999px; top: 0;
  background: var(--lime); color: var(--ink);
  padding: .5rem 1rem; z-index: 2000; border-radius: 0 0 8px 0;
}
.skip-link:focus{ left: 0; }

:focus-visible{
  outline: 2px solid var(--teal-400);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}

/* ============================================================
   Utility / type
   ============================================================ */
.eyebrow{
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .78rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--teal-600);
}
.eyebrow::before{
  content: ''; width: 7px; height: 7px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 0 4px var(--lime-dim);
}
.eyebrow.on-dark{ color: var(--lime-soft); }
.eyebrow.on-dark::before{ background: var(--lime); }

.section{ padding: 6.5rem 0; }
.section-tight{ padding: 4rem 0; }
.section-alt{ background: var(--surface-alt); }
.section-dark{ background: var(--navy-900); color: var(--text-onDark); }

.section-head{ max-width: 640px; margin-bottom: 3rem; }
.section-head.center{ margin-left: auto; margin-right: auto; text-align: center; }

.section-title{
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  font-weight: 700;
  color: var(--text);
  margin: .6rem 0 .9rem;
  line-height: 1.15;
}
.section-dark .section-title{ color: var(--text-onDark); }

.section-sub{
  color: var(--text-soft);
  font-size: 1.05rem;
  line-height: 1.65;
}
.section-dark .section-sub{ color: var(--text-onDark-soft); }

.text-lime{ color: var(--lime); }
.text-teal{ color: var(--teal-500); }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  border-radius: 999px;
  padding: .8rem 1.7rem;
  font-size: .95rem;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.btn:active{ transform: translateY(1px); }

.btn-grad{
  background: linear-gradient(120deg, var(--teal-500), var(--teal-600));
  color: #fff;
  box-shadow: 0 14px 30px -10px rgba(15,122,140,.55);
}
.btn-grad:hover{
  color: #fff;
  box-shadow: 0 18px 36px -8px rgba(15,122,140,.65);
  transform: translateY(-2px);
}

.btn-lime{
  background: var(--lime);
  color: var(--ink);
  box-shadow: 0 14px 30px -10px rgba(198,242,78,.45);
}
.btn-lime:hover{ color: var(--ink); transform: translateY(-2px); box-shadow: 0 18px 34px -8px rgba(198,242,78,.55); }

.btn-outline-onDark{
  background: transparent;
  color: var(--text-onDark);
  border: 1.5px solid rgba(255,255,255,.35);
}
.btn-outline-onDark:hover{
  color: #fff;
  background: #25D366;
  border-color: #25D366;
  box-shadow:
    0 12px 24px -10px rgba(37,211,102,.48),
    0 0 18px rgba(37,211,102,.18);
}

.btn-outline-brand{
  background: transparent;
  border: 1.5px solid var(--teal-500);
  color: var(--teal-600);
}
.btn-outline-brand:hover{
  background: var(--teal-500);
  color: #fff;
}

.btn-sm{ padding: .6rem 1.25rem; font-size: .85rem; }

.btn-wa{
  background: #25D366;
  color: #fff;
  box-shadow:
    0 14px 30px -10px rgba(37,211,102,.45),
    0 0 0 1px rgba(255,255,255,.08) inset;
  border: 1px solid rgba(255,255,255,.08);
}
.btn-wa:hover{
  color: #fff;
  background: #1F9E5B;
  transform: translateY(-2px) scale(1.01);
  box-shadow:
    0 18px 36px -12px rgba(31,158,91,.62),
    0 0 18px rgba(37,211,102,.18);
}

/* ============================================================
   Navbar
   ============================================================ */
.dai-nav{
  padding: 1.1rem 0;
  transition:
    background .35s var(--ease),
    padding .35s var(--ease),
    box-shadow .35s var(--ease),
    border-color .35s var(--ease),
    backdrop-filter .35s var(--ease);
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid transparent;
  -webkit-backdrop-filter: blur(0px);
  backdrop-filter: blur(0px);
}
.dai-nav .navbar-brand{
  display: flex; align-items: center; gap: .6rem;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--text-onDark);
}
.dai-nav .navbar-brand img{ height: 36px; }
.dai-nav .navbar-brand small{
  display: block; font-family: 'Inter',sans-serif; font-weight: 500;
  font-size: .68rem; letter-spacing: .06em; color: var(--text-onDark-soft);
  text-transform: uppercase;
}
.dai-nav .nav-link{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  color: var(--text-onDark-soft) !important;
  margin: 0 .25rem;
  padding: .5rem .9rem !important;
  border-radius: 999px;
  font-size: .92rem;
  transition: color .25s var(--ease), background .25s var(--ease);
}
.dai-nav .nav-link:hover,
.dai-nav .nav-link.active{
  color: #fff !important;
  background: rgba(255,255,255,.1);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
.dai-nav .btn-cta{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  background: var(--lime);
  color: var(--ink);
  border-radius: 999px;
  padding: .55rem 1.25rem;
  font-size: .9rem;
  margin-left: .4rem;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.dai-nav .btn-cta:hover{ transform: translateY(-2px); box-shadow: 0 10px 22px -8px rgba(198,242,78,.6); }

.dai-nav.scrolled{
  background: linear-gradient(90deg, rgba(7, 28, 68, .72), rgba(18, 96, 180, .56));
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid rgba(140, 198, 255, .12);
  box-shadow:
    0 14px 36px -20px rgba(4, 18, 46, .62),
    inset 0 -1px 0 rgba(255, 255, 255, .05);
  padding: .7rem 0;
}

.navbar-toggler{ border: none; }
.navbar-toggler:focus{ box-shadow: none; }
.navbar-toggler-icon{
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(255,255,255,0.92)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.nav-mobile-head{ display: none; }
@media (max-width: 991.98px){
  .nav-mobile-head{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
    margin-bottom: .9rem;
    padding: .75rem .8rem;
    border-radius: 12px;
    background: linear-gradient(120deg, rgba(255,255,255,.14), rgba(255,255,255,.07));
    border: 1px solid rgba(255,255,255,.16);
  }
  .nav-mobile-head span{
    color: #fff;
    font-family: 'Space Grotesk', sans-serif;
    font-size: .8rem;
    line-height: 1.35;
  }
  .nav-mobile-head .btn{
    padding: .52rem .95rem;
    font-size: .78rem;
    white-space: nowrap;
  }
  .dai-nav .navbar-collapse{
    background: linear-gradient(160deg, rgba(22,62,136,.95), rgba(31, 71, 156, .93));
    margin-top: 1rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255,255,255,.14);
    padding: .9rem 1rem 1rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 16px 40px -18px rgba(0,0,0,.45);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .dai-nav .navbar-nav{
    gap: .35rem;
    align-items: stretch !important;
  }
  .dai-nav .nav-link{
    width: 100%;
    padding: .76rem .7rem !important;
    border-radius: 10px;
  }
  .dai-nav .btn-cta{
    display: inline-block;
    margin: .55rem 0 0;
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

/* ============================================================
   Hero (shared scaffold)
   ============================================================ */
.hero{
  position: relative;
  background: var(--ink);
  color: var(--text-onDark);
  overflow: hidden;
  padding-top: 9.5rem;
  padding-bottom: 6.5rem;
}
.hero-bg-photo{
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  z-index: 0;
  overflow: hidden;
}
.hero-bg-photo video{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-bg-photo::after{
  content: '';
  position: absolute; inset: 0;
}
.hero-overlay-home::after{
  background:
    linear-gradient(100deg, rgba(8, 34, 74, .72) 18%, rgba(16, 58, 114, .58) 46%, rgba(31, 71, 156, .36) 70%, rgba(31, 71, 156, .18) 100%),
    linear-gradient(0deg, rgba(8, 34, 74, .18), transparent 52%);
}
.hero-overlay-rental::after{
  background:
    linear-gradient(110deg, rgba(3,20,46,.95) 10%, rgba(10,42,82,.86) 38%, rgba(18,58,110,.56) 65%, rgba(28,79,143,.36) 100%),
    linear-gradient(0deg, rgba(3,20,46,.6), transparent 50%);
}
.hero-grid{
  position: absolute; inset: 0; z-index: 1; opacity: .5;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: linear-gradient(180deg, transparent, rgba(0,0,0,.9) 30%, rgba(0,0,0,.9) 75%, transparent);
  mask-image: linear-gradient(180deg, transparent, rgba(0,0,0,.9) 30%, rgba(0,0,0,.9) 75%, transparent);
}
.hero-net{ position: absolute; z-index: 1; pointer-events: none; }
.hero-net .nd{ fill: var(--lime); }
.hero-net .nd.alt{ fill: var(--teal-400); }
.hero-net line, .hero-net path{
  stroke: rgba(198,242,78,.4);
  stroke-width: 1;
  fill: none;
}
.hero-net .pulse{
  animation: net-pulse 3.2s ease-in-out infinite;
}
.hero-net .pulse:nth-child(2n){ animation-delay: .6s; }
.hero-net .pulse:nth-child(3n){ animation-delay: 1.3s; }
.hero-net .flow{
  stroke-dasharray: 6 10;
  animation: net-flow 5s linear infinite;
}
@keyframes net-pulse{
  0%, 100%{ opacity:.35; r:2.6; }
  50%{ opacity:1; r:4.2; }
}
@keyframes net-flow{
  to{ stroke-dashoffset: -160; }
}

.hero-inner{ position: relative; z-index: 2; }

.hero-kicker-row{
  display:flex; flex-wrap:wrap; gap:.6rem; margin-top: 1.6rem;
}
.kicker-chip{
  font-family:'Space Grotesk',sans-serif;
  font-size:.78rem; font-weight:600; letter-spacing:.02em;
  color: var(--text-onDark);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.16);
  padding: .45rem 1rem;
  border-radius: 999px;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}

.hero h1{
  font-size: clamp(2.3rem, 4.6vw, 3.6rem);
  font-weight: 700;
  line-height: 1.08;
  margin: 1rem 0 1.2rem;
  max-width: 720px;
}
.hero p.lead{
  font-size: 1.12rem;
  color: var(--text-onDark-soft);
  max-width: 560px;
  line-height: 1.7;
  font-family: 'Inter', sans-serif;
}
.hero .hero-ctas{
  display:flex; gap: 1rem; flex-wrap: wrap; margin-top: 2.1rem;
}

/* Stat strip overlapping hero bottom */
.stat-strip{
  position: relative;
  z-index: 3;
  margin-top: 3.5rem;
}
.stat-row{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius-md);
  overflow: hidden;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.stat-cell{
  background: rgba(18,58,110,.5);
  padding: 1.5rem 1.4rem;
}
.stat-num{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size: 1.9rem;
  color: var(--lime);
  display:flex; align-items:baseline; gap:.15rem;
}
.stat-label{
  font-size: .82rem;
  color: var(--text-onDark-soft);
  margin-top:.3rem;
  line-height:1.4;
}
@media (max-width: 767.98px){
  .stat-row{ grid-template-columns: repeat(2,1fr); }
}

/* Capability ticker */
.ticker-wrap{
  background: var(--navy-950);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  white-space: nowrap;
  padding: .95rem 0;
}
.ticker-track{
  display: inline-flex;
  gap: 3rem;
  animation: ticker-scroll 26s linear infinite;
}
.ticker-track span{
  font-family:'Space Grotesk',sans-serif;
  font-size: .85rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--text-onDark-soft);
  display:inline-flex; align-items:center; gap: .8rem;
}
.ticker-track span::before{
  content:''; width:6px; height:6px; border-radius:50%; background: var(--lime);
  display:inline-block;
}
@keyframes ticker-scroll{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-50%); }
}

/* ============================================================
   Trust strip (credibility band)
   ============================================================ */
.trust-strip{
  position: relative;
  z-index: 3;
  margin-top: 2.2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  align-items: center;
  justify-content: space-around;
  padding: 1.4rem 0;
}
.trust-item{
  display: flex;
  align-items: center;
  gap: .7rem;
  font-size: .9rem;
  color: var(--text-onDark-soft);
}
.trust-icon{
  font-size: 1.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--lime);
}
@media (max-width: 767.98px){
  .trust-strip{
    gap: 1.2rem;
    margin-top: 1.6rem;
  }
  .trust-item{
    font-size: .82rem;
    flex: 1 1 calc(50% - .6rem);
  }
}

/* ============================================================
   About
   ============================================================ */
.about-section{
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,14,32,.88) 0%, rgba(5,14,32,.78) 45%, rgba(5,14,32,.52) 100%),
    url('../img/IT.jpg') center/cover;
}
.about-section::before{
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(41,123,255,.12), transparent 18%);
  pointer-events: none;
}
.about-shell{
  position: relative;
  z-index: 1;
  min-height: 560px;
}
.about-content{
  position: relative;
  max-width: 640px;
  text-align: left;
  color: #fff;
  padding: 2rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.1);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 24px 55px -32px rgba(2,10,24,.7);
}
.about-content .section-title,
.about-content .section-sub,
.about-content .eyebrow{
  text-align: left;
}
.about-content .section-title{
  max-width: 100%;
  color: #fff;
  margin-bottom: .9rem;
}
.about-content .section-sub{
  max-width: 56ch;
  color: rgba(255,255,255,.82);
}
.about-highlight-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.4rem;
}
.about-highlight-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 1rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 10px 22px -18px rgba(0,0,0,.48);
}
.about-highlight-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(41,123,255,.18), rgba(15,196,196,.18));
  color: var(--teal-300);
  font-size: .78rem;
  font-weight: 700;
  margin-bottom: .65rem;
}
.about-highlight-card h5{
  margin: 0 0 .35rem;
  font-size: 1rem;
  color: #fff;
}
.about-highlight-card p{
  margin: 0;
  font-size: .9rem;
  color: rgba(255,255,255,.78);
}

.check-list{
  list-style: none;
  padding: 0;
  margin: 1.3rem 0 0;
  display: grid;
  gap: .8rem;
}
.check-list li{
  display: flex;
  gap: .8rem;
  align-items: flex-start;
  color: #fff;
  font-size: .96rem;
  padding: .75rem .9rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
}
.check-list li svg{
  flex-shrink: 0;
  margin-top: .12rem;
  color: var(--teal-300);
}

.about-actions{
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.3rem;
}

@media (max-width: 1199.98px){
  .about-shell{ min-height: auto; }
}
@media (max-width: 575px){
  .about-content{
    padding: 1.4rem;
  }
  .about-highlight-grid{
    grid-template-columns: 1fr;
  }
  .about-actions{
    align-items: flex-start;
  }
}

/* ============================================================
   Portfolio
   ============================================================ */
.portfolio-section{
  position: relative;
  overflow: hidden;
}
.portfolio-carousel-shell{
  max-width: 1120px;
  margin: 0 auto;
}
.portfolio-carousel{
  border-radius: 26px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(245,250,255,.74));
  border: 1px solid rgba(41,123,255,.12);
  box-shadow:
    0 0 0 1px rgba(41,123,255,.08),
    0 22px 50px -28px rgba(10,42,82,.35);
}
.portfolio-slide{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  min-height: 520px;
}
.portfolio-slide-media{
  position: relative;
  overflow: hidden;
  min-height: 520px;
  background: linear-gradient(180deg, rgba(10,42,82,.04), rgba(10,42,82,.08));
}
.portfolio-slide-media-grid{
  padding: 1rem;
}
.portfolio-photo-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  grid-template-rows: 1fr 1fr;
  gap: .7rem;
  width: 100%;
  height: 100%;
}
.portfolio-photo-grid img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 16px;
}
.portfolio-photo-grid img:first-child{
  grid-row: span 2;
}
.portfolio-slide-tag{
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .5rem .75rem;
  border-radius: 999px;
  background: rgba(10,42,82,.78);
  color: var(--lime);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  backdrop-filter: blur(10px);
}
.portfolio-slide-copy{
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,250,255,.92));
}
.portfolio-slide-label{
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--teal-500);
  margin-bottom: .6rem;
}
.portfolio-slide-copy h3{
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  color: var(--text);
}
.portfolio-slide-copy p{
  margin: .8rem 0 1rem;
  color: var(--text-muted);
  max-width: 52ch;
}
.portfolio-slide-copy ul{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .6rem;
}
.portfolio-slide-copy li{
  position: relative;
  padding-left: 1.1rem;
  color: var(--text);
  font-size: .95rem;
}
.portfolio-slide-copy li::before{
  content: '';
  position: absolute;
  left: 0;
  top: .58rem;
  width: .45rem;
  height: .45rem;
  border-radius: 50%;
  background: var(--lime);
}
.portfolio-carousel .carousel-indicators{
  bottom: 1rem;
}
.portfolio-carousel .carousel-indicators [data-bs-target]{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background-color: rgba(10,42,82,.35);
  margin: 0 4px;
}
.portfolio-carousel .carousel-indicators .active{
  background-color: var(--teal-500);
}
.portfolio-carousel .carousel-control-prev,
.portfolio-carousel .carousel-control-next{
  width: 54px;
  opacity: 1;
}
.portfolio-carousel .carousel-control-prev-icon,
.portfolio-carousel .carousel-control-next-icon{
  width: 18px;
  height: 18px;
  filter: none;
}
.portfolio-carousel .carousel-control-prev-icon{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230a2a52'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}
.portfolio-carousel .carousel-control-next-icon{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230a2a52'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}
.portfolio-carousel .carousel-control-prev,
.portfolio-carousel .carousel-control-next{
  background: rgba(255,255,255,.72);
  top: auto;
  bottom: 1rem;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  margin: 0;
  box-shadow: 0 10px 22px -14px rgba(10,42,82,.5);
}
.portfolio-carousel .carousel-control-prev{ left: auto; right: 4.5rem; }
.portfolio-carousel .carousel-control-next{ right: 1rem; }

@media (max-width: 991px){
  .portfolio-slide{
    grid-template-columns: 1fr;
  }
  .portfolio-slide-media,
  .portfolio-slide-copy{
    min-height: auto;
  }
  .portfolio-slide-media{
    min-height: 360px;
  }
}
@media (max-width: 575px){
  .portfolio-slide-copy{
    padding: 1.4rem;
  }
  .portfolio-slide-media{
    min-height: 280px;
  }
  .portfolio-carousel .carousel-control-prev,
  .portfolio-carousel .carousel-control-next{
    bottom: .75rem;
  }
  .portfolio-carousel .carousel-control-prev{ right: 4rem; }
}
/* ============================================================
   Service portfolio subsection
   ============================================================ */
.portfolio-subsection{
  position: relative;
  overflow: hidden;
}
.portfolio-service-card{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  min-height: 320px;
  background: var(--surface-2);
  box-shadow:
    0 0 0 1px rgba(41,123,255,.12),
    0 18px 46px -28px rgba(10,42,82,.36);
}
.portfolio-service-slider{
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}
.portfolio-service-slider,
.portfolio-service-slider .carousel-inner,
.portfolio-service-slider .carousel-item{
  height: 100%;
}
.portfolio-service-slider .carousel-item{
  transition: transform .85s ease, opacity .85s ease;
}
.portfolio-service-slider img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s var(--ease);
}
.portfolio-service-card:hover .portfolio-service-slider img{
  transform: scale(1.05);
}
.portfolio-service-slider .carousel-indicators{
  margin: 0;
  bottom: .65rem;
  z-index: 4;
  pointer-events: auto;
}
.portfolio-service-slider .carousel-indicators [data-bs-target]{
  width: .5rem;
  height: .5rem;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.65);
  background-color: rgba(255,255,255,.42);
  opacity: 1;
  margin: 0 .22rem;
  pointer-events: auto;
}
.portfolio-service-slider .carousel-indicators .active{
  background-color: #fff;
  transform: scale(1.15);
}
.portfolio-service-control{
  width: 42px;
  height: 42px;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  border-radius: 0;
  opacity: .82;
  border: 0;
  background: transparent;
  outline: 0;
  z-index: 4;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
}
.portfolio-service-control.carousel-control-prev{ left: .65rem; }
.portfolio-service-control.carousel-control-next{ right: .65rem; }
.portfolio-service-control .carousel-control-prev-icon,
.portfolio-service-control .carousel-control-next-icon{
  width: 16px;
  height: 16px;
  background-image: none;
  position: relative;
}
.portfolio-service-control .carousel-control-prev-icon::before,
.portfolio-service-control .carousel-control-next-icon::before{
  content: '';
  position: absolute;
  inset: 0;
  margin: auto;
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
.portfolio-service-control .carousel-control-prev-icon::before{ transform: rotate(-135deg); }
.portfolio-service-control .carousel-control-next-icon::before{ transform: rotate(45deg); }
.portfolio-service-control:hover{
  background: transparent;
  opacity: 1;
}
.portfolio-service-control:focus,
.portfolio-service-control:focus-visible,
.portfolio-service-control:active{
  background: transparent;
  border: 0;
  outline: 0;
  box-shadow: none;
  opacity: 1;
}
.portfolio-service-card::after{
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,22,52,.03), rgba(7,22,52,.78));
  z-index: 1;
  pointer-events: none;
}
.portfolio-service-card-overlay{
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 2rem;
  z-index: 2;
  color: #fff;
  pointer-events: none;
}
.portfolio-service-card-overlay span{
  display: inline-flex;
  align-items: center;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--lime);
  margin-bottom: .35rem;
}
.portfolio-service-card-overlay h5{
  margin: 0;
  font-size: 1.1rem;
}

/* ============================================================
   Service cards
   ============================================================ */
.service-card{
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(245,250,255,.70)),
    linear-gradient(90deg, rgba(255,255,255,.10), rgba(255,255,255,.03));
  box-shadow:
    0 10px 28px -18px rgba(10,42,82,.28),
    inset 0 1px 0 rgba(255,255,255,.32);
  border: 1px solid rgba(41,123,255,.18);
  background-clip: padding-box;
  backdrop-filter: blur(12px) saturate(145%);
  -webkit-backdrop-filter: blur(12px) saturate(145%);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  height: 100%;
}
.service-card::before{
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(51, 158, 210, .46), rgba(52, 205, 198, .32));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  opacity: .88;
}
.service-card:hover{
  transform: translateY(-6px);
  box-shadow:
    0 0 0 1px rgba(41,123,255,.12),
    0 18px 46px -18px rgba(10,42,82,.35),
    0 0 22px rgba(41,123,255,.16),
    0 0 34px rgba(15,196,196,.12);
}
.service-card .sc-media{
  position: relative;
  height: 190px;
  overflow: hidden;
}
.service-card .sc-media img{
  width:100%; height:100%; object-fit: cover;
  transition: transform .6s var(--ease), opacity .5s ease;
  background: rgba(224,232,245,.5);
}
.service-card:hover .sc-media img{ transform: scale(1.08); }
.service-card .sc-media::after{
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(10,42,82,0) 40%, rgba(3,20,46,.55) 100%);
}
.sc-badge{
  position:absolute; top: 14px; left: 14px; z-index: 2;
  width: 42px; height: 42px;
  background: rgba(8,28,38,.7);
  border: 1px solid rgba(255,255,255,.25);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  color: var(--lime);
}
.sc-tag{
  position:absolute; bottom: 12px; right: 14px; z-index:2;
  font-size: .68rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-onDark-soft);
  font-family:'Space Grotesk',sans-serif;
}
.service-card .sc-body{ padding: 1.4rem 1.5rem 1.6rem; }
.service-card h5{
  font-family:'Space Grotesk',sans-serif;
  font-size: 1.12rem; font-weight: 700;
  margin-bottom: .4rem;
  color: var(--text);
}
.sc-usecase{
  margin: 0 0 .5rem;
  font-family:'Space Grotesk',sans-serif;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--teal-600);
}
.service-card p{
  color: var(--text-soft);
  font-size: .92rem;
  line-height: 1.55;
  margin-bottom: 1.1rem;
}
.service-card p.sc-usecase{ margin-bottom: .55rem; }
.sc-link{
  font-family:'Space Grotesk',sans-serif;
  font-size:.88rem; font-weight:600;
  color: var(--teal-600);
  display:inline-flex; align-items:center; gap:.4rem;
  transition: gap .25s var(--ease), color .25s var(--ease);
}
.sc-link svg{ transition: transform .25s var(--ease); }
.sc-link:hover{ color: var(--navy-900); }
.sc-link:hover svg{ transform: translateX(3px); }

.service-card.featured{
  box-shadow:
    0 0 0 1px rgba(15,196,196,.18),
    0 12px 28px -16px rgba(10,42,82,.3),
    0 0 18px rgba(41,123,255,.1),
    0 0 24px rgba(15,196,196,.08);
}
.service-card.featured::before{
  opacity: .88;
}
.service-card.featured .sc-pill{
  position:absolute; top:14px; right:14px; z-index:2;
  background: var(--lime); color: var(--ink);
  font-family:'Space Grotesk',sans-serif; font-weight:700;
  font-size:.68rem; letter-spacing:.04em; text-transform:uppercase;
  padding:.3rem .65rem; border-radius:999px;
}

/* ============================================================
   Process steps
   ============================================================ */
.process-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.6rem;
  position: relative;
}
.process-grid::before{
  content:'';
  position:absolute; top: 30px; left: 6%; right: 6%; height: 1px;
  background: repeating-linear-gradient(90deg, var(--line) 0 8px, transparent 8px 16px);
  z-index:0;
}
.process-step{
  position: relative;
  z-index:1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.process-icon{
  width: 64px; height: 64px;
  border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  background:
    linear-gradient(145deg, #1f479c, #2f67d1);
  color: var(--lime);
  margin: 0 auto 1rem;
  border: 1px solid rgba(76, 144, 255, 0.26);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.1),
    0 0 0 1px rgba(31, 71, 156, .08),
    0 0 18px rgba(47, 103, 209, .18),
    0 8px 28px -12px rgba(31, 71, 156, .62),
    0 18px 44px -18px rgba(31, 71, 156, .52),
    0 26px 58px -28px rgba(31, 71, 156, .46);
}
.process-step h5{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700; font-size:1.05rem; margin-bottom:.5rem;
}
.process-step p{
  color: var(--text-soft);
  font-size:.92rem;
  line-height:1.55;
  max-width: 33ch;
  margin: 0 auto;
}

@media (max-width: 991.98px){
  .process-grid{ grid-template-columns: repeat(2,1fr); row-gap: 2.2rem; }
  .process-grid::before{ display:none; }
}
@media (max-width: 575.98px){
  .process-grid{ grid-template-columns: 1fr; }
}

/* ============================================================
   Clients
   ============================================================ */
.client-panel{
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(245,250,255,.72)),
    linear-gradient(90deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border-radius: var(--radius-lg);
  padding: 1.6rem 0;
  box-shadow:
    0 10px 28px -18px rgba(10,42,82,.28),
    inset 0 1px 0 rgba(255,255,255,.32);
  border: 1px solid rgba(41,123,255,.18);
  backdrop-filter: blur(12px) saturate(145%);
  -webkit-backdrop-filter: blur(12px) saturate(145%);
  overflow: hidden;
}
.scroll-row-wrapper{ display:flex; flex-direction:column; gap: 1.2rem; }
.scroll-row{
  overflow:hidden;
  white-space: nowrap;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.scroll-track{
  display:inline-flex; gap: 2.4rem; padding: 0 1rem;
  animation: scroll-horizontal 90s linear infinite;
}
.scroll-row:hover .scroll-track{ animation-play-state: paused; }
.scroll-track.reverse{ animation-direction: reverse; }
.scroll-track img{
  width: 132px;
  height: 64px;
  padding: .45rem .7rem;
  object-fit: contain;
  object-position: center;
  background: rgba(255,255,255,.82);
  border-radius: 12px;
  box-shadow: 0 8px 18px -12px rgba(10,42,82,.35);
  filter: grayscale(45%) opacity(.85);
  transition: filter .3s var(--ease), transform .3s var(--ease);
}
.scroll-track img:hover{ filter: none; transform: translateY(-2px); }

/* Rental page override: gradient on container, equal logo size without per-logo boxes */
.page-rental #clients .client-panel{
  background:
    linear-gradient(145deg, #ffffff 0%, #f4f6f8 55%, #e9edf1 100%),
    radial-gradient(circle at 14% 18%, rgba(255,255,255,.58), transparent 44%),
    radial-gradient(circle at 88% 80%, rgba(255,255,255,.36), transparent 50%);
  border: 1px solid rgba(22, 45, 75, .14);
  box-shadow:
    0 14px 30px -22px rgba(20, 35, 58, .26),
    inset 0 1px 0 rgba(255,255,255,.72);
}
.page-rental #clients .scroll-track{
  gap: 1.8rem;
}
.page-rental #clients .scroll-track img{
  width: 144px;
  height: 78px;
  padding: 0;
  object-fit: contain;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  filter: none;
}
.page-rental #clients .scroll-track img:hover{
  transform: translateY(-3px);
}
@keyframes scroll-horizontal{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-100%); }
}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{
  position: relative;
  background:
    linear-gradient(-90deg, #0f4d7a 0%, #177d8f 52%, #2ca9b3 100%);
  color: var(--text-onDark);
  border-radius: var(--radius-lg);
  padding: 3.2rem 3rem;
  overflow: hidden;
  display:flex; align-items:center; justify-content:space-between; gap: 2rem; flex-wrap: wrap;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 18px 50px -22px rgba(8, 24, 56, .28);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.cta-band::before,
.cta-band::after{
  content:'';
  position:absolute;
  pointer-events:none;
  border-radius: 999px;
  filter: blur(10px);
}
.cta-band::before{
  right:-60px;
  top:-60px;
  width:260px;
  height:260px;
  background: radial-gradient(circle, rgba(41,123,255,.18), transparent 72%);
}
.cta-band::after{
  left: 50%;
  bottom: -40px;
  width: 72%;
  height: 80px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, rgba(15,196,196,.06), rgba(51,158,210,.08), rgba(15,196,196,.06));
}
.cta-band h3{
  font-size: clamp(1.4rem,2.4vw,1.9rem);
  margin-bottom:.5rem;
  max-width: 480px;
  position: relative; z-index:1;
}
.cta-band p{ color: var(--text-onDark-soft); max-width: 460px; position:relative; z-index:1; }
.cta-band .cta-actions{ display:flex; gap: 1rem; flex-wrap: wrap; position: relative; z-index:1; }

/* ============================================================
   Contact
   ============================================================ */
.contact-card{
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(245,250,255,.72)),
    linear-gradient(90deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border-radius: var(--radius-lg);
  padding: 2.2rem 1.8rem;
  text-align:center;
  height: 100%;
  box-shadow:
    0 10px 28px -18px rgba(10,42,82,.28),
    inset 0 1px 0 rgba(255,255,255,.32);
  border: 1px solid rgba(41,123,255,.18);
  background-clip: padding-box;
  backdrop-filter: blur(12px) saturate(145%);
  -webkit-backdrop-filter: blur(12px) saturate(145%);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.contact-card::before{
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(51, 158, 210, .46), rgba(52, 205, 198, .32));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  opacity: .88;
}
.contact-card:hover{
  transform: translateY(-5px);
  box-shadow:
    0 0 0 1px rgba(41,123,255,.12),
    0 18px 46px -18px rgba(10,42,82,.35),
    0 0 22px rgba(41,123,255,.12),
    0 0 30px rgba(15,196,196,.1);
}
.contact-icon{
  width: 56px; height:56px; border-radius:50%;
  background: var(--surface-alt);
  color: var(--teal-600);
  display:flex; align-items:center; justify-content:center;
  margin: 0 auto 1.1rem;
}
.contact-card h5{ font-family:'Space Grotesk',sans-serif; font-weight:700; margin-bottom:.5rem; }
.contact-card p{ color: var(--text-soft); font-size:.92rem; margin-bottom:1.3rem; }
.page-rental .contact-card{ display: flex; flex-direction: column; }
.page-rental .contact-card .btn{ margin-top: auto; }
.page-rental .contact-card-primary{
  border-color: rgba(37, 211, 102, .38);
  box-shadow:
    0 10px 28px -18px rgba(31,158,91,.35),
    inset 0 1px 0 rgba(255,255,255,.32);
}
.page-rental .contact-card-primary .contact-icon{
  background: rgba(37, 211, 102, .12);
  color: #1f9e5b;
}
.contact-response-note{
  margin: .7rem 0 0;
  font-size: .86rem;
  color: var(--teal-600);
  font-weight: 600;
}
.page-rental .contact-response-note{
  margin: .45rem 0 0;
  font-size: .86rem;
  color: var(--teal-600);
  font-weight: 600;
}

.rental-form-shell{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 2rem 1.7rem;
  box-shadow: var(--shadow-sm);
}
.rental-form{ max-width: 980px; margin: 0 auto; }
.rental-form-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .95rem;
}
.rental-field{ display: flex; flex-direction: column; gap: .42rem; }
.rental-field-full{ grid-column: 1 / -1; }
.rental-field label{
  font-family: 'Space Grotesk', sans-serif;
  font-size: .82rem;
  letter-spacing: .04em;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text);
}
.rental-field input,
.rental-field select,
.rental-field textarea{
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  padding: .72rem .85rem;
  font-size: .92rem;
}
.rental-field input:focus,
.rental-field select:focus,
.rental-field textarea:focus{
  border-color: var(--teal-400);
  box-shadow: 0 0 0 3px rgba(24,160,176,.12);
  outline: none;
}
.rental-form-actions{
  margin-top: 1rem;
  display: flex;
  gap: .9rem;
  align-items: center;
  flex-wrap: wrap;
}
.rental-form-actions .btn{ min-width: 210px; }
.rental-form-note{
  margin: 0;
  font-size: .86rem;
  color: var(--teal-600);
  font-weight: 600;
}
.rental-form-status{
  margin: .7rem 0 0;
  min-height: 1.1rem;
  font-size: .86rem;
  color: var(--text-soft);
}

.contact-location-divider{
  position: relative;
  margin: 3rem auto 2.4rem;
  max-width: 920px;
  height: 1px;
  background: linear-gradient(90deg, rgba(41,123,255,0), rgba(41,123,255,.34), rgba(15,196,196,.34), rgba(41,123,255,0));
}
.contact-location-divider::after{
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(41,123,255,.46);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 6px rgba(41,123,255,.08);
}

.location-hub{
  position: relative;
  margin-top: .6rem;
}
.location-info,
.location-map{
  border-radius: var(--radius-lg);
  height: 100%;
}
.location-info{
  padding: 2rem 1.7rem;
  background:
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(245,250,255,.74)),
    linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(41,123,255,.16);
  box-shadow:
    0 12px 30px -18px rgba(10,42,82,.28),
    inset 0 1px 0 rgba(255,255,255,.34);
}
.location-info .section-title{
  margin-bottom: .45rem;
}
.location-info .section-sub{
  margin-bottom: 1.2rem;
}
.location-meta{
  display: grid;
  gap: .85rem;
  margin-bottom: 1.3rem;
}
.location-meta-item{
  padding: .85rem .95rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(41,123,255,.12);
  background: rgba(255,255,255,.62);
}
.location-meta-item h6{
  margin: 0 0 .2rem;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--teal-700);
}
.location-meta-item p{
  margin: 0;
  color: var(--text);
  font-size: .92rem;
}
.location-actions{
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
}

.location-map{
  padding: .6rem;
  background: linear-gradient(130deg, rgba(41,123,255,.14), rgba(15,196,196,.12));
  border: 1px solid rgba(41,123,255,.2);
  box-shadow: 0 16px 38px -22px rgba(10,42,82,.36);
}
.map-frame{
  border-radius: calc(var(--radius-lg) - 6px);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--line);
  background: #e7eef9;
}
.map-frame iframe{
  width: 100%;
  height: 100%;
  display: block;
}

@media (max-width: 991.98px){
  .contact-location-divider{
    margin: 2.3rem auto 1.9rem;
  }
  .location-info{
    padding: 1.6rem 1.25rem;
  }
  .location-map{
    padding: .45rem;
  }
}

/* ============================================================
   Benefit / product cards (rental page)
   ============================================================ */
.page-rental__benefits-grid{
  counter-reset: rental-benefit;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.25rem;
  margin-top: 2.5rem;
  position: relative;
}
.page-rental__benefits-grid::before{
  content: '';
  position: absolute;
  left: 50%;
  top: .25rem;
  bottom: .25rem;
  width: 2px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(38,131,176,.24), rgba(37,198,173,.58), rgba(251,180,28,.34));
  border-radius: 999px;
}
.benefit-item{
  display: block;
  animation-duration: 0.6s;
  counter-increment: rental-benefit;
  position: relative;
}
.benefit-item::after{
  content: '';
  position: absolute;
  top: 50%;
  width: 22px;
  height: 2px;
  margin-top: -1px;
  background: linear-gradient(90deg, rgba(37,198,173,.5), rgba(38,131,176,.35));
}
.benefit-item:nth-child(odd)::after{
  right: -12px;
}
.benefit-item:nth-child(even)::after{
  left: -12px;
}
.benefit-card{
  background: linear-gradient(132deg, #f8fcff 0%, #eef8ff 100%);
  border: 1px solid rgba(39,122,171,.22);
  border-radius: 22px;
  padding: 1rem 1rem .95rem;
  height: 100%;
  position: relative;
  overflow: hidden;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease), filter .35s var(--ease);
  display: grid;
  grid-template-columns: 58px 1fr;
  grid-template-areas:
    'icon title'
    'icon metric'
    'icon desc';
  gap: .55rem .85rem;
  align-items: start;
  box-shadow:
    0 16px 30px -24px rgba(10,42,82,.3),
    inset 0 1px 0 rgba(255,255,255,.75);
}
.benefit-card::before{
  content: counter(rental-benefit, decimal-leading-zero);
  position: absolute;
  top: .7rem;
  right: .7rem;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .07em;
  color: #06344f;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(6,52,79,.16);
  border-radius: 999px;
  padding: .15rem .5rem;
  z-index: 2;
}
.benefit-card::after{
  content: '';
  position: absolute;
  left: -38px;
  bottom: -38px;
  width: 120px;
  height: 120px;
  border-radius: 999px;
  background: radial-gradient(circle at center, rgba(37,198,173,.22), rgba(37,198,173,0));
  pointer-events: none;
}
.benefit-card:hover{
  transform: translateY(-6px) scale(1.01);
  border-color: rgba(40,168,185,.58);
  box-shadow:
    0 22px 38px -26px rgba(10,42,82,.46),
    0 16px 26px -24px rgba(40,168,185,.56);
}
.benefit-badge{
  display: none;
}
.benefit-icon{
  width: 58px;
  height: 58px;
  border-radius: 16px;
  background: linear-gradient(150deg, #0a2a52, #1498b6);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  grid-area: icon;
  margin: .15rem 0 0;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  box-shadow: 0 10px 24px -16px rgba(10,42,82,.6);
}
.benefit-card:hover .benefit-icon{
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 14px 28px -18px rgba(10,42,82,.72);
}
.benefit-card h6{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  margin: .08rem 2.9rem 0 0;
  font-size: 1rem;
  color: var(--text);
  line-height: 1.32;
  grid-area: title;
}
.benefit-metric{
  grid-area: metric;
  display: inline-flex;
  align-items: baseline;
  gap: .45rem;
  flex-wrap: wrap;
  margin-top: -.1rem;
}
.benefit-metric strong{
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  color: #06344f;
}
.benefit-metric span{
  font-family: 'Space Grotesk', sans-serif;
  font-size: .7rem;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: #0f5f7f;
}
.benefit-card p{
  color: var(--text-soft);
  font-size: .88rem;
  line-height: 1.54;
  margin: 0;
  grid-area: desc;
}

.benefit-item:nth-child(4n+1) .benefit-card{
  background: linear-gradient(132deg, #f4fbff 0%, #e6f6ff 100%);
  border-color: rgba(34,137,197,.26);
}
.benefit-item:nth-child(4n+1) .benefit-icon{
  background: linear-gradient(150deg, #0a2a52, #1687cc);
}

.benefit-item:nth-child(4n+2) .benefit-card{
  background: linear-gradient(132deg, #f7fffa 0%, #e9fff3 100%);
  border-color: rgba(45,174,112,.28);
}
.benefit-item:nth-child(4n+2) .benefit-icon{
  background: linear-gradient(150deg, #18634d, #1cae79);
}

.benefit-item:nth-child(4n+3) .benefit-card{
  background: linear-gradient(132deg, #fffaf3 0%, #fff0dc 100%);
  border-color: rgba(216,140,26,.3);
}
.benefit-item:nth-child(4n+3) .benefit-icon{
  background: linear-gradient(150deg, #89530f, #d2871c);
}

.benefit-item:nth-child(4n+4) .benefit-card{
  background: linear-gradient(132deg, #fff7fd 0%, #f7ecff 100%);
  border-color: rgba(144,84,189,.3);
}
.benefit-item:nth-child(4n+4) .benefit-icon{
  background: linear-gradient(150deg, #5f3188, #9a62c8);
}

@media (max-width: 768px){
  .page-rental__benefits-grid{
    grid-template-columns: 1fr;
    gap: .9rem;
    margin-top: 2rem;
  }
  .page-rental__benefits-grid::before,
  .benefit-item::after{
    display: none;
  }
  .benefit-card{
    padding: .95rem .95rem .9rem;
    grid-template-columns: 52px 1fr;
    gap: .45rem .75rem;
  }
  .benefit-card::before{
    top: .58rem;
    right: .6rem;
    font-size: .7rem;
  }
  .benefit-icon{
    width: 52px;
    height: 52px;
  }
  .benefit-card h6{
    margin-right: 2.45rem;
    font-size: .96rem;
  }
  .benefit-metric strong{
    font-size: .92rem;
  }
  .benefit-metric span{
    font-size: .66rem;
  }
}

.product-card{
  border-radius: var(--radius-lg);
  overflow:hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
  height: 100%;
  background: var(--surface);
}
.product-card:hover{ transform: translateY(-5px); box-shadow: var(--shadow-md); }
.product-card .pc-media{ height: 200px; overflow:hidden; }
.product-card .pc-media img{ width:100%; height:100%; object-fit:cover; transition: transform .5s var(--ease); }
.product-card:hover .pc-media img{ transform: scale(1.07); }
.product-card .pc-body{ padding: 1.4rem 1.5rem; }
.product-card h5{ font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:1.05rem; margin-bottom:.4rem; }
.product-card p{ color: var(--text-soft); font-size:.9rem; margin:0; }

/* ============================================================
   Testimonials (bootstrap carousel override)
   ============================================================ */
#testimonial .carousel-item{ min-height: auto; }
.testi-card{
  max-width: 680px; margin: 0 auto;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 2.6rem 2.4rem;
  text-align:center;
  box-shadow: var(--shadow-sm);
}
.testi-quote{ color: var(--lime); margin-bottom: 1rem; }
.testi-card p.quote{
  font-size: 1.08rem;
  font-style: italic;
  color: var(--text);
  line-height:1.7;
  margin-bottom: 1.4rem;
}
.testi-card .name{ font-family:'Space Grotesk',sans-serif; font-weight:700; }
.testi-card .org{ color: var(--text-faint); font-size: .85rem; }
.page-rental #testimonialCarousel .carousel-indicators{
  position: static;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 1.8rem 0 0;
  gap: .6rem;
  padding: 0;
}
.page-rental #testimonialCarousel .carousel-indicators [data-bs-target]{
  width: 9px;
  height: 9px;
  margin: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(31, 71, 156, .28);
  opacity: 1;
  transition: transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
  cursor: pointer;
  padding: 0;
}
.page-rental #testimonialCarousel .carousel-indicators [data-bs-target]:hover{
  transform: scale(1.15);
  background: rgba(31, 71, 156, .45);
}
.page-rental #testimonialCarousel .carousel-indicators .active{
  background: var(--teal-500);
  transform: scale(1.25);
  box-shadow: 0 0 0 3px rgba(24, 160, 176, .2);
}
#testimonialCarousel .carousel-indicators{
  position: static;
  margin: 1.2rem 0 0;
  gap: .45rem;
}
#testimonialCarousel .carousel-indicators [data-bs-target]{
  width: 9px;
  height: 9px;
  margin: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(31, 71, 156, .28);
  opacity: 1;
  transition: transform .25s var(--ease), background .25s var(--ease);
}
#testimonialCarousel .carousel-indicators .active{
  background: var(--teal-500);
  transform: scale(1.2);
}
.carousel-control-prev, .carousel-control-next{ width: 5%; }
.carousel-control-prev-icon, .carousel-control-next-icon{
  background-color: var(--navy-900);
  border-radius: 50%;
  padding: 1.1rem;
  background-size: 50%;
}

/* ============================================================
   Instagram embed wrapper
   ============================================================ */
.page-rental__instagram-wrapper{
  display: grid;
  grid-template-columns: 1fr 350px;
  gap: 2.4rem;
  align-items: start;
}
.page-rental__instagram-wrapper .ig-panel{
  background: linear-gradient(135deg, var(--surface) 0%, rgba(245, 250, 254, .5) 100%);
  border: 1.5px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
  overflow: hidden;
  position: relative;
}
.page-rental__instagram-wrapper .ig-panel::before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #E1306C, #833AB4, #FD1D1D);
  opacity: 0.6;
}
.ig-cta{
  display: flex;
  flex-direction: column;
}
.ig-cta-card{
  background: linear-gradient(135deg, #fafbfd 0%, rgba(225, 48, 108, .04) 100%);
  border: 1.5px solid rgba(225, 48, 108, .15);
  border-radius: var(--radius-lg);
  padding: 2rem 1.8rem;
  text-align: center;
  transition: all .35s var(--ease);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.ig-cta-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(225, 48, 108, .12);
  border-color: rgba(225, 48, 108, .3);
}
.ig-cta-icon{
  width: 64px;
  height: 64px;
  margin: 0 auto 1.4rem;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(225, 48, 108, .15), rgba(131, 58, 180, .08));
  color: #E1306C;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .35s var(--ease);
}
.ig-cta-card:hover .ig-cta-icon{
  transform: scale(1.1) rotate(-2deg);
  background: linear-gradient(135deg, rgba(225, 48, 108, .25), rgba(131, 58, 180, .15));
}
.ig-cta-card h6{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  margin-bottom: 0.6rem;
  font-size: 1.1rem;
  color: var(--text);
  line-height: 1.3;
}
.ig-cta-card p{
  color: var(--text-soft);
  font-size: 0.9rem;
  line-height: 1.6;
  margin-bottom: 1.6rem;
  flex-grow: 1;
}
.btn-ig{
  background: linear-gradient(135deg, #E1306C, #C13584);
  color: white;
  border: none;
  padding: 0.8rem 1.8rem;
  border-radius: 8px;
  font-weight: 600;
  font-size: 0.95rem;
  transition: all .3s var(--ease);
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  text-align: center;
}
.btn-ig:hover{
  background: linear-gradient(135deg, #C13584, #833AB4);
  transform: scale(1.05);
  box-shadow: 0 8px 20px rgba(225, 48, 108, .3);
  color: white;
}
@media (max-width: 1024px){
  .page-rental__instagram-wrapper{
    grid-template-columns: 1fr;
    gap: 1.8rem;
  }
  .ig-cta-card{
    padding: 1.6rem;
  }
}
@media (max-width: 768px){
  .page-rental__instagram-wrapper{
    gap: 1.4rem;
  }
  .ig-cta-card{
    padding: 1.4rem;
  }
  .ig-cta-icon{
    width: 56px;
    height: 56px;
    margin-bottom: 1.2rem;
  }
  .ig-cta-card h6{
    font-size: 1rem;
  }
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, #1f479c, #2f67d1);
  color: var(--text-onDark-soft);
  padding: 4.5rem 0 0;
}
.site-footer::before{
  content: '';
  position: absolute;
  left: -8%;
  right: -8%;
  top: -90px;
  height: 170px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  pointer-events: none;
}
.footer-brand{ display:flex; align-items:center; gap:.7rem; margin-bottom: 1rem; }
.footer-brand img{ height: 38px; }
.footer-brand span{
  font-family:'Space Grotesk',sans-serif; font-weight:700; color:#fff; font-size:1.05rem;
}
.site-footer p{ font-size:.9rem; line-height:1.7; }
.footer-col h6{
  font-family:'Space Grotesk',sans-serif;
  color:#fff; font-weight:700; font-size:.85rem;
  letter-spacing:.06em; text-transform:uppercase;
  margin-bottom: 1.1rem;
}
.footer-links{ list-style:none; padding:0; margin:0; display:grid; gap:.65rem; }
.footer-links a{
  color: var(--text-onDark-soft);
  font-size: .9rem;
  transition: color .2s var(--ease), padding-left .2s var(--ease);
}
.footer-links a:hover{ color: var(--lime); padding-left: 4px; }
.footer-social{ display:flex; gap:.7rem; margin-top:1.2rem; }
.footer-social a{
  width: 38px; height: 38px; border-radius:50%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  transition: background .25s var(--ease), transform .25s var(--ease);
}
.footer-social a:hover{ background: var(--lime); transform: translateY(-2px); }
.footer-social img{ height: 18px; filter: brightness(0) invert(1); }
.footer-social a:hover img{ filter: none; }
.footer-bottom{
  margin-top: 3.2rem;
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 1.4rem 0;
  font-size: .82rem;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem;
}

/* ============================================================
   WhatsApp floating button
   ============================================================ */
.wa-fab{
  position: fixed; bottom: 24px; right: 24px; z-index: 1000;
  width: 58px; height: 58px; border-radius: 50%;
  background: #1f9e5b;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 12px 28px -8px rgba(31,158,91,.6);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.wa-fab:hover{ transform: translateY(-3px) scale(1.05); box-shadow: 0 16px 34px -8px rgba(31,158,91,.7); }
.wa-fab svg{ color:#fff; }
.wa-fab .wa-ping{
  position:absolute; inset:0; border-radius:50%;
  border: 2px solid #1f9e5b;
  animation: wa-ping 2.4s var(--ease) infinite;
}
@keyframes wa-ping{
  0%{ transform: scale(1); opacity:.7; }
  100%{ transform: scale(1.6); opacity:0; }
}

.mobile-cta-bar{
  display: none;
  position: fixed;
  left: .75rem;
  right: .75rem;
  bottom: .75rem;
  z-index: 1002;
  padding: .45rem;
  border-radius: 999px;
  background: rgba(7,28,68,.88);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 14px 28px -14px rgba(4,18,46,.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  gap: .45rem;
}
.mobile-cta-btn{
  flex: 1;
  text-align: center;
  padding: .68rem .9rem;
  border-radius: 999px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .86rem;
  font-weight: 700;
  letter-spacing: .01em;
}
.mobile-cta-whatsapp{
  background: #25D366;
  color: #fff;
}
.mobile-cta-call{
  background: rgba(255,255,255,.14);
  color: #fff;
  border: 1px solid rgba(255,255,255,.22);
}

/* ============================================================
   Performance / Image loading
   ============================================================ */
img[loading="lazy"]{
  opacity: 0;
  animation: fade-in-image .6s ease-in-out forwards;
}
@keyframes fade-in-image{
  to{ opacity: 1; }
}

/* ============================================================
   Misc / responsive
   ============================================================ */
@media (max-width: 767.98px){
  .section{ padding: 4.5rem 0; }
  .cta-band{ padding: 2.4rem 1.6rem; text-align:center; justify-content:center; }
  .cta-band .cta-actions{ justify-content:center; }
  .hero{ padding-top: 7.5rem; padding-bottom: 4rem; }
  .page-rental .contact-card{ padding: 1.8rem 1.25rem; }
  .page-rental .contact-response-note{ margin-top: .65rem; }
  .rental-form-grid{ grid-template-columns: 1fr; }
  .rental-form-shell{ padding: 1.45rem 1.1rem; }
  .page-rental .rental-form-actions .btn{ width: 100%; }
  .page-rental .rental-form-note,
  .page-rental .rental-form-status{ text-align: center; width: 100%; }
  #testimonialCarousel .carousel-control-prev,
  #testimonialCarousel .carousel-control-next{ width: 11%; }
  .wa-fab{ display:none; }
  .mobile-cta-bar{ display:flex; }
  body{ padding-bottom: 5.4rem; }
}

.no-backdrop .dai-nav.scrolled,
.no-backdrop .stat-cell,
.no-backdrop .kicker-chip{ background: rgba(10,42,82,.92); }

/* ============================================================
   SERVICE COVERAGE SECTION
   ============================================================ */
.coverage-section {
  background: linear-gradient(180deg, #07162b 0%, #0c2040 55%, #07162b 100%);
  overflow: hidden;
  position: relative;
}
.coverage-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 90% 55% at 50% 38%, rgba(78,199,209,.08) 0%, transparent 70%);
  pointer-events: none;
}
.coverage-section .eyebrow      { color: var(--teal-400); }
.coverage-section .section-title{ color: #eef8f9; }
.coverage-section .section-sub  { color: var(--text-onDark-soft); }

/* stats row */
.coverage-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2.5rem;
}
.coverage-stat-item {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(78,199,209,.22);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.8rem;
  text-align: center;
  min-width: 130px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.coverage-stat-num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--teal-400);
  line-height: 1.1;
  margin-bottom: .3rem;
}
.coverage-stat-label {
  font-size: .75rem;
  font-weight: 500;
  color: var(--text-onDark-soft);
  letter-spacing: .03em;
  text-transform: uppercase;
}

/* map wrapper */
.coverage-map-wrap {
  width: 100%;
  margin: 2rem 0 1rem;
  overflow: hidden;
}
.coverage-map-stage {
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
  position: relative;
  padding: clamp(.85rem, 1.8vw, 1.1rem);
  border: 1px solid rgba(78,199,209,.16);
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 22%, rgba(78,199,209,.12), transparent 46%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 28px 80px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255,255,255,.06);
  transform: translateY(0) scale(1);
  transition: transform .55s var(--ease), box-shadow .55s var(--ease), border-color .55s var(--ease);
}
.coverage-map-stage::before {
  content: '';
  position: absolute;
  inset: 10% 8% auto;
  height: 58%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(78,199,209,.18) 0%, rgba(78,199,209,0) 72%);
  filter: blur(26px);
  pointer-events: none;
}
.coverage-map-media {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 18px;
}
.coverage-map-image {
  width: 108%;
  margin-left: -4%;
  margin-top: -1%;
  height: auto;
  display: block;
  transform-origin: center bottom;
  filter: drop-shadow(0 26px 55px rgba(0, 0, 0, .24));
  animation: coverage-map-float 7s ease-in-out infinite;
}
.coverage-map-stage:hover {
  transform: translateY(-6px) scale(1.01);
  border-color: rgba(78,199,209,.3);
  box-shadow: 0 34px 90px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255,255,255,.08);
}
.coverage-map-caption {
  position: absolute;
  right: clamp(1rem, 2vw, 1.4rem);
  bottom: clamp(.75rem, 1.8vw, 1rem);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .55rem .9rem;
  border-radius: 999px;
  background: rgba(7,22,43,.74);
  border: 1px solid rgba(78,199,209,.22);
  color: #d8edf0;
  font-size: .76rem;
  font-weight: 500;
  letter-spacing: .01em;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.coverage-map-dot {
  width: .6rem;
  height: .6rem;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 0 .28rem rgba(198,242,78,.16);
}

@keyframes coverage-map-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@media (prefers-reduced-motion: reduce) {
  .coverage-map-image {
    animation: none;
  }

  .coverage-pin-marker,
  .coverage-pin-marker::after {
    animation: none;
  }

  .coverage-map-stage {
    transition: none;
  }
}

@media (max-width: 767.98px) {
  .coverage-map-wrap {
    margin: 1.6rem 0 .9rem;
  }

  .coverage-map-stage {
    padding: .7rem;
    border-radius: 18px;
  }

  .coverage-map-media {
    border-radius: 14px;
  }

  .coverage-pin-marker {
    width: .68rem;
    height: .68rem;
  }

  .coverage-pin-marker::after {
    height: 14px;
  }

  .coverage-pin-label {
    font-size: .64rem;
    padding: .22rem .45rem;
  }

  .coverage-map-caption {
    position: static;
    margin-top: .65rem;
    justify-content: center;
    text-align: center;
    border-radius: 16px;
  }
}
