/* ── CSS Custom Property for border rotation ── */
@property --border-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}


:root{
  --lime:      #C8FF00;
  --lime-dim:  rgba(200,255,0,.1);
  --lime-gw:   rgba(200,255,0,.22);
  --bg:        #0a0a0a;
  --card:      #0f1114;
  --card-dark: #0c1220;
  --surface:   #161a1e;
  --border:    rgba(255,255,255,.07);
  --bord-l:    rgba(200,255,0,.28);
  --white:     #ffffff;
  --grey:      #6b7280;
  --grey-lt:   #9ca3af;
  --f-h:       'Poppins', sans-serif;
  --f-s:       'Urbanist', sans-serif;
  --f-b:       'Nunito', sans-serif;
  --ease:      cubic-bezier(.4,0,.2,1);
  --spring:    cubic-bezier(.22,1,.36,1);
}


*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:var(--f-s);overflow-x:hidden}


/* ═══════════════════════════
   SHARED
═══════════════════════════ */
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}


/* ═══════════════════════════
   SECTION HEADER
═══════════════════════════ */
.sec-head{text-align:center;margin-bottom:56px}
.sec-label{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;
}
.s-dash{width:24px;height:2px;background:var(--lime);border-radius:2px}
.s-txt{
  font-family:var(--f-h);font-size:11px;font-weight:500;
  letter-spacing:3px;text-transform:uppercase;color:var(--lime);
}
.sec-title{
  font-family:var(--f-h);
  font-size:clamp(36px,5vw,60px);
  font-weight:600;color:var(--white);
  line-height:1;margin-bottom:12px;
}
.sec-title span{color:var(--lime)}
.sec-sub{
  font-family:var(--f-s);font-size:15px;
  color:var(--grey-lt);max-width:460px;margin:0 auto;line-height:1.7;
}


/* ═══════════════════════════
   CONTACT SECTION  — added more top padding for navbar gap
═══════════════════════════ */
.contact-section{padding:120px 0 0}


.contact-grid{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:24px;
  align-items:start;
}


/* ═══════════════════════════
   ANIMATED BORDER WRAPPER
═══════════════════════════ */
.form-card-wrapper{
  position:relative;
  border-radius:24px;
  padding:2px;
  background:conic-gradient(
    from var(--border-angle),
    #C8FF00    0%,
    #00ffcc   20%,
    #0088ff   38%,
    #cc00ff   55%,
    #ff4400   72%,
    #ffcc00   88%,
    #C8FF00  100%
  );
  animation:rotateBorder 5s linear infinite;
  box-shadow:0 0 28px rgba(200,255,0,.15), 0 0 60px rgba(0,136,255,.08);
  will-change: transform; 
}


@keyframes rotateBorder{
  to{ --border-angle: 360deg; }
}


/* inner card sits on top of the wrapper's gradient */
.form-card-wrapper .form-card{
  border:none;       /* gradient wrapper IS the border now */
  border-radius:22px;
}


/* ── FORM CARD ── */
.form-card{
  background:var(--card);
  border-radius:22px;
  padding:36px 32px;
  position:relative;overflow:hidden;
}


.form-card::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:22px 22px;opacity:.25;pointer-events:none;
}


.form-card::after{
  content:'';position:absolute;
  width:250px;height:180px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(200,255,0,.05),transparent 70%);
  top:-60px;left:-40px;pointer-events:none;
}


.form-head{
  position:relative;z-index:1;margin-bottom:28px;
}
.form-title{
  font-family:var(--f-h);font-size:26px;font-weight:600;
  color:var(--white);margin-bottom:6px;
}
.form-sub{
  font-family:var(--f-s);font-size:13.5px;color:var(--grey-lt);line-height:1.6;
}

.form-group{
  display:flex;flex-direction:column;gap:7px;
  position:relative;z-index:1;
  opacity:0;
  transform:translate3d(0, 18px, 0); 
  animation:fieldFadeUp .5s var(--spring) forwards;
}
@keyframes fieldFadeUp {
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0); 
  }
}

