/*
  Smart Traffic Solutions — dark + blue accent
  - Pure CSS3 (Grid/Flexbox)
  - Subtle gradients + glassmorphism
  - Motion respectful (prefers-reduced-motion)
*/

:root{
  --bg0:#050711;
  --bg1:#070A12;
  --panel:rgba(255,255,255,.06);
  --panel2:rgba(255,255,255,.08);
  --stroke:rgba(255,255,255,.10);
  --text:#EAF0FF;
  --muted:rgba(234,240,255,.72);
  --muted2:rgba(234,240,255,.55);

  --blue:#4EA3FF;
  --blue2:#2D7CFF;
  --cyan:#3EE0FF;

  --shadow:0 18px 55px rgba(0,0,0,.55);
  --shadow-soft:0 10px 30px rgba(0,0,0,.35);

  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px;

  --container: min(1120px, 92vw);

  --ease: cubic-bezier(.2,.8,.2,1);
  --ease2: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html,body{ height:100%; }
body{
  margin:0;
  background:
    radial-gradient(1200px 800px at 15% 10%, rgba(78,163,255,.15), transparent 55%),
    radial-gradient(900px 600px at 80% 30%, rgba(62,224,255,.08), transparent 45%),
    radial-gradient(700px 700px at 50% 90%, rgba(45,124,255,.10), transparent 50%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  color:var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.5;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }

.skip{
  position:absolute;
  left:-999px;
  top:10px;
  background: rgba(78,163,255,.18);
  border: 1px solid rgba(78,163,255,.35);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  z-index: 100;
}
.skip:focus{
  left: 12px;
  outline: none;
  box-shadow: 0 0 0 4px rgba(78,163,255,.18);
}

img{ max-width:100%; display:block; }
button, input, textarea{ font:inherit; color:inherit; }

.container{ width:var(--container); margin:0 auto; }

#bg-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:-2;
  opacity:.85;
}

/* Scroll progress */
.scroll-progress{
  position:fixed;
  top:0;
  left:0;
  right:0;
  height:2px;
  z-index:50;
  background:rgba(255,255,255,.05);
}
.scroll-progress__bar{
  height:100%;
  width:0%;
  background: linear-gradient(90deg, rgba(78,163,255,.0), rgba(78,163,255,.95), rgba(62,224,255,.95));
  box-shadow: 0 0 14px rgba(78,163,255,.55);
}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter: blur(12px);
  background: rgba(5,7,17,.55);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 220px;
}
.brand__logo{
  width:38px;
  height:38px;
  object-fit:contain;
  border-radius:10px;
  border:1px solid rgba(78,163,255,.35);
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}
.brand__mark{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:
    linear-gradient(140deg, rgba(78,163,255,.16), rgba(62,224,255,.08)),
    rgba(255,255,255,.04);
  border:1px solid rgba(78,163,255,.35);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight:700;
  letter-spacing:.6px;
}
.brand__text{
  font-weight:600;
  letter-spacing:.2px;
  opacity:.95;
}

