:root {
  --g: #6EC286;
  --g2: #4fa36a;
  --g-glow: rgba(110,194,134,0.3);
  --g-dim: rgba(110,194,134,0.08);
  --dark: #0B182E;
  --darker: #060e1c;
  --panel: #0d1f3a;
  --panel2: #112240;
  --border: rgba(110,194,134,0.14);
  --border-bright: rgba(110,194,134,0.35);
  --text: #b8cde8;
  --text-dim: #516a8a;
  --white: #f0f6ff;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Barlow',sans-serif;background:var(--darker);color:var(--text);overflow-x:hidden}

/* CURSOR */
body { cursor: none; }
#cursor {
  position: fixed; width: 7px; height: 7px;
  background: var(--g); border-radius: 50%;
  pointer-events: none; z-index: 99999;
  transform: translate(-50%,-50%);
  mix-blend-mode: screen;
  box-shadow: 0 0 12px var(--g-glow), 0 0 24px var(--g-glow);
  transition: width .18s, height .18s;
}
#cursor-ring {
  position: fixed; width: 28px; height: 28px;
  border: 1px solid rgba(110,194,134,0.45);
  border-radius: 50%; pointer-events: none; z-index: 99998;
  transform: translate(-50%,-50%);
  transition: width .14s, height .14s, border-color .2s;
}

/* ── NAV ── */
nav {
  position: fixed; top: 0; inset-inline: 0; z-index: 1000;
  height: 68px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 5%;
  background: rgba(4,10,20,0.82);
  backdrop-filter: blur(24px) saturate(1.6);
  border-bottom: 1px solid var(--border);
  transition: height .3s, background .3s, box-shadow .3s;
}
nav.scrolled {
  height: 58px;
  background: rgba(4,10,20,0.96);
  box-shadow: 0 6px 40px rgba(0,0,0,0.5);
  border-bottom-color: var(--border2);
}
.nav-logo img { height: 36px; display: block; transition: transform .3s; }
.nav-logo:hover img { transform: scale(1.06)}
.nav-links { display: flex; align-items: center; gap: 1.8rem; list-style: none; }
.nav-links a {
  color: var(--text2); text-decoration: none;
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.76rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: color .2s; position: relative;
}
.nav-links a::after {
  content:''; position: absolute; left: 0; bottom: -4px;
  width: 0; height: 1px; background: var(--g);
  transition: width .28s;
}
.nav-links a:hover { color: var(--g); }
.nav-links a:hover::after { width: 100%; }
.nav-cta {
  padding: 7px 18px !important;
  border: 1px solid var(--g) !important;
  color: var(--g) !important;
  border-radius: var(--r) !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 0.68rem !important;
  transition: all .22s !important;
}
.nav-cta::after { display: none !important; }
.nav-cta:hover { background: var(--g) !important; color: var(--darker) !important; box-shadow: 0 0 22px var(--g-glow) !important; }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px; }
.hamburger span { display: block; width: 22px; height: 1.5px; background: var(--g); border-radius: 2px; transition: .3s; }

/* ── NAV DROPDOWN ── */
.nav-btn {
  color: var(--text2);
  background: none;
  border: none;
  cursor: pointer;
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: color .2s;
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0;
}
.nav-btn::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 0;
  height: 1px;
  background: var(--g);
  transition: width .28s;
}
.nav-btn:hover { color: var(--g); }
.nav-btn:hover::after { width: calc(100% - 14px); }

/* Chevron arrow */
.chevron {
  display: inline-block;
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transition: transform .25s;
  margin-top: 1px;
  flex-shrink: 0;
}
.has-dropdown:hover .chevron { transform: rotate(180deg); }
.has-dropdown.open .dropdown { display: block; }

/* Dropdown wrapper */
.has-dropdown { position: relative; }

.dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(4,10,20,0.98);
  border: 1px solid var(--border2);
  border-radius: var(--r2);
  min-width: 210px;
  padding: 8px 0;
  backdrop-filter: blur(24px) saturate(1.6);
  z-index: 999;
  box-shadow: 0 20px 56px rgba(0,0,0,0.7), 0 0 0 1px rgba(110,194,134,0.04);
}

/* Top accent line — matches your card style */
.dropdown::before {
  content: '';
  position: absolute;
  top: 0; left: 18px; right: 18px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--g), transparent);
}