@keyframes trainRide {
  0% {
    transform: translate3d(0, 0, 0);   
    opacity: 0;
  }
  8% { 
    opacity: 1; 
  }
  88% { 
    opacity: 1; 
  }
  100% { 
    transform: translate3d(0, -240px, 0); 
    opacity: 0; 
  }
}

/* stagger delays for each group */
.form-group:nth-child(1)  { animation-delay:.08s }
.form-group:nth-child(2)  { animation-delay:.14s }
.form-group:nth-child(3)  { animation-delay:.20s }
.form-group:nth-child(4)  { animation-delay:.26s }
.form-group:nth-child(5)  { animation-delay:.32s }
.form-group:nth-child(6)  { animation-delay:.38s }
.form-group:nth-child(7)  { animation-delay:.44s }
.form-group:nth-child(8)  { animation-delay:.50s }
.form-group:nth-child(9)  { animation-delay:.56s }


.form-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:14px;margin-bottom:14px;
}
.form-group.full{grid-column:1/-1}


.f-label{
  font-family:var(--f-s);font-size:12px;font-weight:500;
  color:var(--grey-lt);letter-spacing:.3px;
  display:flex;align-items:center;gap:6px;
}
.f-label i{color:var(--lime);font-size:10px}


.f-input, .f-textarea, .f-select{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:10px;
  padding:13px 16px;
  font-family:var(--f-s);font-size:13.5px;
  color:var(--white);
  outline:none;
  transition:border-color .3s,background .3s,box-shadow .3s,transform .2s;
  width:100%;
}
.f-input::placeholder,.f-textarea::placeholder{color:var(--grey)}
.f-input:focus,.f-textarea:focus,.f-select:focus{
  border-color:rgba(200,255,0,.45);
  background:rgba(200,255,0,.03);
  box-shadow:0 0 0 3px rgba(200,255,0,.08), 0 4px 20px rgba(200,255,0,.06);
  transform:translateY(-1px);
}
/* subtle shimmer on hover for inputs */
.f-input:hover:not(:focus),.f-textarea:hover:not(:focus),.f-select:hover:not(:focus){
  border-color:rgba(255,255,255,.15);
  background:rgba(255,255,255,.05);
}


.f-textarea{resize:vertical;min-height:100px}

.f-select{
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none; /* iPhone ke liye zaroori hai */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:8px;
  padding-right:36px;
}
.f-select option{background:#111314;color:var(--white)}


/* phone row */
.phone-wrap{display:flex;gap:0}
.phone-code{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-right:none;
  border-radius:10px 0 0 10px;
  padding:13px 14px;
  font-family:var(--f-s);font-size:13.5px;color:var(--grey-lt);
  white-space:nowrap;display:flex;align-items:center;gap:6px;
  min-width:80px;
}
.phone-code i{font-size:11px}
.f-input.phone{border-radius:0 10px 10px 0}


/* ── SUBMIT BUTTON ── */
.btn-submit{
  width:100%;
  font-family:var(--f-b);font-size:13px;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;
  color:#000;background:var(--lime);
  border:none;border-radius:10px;
  padding:15px 24px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  cursor:pointer;margin-top:20px;
  position:relative;overflow:hidden;z-index:1;
  transition:box-shadow .3s,transform .2s;
}
.btn-submit::before{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.1);
  transform:scaleX(0);transform-origin:right;
  transition:transform .3s var(--ease);
}
.btn-submit:hover{box-shadow:0 0 32px var(--lime-gw);transform:translateY(-2px)}
.btn-submit:hover::before{transform:scaleX(1)}
.btn-submit span,.btn-submit i{position:relative;z-index:1}
.btn-submit i{transition:transform .3s}
.btn-submit:hover i{transform:translateX(4px)}