.nav{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav__link{
  font-weight:500;
  color:var(--muted);
  padding:10px 12px;
  border-radius:12px;
  transition: color .25s var(--ease), background .25s var(--ease);
}
.nav__link:hover{
  color: var(--text);
  background: rgba(255,255,255,.04);
}

.header__cta{ display:inline-flex; }

.menu{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
  cursor:pointer;
  padding:10px 12px;
  gap:5px;
  flex-direction:column;
  justify-content:center;
}
.menu span{
  display:block;
  height:2px;
  width:100%;
  background: rgba(234,240,255,.85);
  border-radius:2px;
  transition: transform .25s var(--ease), opacity .25s var(--ease);
}
.menu[aria-expanded="true"] span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.menu[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu[aria-expanded="true"] span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

.mobile-nav{
  width:var(--container);
  margin:0 auto 12px auto;
  display:grid;
  gap:10px;
  padding:12px 0 6px 0;
}
.mobile-nav[hidden]{
  display:none;
}
.mobile-nav__link{
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background: rgba(255,255,255,.03);
  color:var(--muted);
}
.mobile-nav__link:hover{
  color:var(--text);
  border-color: rgba(78,163,255,.35);
}
.mobile-nav__cta{
  margin-top:4px;
}

/* Buttons */
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius: 16px;
  border:1px solid transparent;
  cursor:pointer;
  transition:
    transform .18s var(--ease),
    background .25s var(--ease),
    border-color .25s var(--ease),
    box-shadow .25s var(--ease);
  user-select:none;
  white-space:nowrap;
}
.button:active{ transform: translateY(1px) scale(.99); }

.button--primary{
  background: linear-gradient(135deg, rgba(78,163,255,.95), rgba(45,124,255,.95));
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 18px 50px rgba(45,124,255,.22);
}
.button--primary:hover{
  box-shadow: 0 22px 70px rgba(45,124,255,.33);
  transform: translateY(-1px);
}
.button--ghost{
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.10);
}
.button--ghost:hover{
  border-color: rgba(78,163,255,.40);
  background: rgba(78,163,255,.08);
  transform: translateY(-1px);
}
.button--sm{ padding:10px 14px; font-size:14px; }
.button--md{ padding:12px 16px; font-size:14px; }
.button--lg{ padding:14px 18px; font-size:15px; }
.button__icon{
  opacity:.95;
  transform: translateY(-.5px);
}

/* Hero */
.hero{
  position:relative;
  padding: 54px 0 60px 0;
}
.hero__inner{
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 28px;
  align-items: center;
  min-height: 64vh;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color:var(--muted);
  font-size:13px;
}
.dot{
  width:8px; height:8px; border-radius:999px;
  background: var(--blue);
  box-shadow: 0 0 0 4px rgba(78,163,255,.18);
}

.hero__title{
  margin:16px 0 10px 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight:700;
  letter-spacing:-.6px;
  line-height:1.02;
  font-size: clamp(40px, 5.2vw, 62px);
}
.gradient{
  background: linear-gradient(90deg, var(--text), rgba(78,163,255,.95), rgba(62,224,255,.95));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero__tagline{
  margin: 0 0 10px 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  letter-spacing: -.4px;
  font-size: clamp(20px, 2.6vw, 28px);
}

.hero__sub{
  margin: 0;
  color: var(--muted);
  max-width: 52ch;
  font-size: 16px;
}
.hero__actions{
  margin-top: 22px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.hero__badges{
  margin-top: 22px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.badge{
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}
.badge__kicker{
  display:block;
  font-size: 12px;
  color: var(--muted2);
}
.badge__value{
  display:block;
  font-weight: 600;
  letter-spacing:.2px;
}

.hero__panel{
  display:grid;
  place-items: center;
}
.glass-panel{
  width:100%;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
  padding: 18px 18px 16px 18px;
  position: relative;
  overflow:hidden;
}
.glass-panel::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(500px 280px at 20% 10%, rgba(78,163,255,.24), transparent 55%),
    radial-gradient(380px 280px at 80% 35%, rgba(62,224,255,.12), transparent 55%);
  opacity:.65;
  pointer-events:none;
}
.glass-panel > *{ position:relative; z-index:1; }

.glass-panel__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
}
.chip{
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.pulse{
  width:10px; height:10px; border-radius:999px;
  background: var(--cyan);
  box-shadow: 0 0 0 0 rgba(62,224,255,.35);
  animation: pulse 2s infinite var(--ease);
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(62,224,255,.35); }
  70%{ box-shadow: 0 0 0 12px rgba(62,224,255,0); }
  100%{ box-shadow: 0 0 0 0 rgba(62,224,255,0); }
}

.mini-dashboard{
  display:grid;
  gap:12px;
}
.mini-dashboard__row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.metric{
  flex:1;
  min-width:160px;
  padding:12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.18);
}
.metric__label{ color: var(--muted2); font-size:12px; }
.metric__value{ font-weight:600; margin-top:4px; }