/* Small caret pointer */
.dropdown::after {
  content: '';
  position: absolute;
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 10px; height: 10px;
  background: rgba(4,10,20,0.98);
  border-left: 1px solid var(--border2);
  border-top: 1px solid var(--border2);
  rotate: 45deg;
}

.has-dropdown:hover .dropdown { display: block; }

/* Section labels inside dropdown */
.drop-label {
  display: block;
  padding: 8px 18px 5px;
  color: #abefc1;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
  margin-top: 6px;
}
.drop-label:first-child { margin-top: 0; }

/* Dropdown links */
.dropdown a {
  display: block;
  padding: 9px 18px;
  color: var(--text2);
  text-decoration: none;
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: all .2s;
  border-left: 2px solid transparent;
  position: relative;
}
.dropdown a::after { display: none; }
.dropdown a:hover {
  color: var(--g);
  background: var(--g-dim);
  border-left-color: var(--g);
  padding-left: 24px;
}

/* ── MOBILE: dropdowns stack open ── */
@media (max-width: 960px) {
  .nav-links.open .has-dropdown { width: 100%; }
  .nav-links.open .dropdown {
    display: block;
    position: static;
    transform: none;
    background: rgba(11,22,40,0.6);
    border: 1px solid var(--border);
    border-radius: var(--r);
    margin-top: 6px;
    box-shadow: none;
  }
  .nav-links.open .dropdown::before,
  .nav-links.open .dropdown::after { display: none; }
  .nav-links.open .nav-btn { width: 100%; justify-content: space-between; }
}

/* PAGE HERO */
.page-hero{padding:140px 5% 80px;position:relative;overflow:hidden;background:var(--dark);border-bottom:1px solid var(--border)}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(110,194,134,0.04) 0%,transparent 70%)}
.page-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(110,194,134,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(110,194,134,0.03) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}
.page-hero-inner{position:relative;z-index:2;max-width:700px}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-family:'Share Tech Mono',monospace;font-size:0.62rem;color:var(--text-dim);letter-spacing:0.15em;text-transform:uppercase}
.breadcrumb a{color:var(--text-dim);text-decoration:none;transition:color 0.2s}
.breadcrumb a:hover{color:var(--g)}
.breadcrumb span{color:var(--g)}
.page-tag{display:inline-flex;align-items:center;gap:10px;padding:5px 14px;background:rgba(110,194,134,0.06);border:1px solid var(--border-bright);border-radius:2px;font-family:'Share Tech Mono',monospace;font-size:0.65rem;color:var(--g);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:20px}
.page-tag::before{content:'';width:5px;height:5px;background:var(--g);border-radius:50%;animation:blink 1.4s ease-in-out infinite;box-shadow:0 0 8px var(--g)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.15}}
.page-h1{font-family:'Rajdhani',sans-serif;font-size:clamp(2.2rem,4vw,3.8rem);font-weight:700;color:var(--white);line-height:1.08;letter-spacing:0.02em;margin-bottom:16px}
.page-h1 em{color:var(--g);font-style:normal}
.page-sub{font-size:1rem;color:var(--text-dim);line-height:1.75;font-weight:300;max-width:540px}

/* SECTION BASE */
.s-label{font-family:'Share Tech Mono',monospace;font-size:0.65rem;color:var(--g);letter-spacing:0.3em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:12px}
.s-label::before{content:'';width:28px;height:1px;background:var(--g)}
.s-title{font-family:'Rajdhani',sans-serif;font-size:clamp(1.6rem,2.5vw,2.4rem);font-weight:700;color:var(--white);line-height:1.15;margin-bottom:14px;letter-spacing:0.02em}
.s-title em{color:var(--g);font-style:normal}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

/* CONTACT MAIN */
.contact-main{padding:80px 5%;background:var(--darker)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}