/* ripple on click */
.btn-submit:active::after{
  content:'';position:absolute;
  width:200%;height:200%;border-radius:50%;
  background:rgba(255,255,255,.2);
  top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0);
  animation:ripple .5s ease forwards;
}
@keyframes ripple{to{transform:translate(-50%,-50%) scale(1);opacity:0}}


/* ── RIGHT INFO CARD ── */
.info-card{
  background:var(--card-dark);
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  padding:32px 26px;
  display:flex;flex-direction:column;gap:0;
  position:relative;overflow:hidden;
}


.info-card::after{
  content:'';position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,255,0,.07),transparent 70%);
  top:-80px;right:-80px;pointer-events:none;
}


.info-hello{
  font-family:var(--f-h);font-size:22px;font-weight:600;
  color:var(--white);line-height:1.2;margin-bottom:28px;
  position:relative;z-index:1;
}
.info-hello span{color:var(--lime)}


/* WhatsApp big button */
.btn-whatsapp{
  display:flex;align-items:center;gap:14px;
  background:#25D366;
  border:none;border-radius:14px;
  padding:16px 20px;
  cursor:pointer;text-decoration:none;
  margin-bottom:24px;
  position:relative;z-index:1;
  transition:box-shadow .3s,transform .2s;
  overflow:hidden;
}
.btn-whatsapp::before{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.08);
  transform:scaleX(0);transform-origin:right;
  transition:transform .3s;
}
.btn-whatsapp:hover{box-shadow:0 0 28px rgba(37,211,102,.4);transform:translateY(-2px)}
.btn-whatsapp:hover::before{transform:scaleX(1)}