.mini-chart{
  height: 150px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(78,163,255,.05), rgba(0,0,0,.20));
  position: relative;
  overflow:hidden;
}
.mini-chart__line{
  position:absolute;
  inset:auto 0 0 0;
  height:100%;
  background:
    linear-gradient(90deg,
      rgba(78,163,255,0) 0%,
      rgba(78,163,255,.45) 15%,
      rgba(62,224,255,.55) 55%,
      rgba(78,163,255,0) 100%);
  mask-image: linear-gradient(180deg, transparent 10%, #000 60%);
  transform: translateX(-40%);
  animation: sweep 4.2s infinite var(--ease2);
}
.mini-chart__glow{
  position:absolute;
  inset:-40% -20% -60% -20%;
  background: radial-gradient(circle at 40% 60%, rgba(78,163,255,.14), transparent 52%);
  filter: blur(16px);
  animation: drift 6.8s infinite alternate var(--ease2);
}
@keyframes sweep{
  0%{ transform: translateX(-55%); opacity:.2; }
  30%{ opacity:.55; }
  100%{ transform: translateX(60%); opacity:.18; }
}
@keyframes drift{
  from{ transform: translate3d(-2%, 2%, 0); }
  to{ transform: translate3d(2%, -2%, 0); }
}

.pill{
  padding:10px 12px;
  border-radius: 999px;
  font-size:13px;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.glass-panel__bottom .note{
  margin-top: 14px;
  color: var(--muted2);
  font-size: 12px;
}

.scroll-hint{
  position:absolute;
  left:50%;
  bottom: 18px;
  transform: translateX(-50%);
  display:flex;
  align-items:center;
  gap:10px;
  color: rgba(234,240,255,.62);
  font-size: 12px;
}
.scroll-hint__mouse{
  width:22px;
  height:34px;
  border-radius:999px;
  border: 1px solid rgba(255,255,255,.20);
  position:relative;
}
.scroll-hint__mouse::after{
  content:"";
  width:4px; height:6px; border-radius:99px;
  background: rgba(234,240,255,.75);
  position:absolute;
  left:50%;
  top:8px;
  transform: translateX(-50%);
  animation: wheel 1.6s infinite var(--ease);
}
@keyframes wheel{
  0%{ transform: translate(-50%, 0); opacity:.9; }
  60%{ transform: translate(-50%, 10px); opacity:.3; }
  100%{ transform: translate(-50%, 0); opacity:.9; }
}

/* Sections */
.section{ padding: 72px 0; }
.section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:22px;
  margin-bottom: 26px;
}
.section__titlewrap{ max-width: 68ch; }
.section__title{
  margin:0;
  font-family:"Space Grotesk", Inter, sans-serif;
  letter-spacing:-.4px;
  font-size: clamp(26px, 3.0vw, 38px);
}
.section__sub{
  margin:10px 0 0 0;
  color: var(--muted);
}

.section__meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.meta-card{
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  backdrop-filter: blur(12px);
}
.meta-card__label{ font-size:12px; color: var(--muted2); }
.meta-card__value{ margin-top:4px; font-weight:600; }

/* Service cards (unique: gradient border + tilt-ready) */
.services-grid{
  display:grid;
  gap: 14px;
  grid-template-columns: repeat(12, 1fr);
}
.service-card{
  grid-column: span 3;
  position:relative;
  border-radius: var(--radius-lg);
  padding: 18px 18px 16px 18px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  overflow:hidden;
  transform-style: preserve-3d;
  transition: transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
  box-shadow: 0 0 0 rgba(0,0,0,0);
}
.service-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(450px 250px at 15% 12%, rgba(78,163,255,.22), transparent 55%),
    radial-gradient(350px 240px at 80% 36%, rgba(62,224,255,.12), transparent 55%),
    linear-gradient(140deg, rgba(78,163,255,.10), rgba(255,255,255,0));
  opacity:0;
  transition: opacity .25s var(--ease);
  pointer-events:none;
}
.service-card::after{
  /* gradient ring */
  content:"";
  position:absolute;
  inset:0;
  border-radius: var(--radius-lg);
  padding:1px;
  background: linear-gradient(135deg, rgba(78,163,255,.60), rgba(62,224,255,.12), rgba(255,255,255,.05));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity:.0;
  transition: opacity .25s var(--ease);
  pointer-events:none;
}