/* INFO SIDE */
.contact-info-title{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;color:var(--white);margin-bottom:10px;letter-spacing:0.04em;line-height:1.2}
.contact-info-title em{color:var(--g);font-style:normal}
.contact-info-sub{font-size:0.92rem;color:var(--text-dim);line-height:1.75;margin-bottom:36px;font-weight:300}
.c-details{display:flex;flex-direction:column;gap:14px;margin-bottom:40px}
.c-item{display:flex;align-items:flex-start;gap:14px;padding:18px;background:rgba(13,31,58,0.5);border:1px solid var(--border);border-radius:8px;transition:all 0.25s;cursor:default}
.c-item:hover{border-color:var(--border-bright);background:rgba(110,194,134,0.04)}
.c-ico{width:40px;height:40px;background:rgba(110,194,134,0.08);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.c-item-label{font-family:'Share Tech Mono',monospace;font-size:0.6rem;color:var(--g);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:3px}
.c-item-val,.c-item-val a{font-size:0.88rem;color:var(--text);font-weight:400;text-decoration:none;line-height:1.5}
.c-item-val a:hover{color:var(--g)}

/* OFFICE HOURS */
.hours-box{background:linear-gradient(135deg,var(--panel2),rgba(6,14,28,0.7));border:1px solid var(--border);border-radius:8px;padding:24px;margin-bottom:32px;position:relative;overflow:hidden}
.hours-box::before{content:'';position:absolute;top:0;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,var(--g),transparent)}
.hours-title{font-family:'Rajdhani',sans-serif;font-size:0.9rem;font-weight:700;color:var(--g);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:14px}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(110,194,134,0.07)}
.hours-row:last-child{border-bottom:none}
.hours-day{font-size:0.82rem;color:var(--text-dim);font-weight:300}
.hours-time{font-family:'Share Tech Mono',monospace;font-size:0.72rem;color:var(--g)}
.hours-badge{font-family:'Share Tech Mono',monospace;font-size:0.6rem;padding:2px 8px;background:rgba(110,194,134,0.1);border:1px solid rgba(110,194,134,0.3);border-radius:2px;color:var(--g)}

/* SOCIAL */
.social-row{display:flex;gap:10px}
.social-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--panel);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-size:0.8rem;font-family:'Rajdhani',sans-serif;letter-spacing:0.06em;text-transform:uppercase;text-decoration:none;transition:all 0.25s;font-weight:600}
.social-btn:hover{border-color:var(--border-bright);color:var(--g);background:rgba(110,194,134,0.04);transform:translateY(-2px)}
.social-btn img{width:18px;height:18px;object-fit:contain}

/* FORM SIDE */
.c-form{background:linear-gradient(150deg,var(--panel2),rgba(6,14,28,0.8));border:1px solid var(--border);border-radius:10px;padding:40px;position:relative;overflow:hidden}
.c-form::before{content:'';position:absolute;top:0;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,var(--g),transparent)}
.c-form-title{font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:6px;letter-spacing:0.06em;text-transform:uppercase}
.c-form-sub{font-size:0.8rem;color:var(--text-dim);margin-bottom:28px;font-weight:300}
.fg{margin-bottom:18px}
.fg label{display:block;font-family:'Share Tech Mono',monospace;font-size:0.6rem;color:var(--text-dim);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:7px}
.fg input,.fg textarea,.fg select{width:100%;background:rgba(6,14,28,0.9);border:1px solid var(--border);border-radius:5px;padding:11px 14px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.88rem;outline:none;transition:all 0.25s;-webkit-appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(110,194,134,0.08)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(81,106,138,0.6)}
.fg textarea{min-height:110px;resize:vertical}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
select option{background:var(--dark);color:var(--text)}
.form-btn{width:100%;padding:14px;background:var(--g);color:var(--darker);font-family:'Rajdhani',sans-serif;font-size:0.9rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;border:none;border-radius:5px;cursor:pointer;transition:all 0.25s;margin-top:6px;display:flex;align-items:center;justify-content:center;gap:8px}
.form-btn:hover{box-shadow:0 4px 24px rgba(110,194,134,0.35);transform:translateY(-1px)}
.form-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
input[name="botcheck"]{display:none}

/* WHY US STRIP */
.why-strip{padding:60px 5%;background:var(--dark);border-top:1px solid var(--border)}
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:36px}
.why-card{background:linear-gradient(135deg,var(--panel2),rgba(6,14,28,0.7));border:1px solid var(--border);border-radius:8px;padding:22px;transition:all 0.25s;cursor:default}
.why-card:hover{border-color:var(--border-bright);transform:translateY(-3px)}
.why-ico{font-size:1.5rem;margin-bottom:10px}
.why-card h4{font-family:'Rajdhani',sans-serif;font-size:0.9rem;font-weight:700;color:var(--g);margin-bottom:6px;letter-spacing:0.06em;text-transform:uppercase}
.why-card p{font-size:0.78rem;color:var(--text-dim);line-height:1.6;font-weight:300}