.wa-icon{
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:#fff;flex-shrink:0;
  position:relative;z-index:1;
}
.wa-text{position:relative;z-index:1}
.wa-label{font-family:var(--f-s);font-size:10px;color:rgba(255,255,255,.7);letter-spacing:.5px;margin-bottom:2px}
.wa-val{font-family:var(--f-h);font-size:16px;font-weight:600;color:#fff}


/* Contact rows */
.contact-items{display:flex;flex-direction:column;gap:12px;margin-bottom:26px;position:relative;z-index:1}


.c-item{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
  padding:13px 16px;
  transition:border-color .3s,background .3s;
  text-decoration:none;
}
.c-item:hover{border-color:var(--bord-l);background:var(--lime-dim)}


.c-icon{
  width:36px;height:36px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
}
.ic-lime{background:var(--lime-dim);border:1px solid rgba(200,255,0,.2);color:var(--lime)}
.ic-blue{background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.2);color:#60a5fa}
.ic-red {background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);color:#f87171}


.c-label{font-family:var(--f-s);font-size:10px;color:var(--grey);letter-spacing:.5px;text-transform:uppercase;margin-bottom:2px}
.c-val{font-family:var(--f-s);font-size:13px;color:var(--white);font-weight:500}


/* Divider */
.info-div{height:1px;background:rgba(255,255,255,.07);margin:20px 0;position:relative;z-index:1}


/* Connect / Socials */
.connect-label{
  font-family:var(--f-s);font-size:11px;color:var(--grey-lt);
  letter-spacing:1px;text-transform:uppercase;
  margin-bottom:14px;position:relative;z-index:1;
}
.socials-row{
  display:flex;gap:10px;flex-wrap:wrap;
  position:relative;z-index:1;
}
.soc{
  width:42px;height:42px;border-radius:10px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  color:var(--grey-lt);font-size:16px;
  text-decoration:none;cursor:pointer;
  transition:all .3s;
}
.soc.ig:hover{background:radial-gradient(ellipse at 30% 107%,#fdf497,#fd5949 45%,#d6249f 60%,#285AEB 90%);border-color:transparent;color:#fff;transform:translateY(-3px);box-shadow:0 0 20px rgba(214,36,159,.5)}
.soc.wa:hover{background:#25D366;border-color:transparent;color:#fff;transform:translateY(-3px);box-shadow:0 0 20px rgba(37,211,102,.5)}
.soc.yt:hover{background:#FF0000;border-color:transparent;color:#fff;transform:translateY(-3px);box-shadow:0 0 20px rgba(255,0,0,.5)}
.soc.li:hover{background:#0077B5;border-color:transparent;color:#fff;transform:translateY(-3px);box-shadow:0 0 20px rgba(0,119,181,.5)}
.soc.xtwit:hover{background:#111;border-color:rgba(255,255,255,.2);color:#fff;transform:translateY(-3px)}
.soc.tk:hover{background:#000;border-color:#69C9D0;color:#69C9D0;transform:translateY(-3px);box-shadow:0 0 20px rgba(105,201,208,.4)}


/* ═══════════════════════════
   LOCATION SECTION
═══════════════════════════ */
.location-section{padding:80px 0}


.location-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  align-items:stretch;
}


/* ── MAP CARD ── */
.map-card{
  border-radius:22px;
  overflow:hidden;
  position:relative;
  min-height:340px;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  transition:transform .35s var(--ease),box-shadow .35s;
}
.map-card:hover{transform:translateY(-5px);box-shadow:0 28px 70px rgba(0,0,0,.6)}

.map-iframe{
  width:100%;height:100%;
  border:none;display:block;
  min-height:340px;
  pointer-events: none; 
  transition: opacity .4s;
}
.map-card:hover .map-iframe{
  opacity: 0.9;
}


.map-overlay{
  position:absolute;
  bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(10,18,32,.98) 0%,rgba(10,18,32,.7) 55%,transparent 100%);
  padding:28px 24px 22px;
}


.map-pin{
  position:absolute;
  top:40%;left:48%;
  transform:translate(-50%,-50%);
  z-index:5;
  display:flex;align-items:center;justify-content:center;
}
.pin-dot{
  width:18px;height:18px;border-radius:50%;
  background:#4A90D9;
  border:3px solid #fff;
  box-shadow:0 0 0 0 rgba(74,144,217,.5);
  animation:pinPulse 2.5s ease infinite;
  position:relative;z-index:2;
}
@keyframes pinPulse{
  0%{box-shadow:0 0 0 0 rgba(74,144,217,.6)}
  70%{box-shadow:0 0 0 18px rgba(74,144,217,0)}
  100%{box-shadow:0 0 0 0 rgba(74,144,217,0)}
}
.pin-ring{
  position:absolute;
  width:44px;height:44px;border-radius:50%;
  background:rgba(74,144,217,.12);
  border:1px solid rgba(74,144,217,.3);
  animation:ringExpand 2.5s ease infinite;
}
@keyframes ringExpand{
  0%{transform:scale(.5);opacity:1}
  100%{transform:scale(1.8);opacity:0}
}


.map-loc-title{
  display:flex;align-items:center;gap:8px;
  font-family:var(--f-h);font-size:20px;font-weight:600;
  color:var(--white);margin-bottom:5px;
}
.map-loc-title i{color:var(--lime);font-size:16px}
.map-loc-sub{
  font-family:var(--f-s);font-size:13px;color:var(--grey-lt);letter-spacing:.3px;
}
.map-badge{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:10px;
  font-family:var(--f-b);font-size:10px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  color:#000;background:var(--lime);
  border-radius:6px;padding:4px 12px;
}


/* ── NAV CARD ── */
.nav-card{
  border-radius:22px;
  overflow:hidden;
  position:relative;
  min-height:340px;
  border:1px solid rgba(255,255,255,.08);
  background:#0c0e12;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  transition:transform .35s var(--ease);
}
.nav-card:hover{transform:translateY(-5px)}


.nav-map-bg{
  position:absolute;inset:0;
  background:
    repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 1px,transparent 60px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 1px,transparent 60px),
    linear-gradient(135deg,#0c0e12 0%,#0f1520 50%,#0c0e12 100%);
}


/* ── TRAIN TRACK ── */
.nav-route{
  position:absolute;
  right:25%;top:8%;bottom:8%;
  width:3px;
  background:linear-gradient(
    180deg,
    transparent 0%,
    rgba(50,220,180,.35) 15%,
    rgba(50,200,255,.3) 50%,
    rgba(50,220,180,.35) 85%,
    transparent 100%
  );
  border-radius:3px;
  box-shadow:none;
}
/* subtle tick marks on track */
.nav-route::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(
    180deg,
    transparent 0px,transparent 12px,
    rgba(255,255,255,.08) 12px,rgba(255,255,255,.08) 14px
  );
  border-radius:3px;
}


/* ── TRAIN ICON — bottom to top, very slow ── */
.train-icon{
  position:absolute;
  right:calc(25% - 11px);
  bottom:8%;                        /* starts at bottom */
  z-index:6;
  animation:trainRide 9s ease-in-out infinite;
  display:flex;flex-direction:column;align-items:center;
}


.train-body{
  width:22px;height:22px;
  background:#1a2a2a;
  border:1.5px solid rgba(50,220,180,.5);
  border-radius:5px 5px 3px 3px;
  position:relative;
  box-shadow:0 0 6px rgba(50,220,180,.2);
  display:flex;align-items:center;justify-content:center;
}
/* windows */
.train-body::before{
  content:'';position:absolute;
  top:4px;left:3px;right:3px;height:6px;
  background:rgba(50,220,180,.2);
  border-radius:2px;
  border:1px solid rgba(50,220,180,.3);
}
/* front light (top since going up) */
.train-body::after{
  content:'';position:absolute;
  top:-3px;left:50%;transform:translateX(-50%);
  width:6px;height:3px;
  background:rgba(200,255,220,.5);
  border-radius:2px 2px 0 0;
}


/* trail below train */
.train-trail{
  width:1.5px;
  height:20px;
  background:linear-gradient(0deg,transparent,rgba(50,220,180,.25));
  border-radius:2px;
  order:-1;          /* trail appears below the train body */
}



.nav-content{
  position:relative;z-index:5;
  padding:22px 22px 20px;
  display:flex;flex-direction:column;
  height:100%;min-height:340px;
}


.timeline{display:flex;flex-direction:column;gap:0;flex:1}


.tl-item{display:flex;align-items:flex-start;gap:14px;position:relative}


.tl-left{
  display:flex;flex-direction:column;align-items:center;
  flex-shrink:0;width:16px;padding-top:3px;
}


.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--white);
  border:2px solid rgba(255,255,255,.3);
  flex-shrink:0;
  transition:background .3s;
}
.tl-dot.active{background:var(--white);box-shadow:0 0 8px rgba(255,255,255,.5)}
.tl-dot.dim{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.15)}


.tl-line{
  width:1px;flex:1;
  border-left:2px dashed rgba(255,255,255,.2);
  margin:4px 0;min-height:28px;
}


.tl-info{padding-bottom:22px;flex:1}
.tl-title{
  font-family:var(--f-h);font-size:14px;font-weight:600;
  color:var(--white);margin-bottom:3px;
}
.tl-sub{font-family:var(--f-s);font-size:11px;color:var(--grey-lt);letter-spacing:.3px}
.tl-tag{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-b);font-size:9px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  color:#000;background:var(--lime);
  border-radius:4px;padding:3px 8px;margin-top:5px;
}


.nav-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.07);
}
.nav-eta-val{
  font-family:var(--f-h);font-size:32px;font-weight:600;
  color:var(--white);line-height:1;
}
.nav-eta-unit{font-family:var(--f-s);font-size:11px;color:var(--grey-lt);letter-spacing:.5px}
.nav-speed{display:flex;align-items:center;gap:6px}
.speed-dot{width:8px;height:8px;border-radius:50%;background:var(--white)}
.speed-val{font-family:var(--f-h);font-size:14px;font-weight:500;color:var(--white)}