.service-card:hover{
  border-color: rgba(78,163,255,.22);
  background: rgba(255,255,255,.035);
  transform: translateY(-4px);
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}
.service-card:hover::before{ opacity:.9; }
.service-card:hover::after{ opacity: 1; }

.service-card--tmc{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/TMC.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--tmc:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/TMC.jpeg");
}

.service-card--junction{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Junction.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--junction:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Junction.jpeg");
}

.service-card--linkcounts{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Link.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--linkcounts:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Link.jpeg");
}

.service-card--queue{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Q.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--queue:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/Q.jpeg");
}

.service-card--parking{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/PK.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--parking:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/PK.jpeg");
}

.service-card--pedestrian{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/P.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--pedestrian:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/P.jpeg");
}

.service-card--illegal{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/I.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--illegal:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/I.jpeg");
}

.service-card--drone{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/D.jpeg");
  background-size: cover;
  background-position: center;
}
.service-card--drone:hover{
  background-image:
    linear-gradient(180deg, rgba(6,10,20,.65), rgba(6,10,20,.35)),
    url("../assets/D.jpeg");
}

.service-card__icon{
  width:42px;
  height:42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  color: rgba(234,240,255,.92);
  background: rgba(0,0,0,.24);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 12px 24px rgba(0,0,0,.25);
}
.service-card__icon svg{ width:22px; height:22px; color: rgba(78,163,255,.95); }
.service-card__title{
  margin: 14px 0 8px 0;
  font-size: 16px;
  letter-spacing: .1px;
}
.service-card__desc{
  margin:0;
  color: var(--muted);
  font-size: 14px;
}

/* Stats */
.stats-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.stat-card{
  grid-column: span 3;
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  backdrop-filter: blur(14px);
}
.stat-card__label{
  color: var(--muted2);
  font-size: 13px;
}
.stat-card__value{
  margin-top: 10px;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 34px;
  letter-spacing: -.5px;
}

/* Timeline */
.timeline{
  position:relative;
  display:grid;
  gap:14px;
  padding-left: 22px;
}
.timeline__line{
  position:absolute;
  left: 10px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: linear-gradient(180deg, rgba(78,163,255,.0), rgba(78,163,255,.45), rgba(62,224,255,.0));
}
.timeline__item{
  position:relative;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  padding: 18px 18px 16px 18px;
}
.timeline__dot{
  position:absolute;
  left: -18px;
  top: 22px;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: rgba(78,163,255,.92);
  box-shadow: 0 0 0 5px rgba(78,163,255,.18);
}
.timeline__content h3{
  margin: 0 0 8px 0;
  font-size: 16px;
}
.timeline__content p{
  margin:0;
  color: var(--muted);
}