/* MAP SECTION */
.map-section{padding:30px 5% 80px;background:var(--darker)}
.map-box{background:linear-gradient(135deg,var(--panel2),rgba(6,14,28,0.8));border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative}
.map-inner{padding:36px;display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.map-text h3{font-family:'Rajdhani',sans-serif;font-size:1.2rem;font-weight:700;color:var(--white);margin-bottom:8px;letter-spacing:0.04em}
.map-text p{font-size:0.85rem;color:var(--text-dim);line-height:1.65;font-weight:300;max-width:400px}
.map-address{font-family:'Share Tech Mono',monospace;font-size:0.72rem;color:var(--g);margin-top:12px;letter-spacing:0.08em;line-height:1.7}
.map-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 22px;background:rgba(110,194,134,0.08);border:1px solid var(--border-bright);border-radius:4px;color:var(--g);font-family:'Rajdhani',sans-serif;font-size:0.82rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;transition:all 0.25s}
.map-link:hover{background:rgba(110,194,134,0.15);transform:translateY(-2px)}

/* MAP VISUAL — iframe wrapper */
.map-visual{flex:1;min-width:260px;height:360px;border-radius:8px;overflow:hidden;border:1px solid var(--border);position:relative;cursor:none}
.map-visual iframe{width:100%;height:100%;border:0;display:block;border-radius:8px;pointer-events:none;transition:filter 0.3s}
.map-visual.unlocked iframe{pointer-events:auto}

/* Click-to-unlock overlay */
.map-overlay{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:rgba(6,14,28,0.55);backdrop-filter:blur(2px);border-radius:8px;transition:opacity 0.35s,visibility 0.35s;cursor:none}
.map-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.map-overlay-ico{font-size:2rem;animation:pinBounce 2s ease-in-out infinite}
.map-overlay-text{font-family:'Share Tech Mono',monospace;font-size:0.68rem;color:var(--g);letter-spacing:0.18em;text-transform:uppercase}
.map-overlay-hint{font-family:'Barlow',sans-serif;font-size:0.72rem;color:var(--text-dim);font-weight:300}
@keyframes pinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Cursor ring label when over map */
#cursor-map-label{position:fixed;pointer-events:none;z-index:99997;font-family:'Share Tech Mono',monospace;font-size:0.55rem;color:var(--g);letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap;transform:translate(22px,-50%);opacity:0;transition:opacity 0.2s}
#cursor-map-label.show{opacity:1}

/* FOOTER */
footer{background:var(--darker);border-top:1px solid var(--border);padding:36px 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer-logo img{height:28px;opacity:0.8}
.footer-copy{font-size:0.77rem;color:var(--text-dim)}
.footer-copy strong{color:var(--g)}
.footer-nav{display:flex;gap:20px;list-style:none}
.footer-nav a{font-size:0.77rem;color:var(--text-dim);text-decoration:none;font-family:'Rajdhani',sans-serif;letter-spacing:0.06em;text-transform:uppercase;transition:color 0.2s}
.footer-nav a:hover{color:var(--g)}
.footer-socials{display:flex;gap:10px}
.fsoc{width:34px;height:34px;background:var(--panel);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:0.85rem;transition:all 0.25s}
.fsoc:hover{background:rgba(110,194,134,0.08);border-color:var(--border-bright);transform:translateY(-2px)}
.footer-socials img{width:22px;height:22px;object-fit:contain;display:block}

/* MOBILE */
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:40px}
  nav .nav-links{display:none}
  .hamburger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:68px;left:0;right:0;background:rgba(6,14,28,0.97);padding:20px;gap:14px;border-bottom:1px solid var(--border)}
  footer{flex-direction:column;text-align:center}
  .footer-nav{flex-wrap:wrap;justify-content:center}
  .fg-row{grid-template-columns:1fr}
  .map-inner{flex-direction:column}
  .map-visual{width:100%}
}
@media(max-width:600px){
  .contact-main{padding:60px 5%}
  .why-strip{padding:50px 5%}
  .c-form{padding:28px 20px}
}