/* ═══════════════════════════
   FAQ
═══════════════════════════ */
.faq-section{padding:0 0 100px}


.faq-list{
  max-width:780px;margin:0 auto;
  display:flex;flex-direction:column;gap:10px;
}


.faq-item{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  transition:border-color .3s;
}
.faq-item.open{border-color:rgba(200,255,0,.25)}


.faq-q{
  width:100%;display:flex;align-items:center;
  justify-content:space-between;gap:16px;
  padding:20px 22px;
  cursor:pointer;background:none;border:none;color:inherit;
  text-align:left;
}


.faq-q-txt{
  font-family:var(--f-h);font-size:16px;font-weight:500;
  color:var(--white);transition:color .3s;
}
.faq-item.open .faq-q-txt{color:var(--lime)}


.faq-icon{
  width:30px;height:30px;border-radius:8px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--grey-lt);
  flex-shrink:0;transition:all .3s;
}
.faq-item.open .faq-icon{
  background:var(--lime-dim);border-color:rgba(200,255,0,.25);
  color:var(--lime);transform:rotate(45deg);
}


.faq-body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-body{max-height:200px}


.faq-a{
  padding:0 22px 20px;
  font-family:var(--f-s);font-size:14px;
  color:var(--grey-lt);line-height:1.75;
  border-top:1px solid rgba(255,255,255,.05);
  padding-top:16px;
}