/* Contact */
.contact{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:start;
}
.contact__details{
  display:flex;
  justify-content: center;
  gap:40px;
  flex-wrap: wrap;
}
.detail{
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.detail__label{ font-size:12px; color: var(--muted2); }
.detail__value{ margin-top:4px; font-weight:600; }

.callout{
  margin-top: 18px;
  padding: 14px 14px;
  border-radius: 18px;
  border: 1px solid rgba(78,163,255,.20);
  background: rgba(78,163,255,.06);
}
.callout__title{ font-weight:600; }
.callout__text{ margin-top:6px; color: var(--muted); font-size: 13px; }

.form{
  padding: 18px;
}
.form__row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.field{
  display:grid;
  gap: 8px;
}
.field__label{ font-size: 13px; color: var(--muted2); }
.field__input{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  padding: 12px 12px;
  outline: none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field__input::placeholder{ color: rgba(234,240,255,.35); }
.field__input:focus{
  border-color: rgba(78,163,255,.55);
  box-shadow: 0 0 0 4px rgba(78,163,255,.15);
}
.field__input--area{ resize: vertical; min-height: 140px; }

.field__error{
  min-height: 16px;
  font-size: 12px;
  color: rgba(255,140,140,.95);
}

.form__actions{
  margin-top: 14px;
  display:flex;
  align-items:center;
  gap: 14px;
  flex-wrap:wrap;
}
.form__fineprint{
  margin:0;
  color: var(--muted2);
  font-size: 12px;
  max-width: 48ch;
}
.form__status{
  margin-top: 12px;
  color: var(--muted);
  font-size: 13px;
}

/* Footer */
.footer{
  padding: 34px 0;
}
.footer__inner{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 22px;
}
.brand--footer .brand__mark{ width:34px; height:34px; border-radius:12px; }
.footer__tagline{ margin:10px 0 0 0; color: var(--muted); }
.footer__right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.footer__link{ color: var(--muted); }
.footer__link:hover{ color: var(--text); }
.footer__divider{ color: rgba(234,240,255,.35); }
.footer__muted{ color: rgba(234,240,255,.55); }

/* Reveal on scroll */
.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .6s var(--ease2), transform .6s var(--ease2);
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 980px){
  .hero__inner{ grid-template-columns: 1fr; }
  .hero{ padding-top: 40px; }
  .section__head{ flex-direction:column; align-items:flex-start; }
  .section__meta{ justify-content:flex-start; }

  .contact{ grid-template-columns: 1fr; }
  .form__row{ grid-template-columns: 1fr; }
}
@media (max-width: 920px){
  .service-card{ grid-column: span 6; }
  .stat-card{ grid-column: span 6; }
}
@media (max-width: 620px){
  .nav{ display:none; }
  .header__cta{ display:none; }
  .menu{ display:flex; }
  .service-card{ grid-column: span 12; }
  .stat-card{ grid-column: span 12; }
  .scroll-hint{ display:none; }
}
.hero-video-box {
  position: relative;
  width: 100%;
  height: 260px;
  border-radius: 16px;
  overflow: hidden;
  margin-top: 15px;
}

.hero-video-box video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-video-box::after{
  content:" ";
  position: absolute;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.1),
    rgba(0,0,0,0.4)
  );
}
/* ===== ABOUT SECTION ===== */

.about {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 60px;
  align-items: center;
}

.about__points {
  margin-top: 30px;
  display: grid;
  gap: 12px;
  font-weight: 500;
  color: #b8c3d9;
}

.about__card {
  padding: 40px;
  border-radius: 20px;
}

.about__stats {
  margin-top: 30px;
  display: flex;
  gap: 40px;
}

.about__stat-number {
  font-size: 28px;
  font-weight: 700;
  color: #4da3ff;
  display: block;
}

.about__stat-label {
  font-size: 14px;
  color: #9aa7c2;
}

/* Responsive */

@media (max-width: 900px) {
  .about {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
/* ===== CONTACT INFO SECTION ===== */

.contact{
  display: flex;
  justify-content: center;
  align-items: center;
}
.contact_info {
  padding: 40px;
  border-radius: 20px;
  max-width: 500px;
}

.contactitem {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
}

.contactlabel {
  font-size: 14px;
  color: #9aa7c2;
  margin-bottom: 6px;
}

.contactvalue,
.contact_value {
  font-size: 16px;
  font-weight: 500;
  color: #ffffff;
}

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .reveal{ transition:none; transform:none; opacity:1; }
  .pulse, .mini-chart__line, .mini-chart__glow, .scroll-hint__mouse::after{ animation:none !important; }
  .button, .service-card, .nav__link{ transition:none; }
}