/* ═══════════════════════════
   RESPONSIVE
═══════════════════════════ */
@media(max-width:900px){
  .wrap{padding:0 28px}
  .contact-grid{grid-template-columns:1fr}
  .location-grid{grid-template-columns:1fr}
  .map-card,.nav-card{min-height:300px}
}
@media(max-width:600px){
  .wrap{padding:0 16px}
.contact-section{padding:130px 0 0 !important;} /* <--- LOL */  .location-section,.faq-section{padding:60px 0 80px}
  .form-card{padding:26px 20px}
  .info-card{padding:26px 20px}
  .form-row{grid-template-columns:1fr}
  .map-card,.nav-card{min-height:280px}
  .map-iframe{min-height:280px}
  .nav-content{min-height:280px}
  .nav-eta-val{font-size:26px}
}


@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}


.form-group:nth-child(5)  { animation-delay:.40s }
.form-group:nth-child(6)  { animation-delay:.46s }
.form-group:nth-child(7)  { animation-delay:.52s }
.form-group:nth-child(8)  { animation-delay:.58s }
.form-group:nth-child(9)  { animation-delay:.64s }

.sm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:all .3s}
.sm-overlay.on{opacity:1;visibility:visible}
.sm-popup{background:#0f1114;border:1px solid rgba(200,255,0,.2);border-radius:20px;padding:40px 32px;max-width:380px;width:100%;text-align:center;transform:scale(.9) translateY(20px);transition:all .4s cubic-bezier(.22,1,.36,1);opacity:0}
.sm-overlay.on .sm-popup{transform:scale(1) translateY(0);opacity:1}
.sm-ring{width:80px;height:80px;border-radius:50%;border:2px solid rgba(200,255,0,.3);background:rgba(200,255,0,.08);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;animation:smPop .5s cubic-bezier(.22,1,.36,1) .2s both}
.sm-ring i{font-size:34px;color:#C8FF00}
@keyframes smPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.sm-popup h3{font-family:'Poppins',sans-serif;font-size:22px;font-weight:600;color:#fff;margin-bottom:8px}
.sm-popup h3 span{color:#C8FF00}
.sm-popup p{font-family:'Urbanist',sans-serif;font-size:14px;color:#9ca3af;line-height:1.7;margin-bottom:26px}
.sm-ok{width:100%;background:#C8FF00;color:#000;font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;border:none;border-radius:10px;padding:14px;cursor:pointer;transition:box-shadow .25s,transform .2s}
.sm-ok:hover{box-shadow:0 0 24px rgba(200,255,0,.4);transform:translateY(-2px)}