/* ============================================================
   EmberHelix — Main Stylesheet
   File: css/style.css
============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Montserrat:wght@400;500;600;700;800;900&display=swap');

/* === RESET & ROOT === */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: #0A0D14;
  color: #fff;
  overflow-x: hidden;
  line-height: 1.6;
}
:root {
  --or:    #E8600A;
  --or2:   #FF7322;
  --amber: #F5A623;
  --cyan:  #00C8FF;
  --dark:  #0A0D14;
  --dark2: #0F1520;
  --dark3: #141B2A;
  --card:  #111827;
  --bd:    rgba(255,255,255,0.07);
  --bd-o:  rgba(232,96,10,0.25);
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; }

/* === ANNOUNCEMENT BAR === */
.topbar {
  background: linear-gradient(90deg,#C44A00,var(--or),#C44A00);
  background-size: 200% 100%;
  animation: barShift 4s ease infinite;
  padding: 10px 24px;
  display: flex; align-items: center; justify-content: center; gap: 24px;
  font-size: 13px; font-weight: 600; text-align: center; flex-wrap: wrap;
}
@keyframes barShift { 0%,100%{background-position:0%} 50%{background-position:100%} }
.topbar a {
  background: rgba(255,255,255,0.18); border: 1px solid rgba(255,255,255,0.4);
  padding: 4px 16px; border-radius: 100px; font-size: 12px; font-weight: 700; transition: .2s;
}
.topbar a:hover { background: rgba(255,255,255,0.35); }

/* === NAVBAR === */
nav {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(10,13,20,0.96);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--bd);
}
.nav-wrap {
  max-width: 1360px; margin: 0 auto; padding: 0 28px;
  height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.nav-logo { display: flex; flex-direction: column; align-items: flex-start; text-decoration: none; flex-shrink: 0; }
.nav-logo img {
  height: 44px; width: auto; object-fit: contain;
  filter: drop-shadow(0 0 8px rgba(232,96,10,0.2));
}
.nav-logo .tagline {
  font-size: 9px; letter-spacing: 2.5px; color: rgba(255,255,255,0.28);
  text-transform: uppercase; font-weight: 600; margin-top: 1px; white-space: nowrap;
}
.nav-links { display: flex; gap: 2px; list-style: none; align-items: center; }
.nav-links > li > a {
  color: rgba(255,255,255,0.65); font-size: 13px; font-weight: 600;
  letter-spacing: 0.5px; padding: 8px 13px; border-radius: 6px;
  display: block; transition: .2s; white-space: nowrap; text-transform: uppercase;
}
.nav-links > li > a:hover, .nav-links > li > a.active { color: var(--or); }
.nav-links > li > a.active { border-bottom: 2px solid var(--or); border-radius: 0; }
.nav-links > li { position: relative; }
.nav-links > li.hasdrop:hover .ndrop { opacity: 1; visibility: visible; transform: translateY(0); }
.ndrop {
  position: absolute; top: calc(100% + 8px); left: 0;
  background: #111827; border: 1px solid var(--bd); border-radius: 10px;
  box-shadow: 0 20px 60px rgba(0,0,0,.6); min-width: 230px; padding: 8px;
  opacity: 0; visibility: hidden; transform: translateY(8px); transition: .2s; z-index: 200;
}
.ndrop a {
  display: block; padding: 10px 14px; font-size: 13px; color: rgba(255,255,255,.6);
  border-radius: 7px; transition: .2s; font-weight: 500;
}
.ndrop a:hover { background: rgba(232,96,10,.1); color: #fff; }
.nav-right { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.nav-phone {
  font-size: 13px; font-weight: 700; color: #FF69B4; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}
.nav-phone .ph-icon { font-size: 16px; }
.nav-phone:hover { color: #ff8dc7; }
.btn-book {
  background: var(--or); color: #fff;
  padding: 10px 22px; border-radius: 7px;
  font-size: 13px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase;
  transition: .2s; white-space: nowrap;
  box-shadow: 0 4px 16px rgba(232,96,10,.4);
  display: inline-flex; align-items: center; gap: 7px;
}
.btn-book:hover { background: var(--or2); transform: translateY(-1px); box-shadow: 0 6px 24px rgba(232,96,10,.55); }
.btn-book.outline { background: transparent; border: 2px solid var(--or); color: var(--or); box-shadow: none; }
.btn-book.outline:hover { background: var(--or); color: #fff; }
.hbg { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 6px; cursor: pointer; }
.hbg span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: .3s; }

/* === HERO === */
#hero { position: relative; overflow: hidden; display: flex; flex-direction: column; }
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    linear-gradient(to right, rgba(10,13,20,0.92) 42%, rgba(10,13,20,0.15) 100%),
    linear-gradient(to bottom, rgba(10,13,20,0.05) 0%, rgba(10,13,20,0.9) 100%),
    url('https://images.unsplash.com/photo-1639762681485-074b7f938ba0?w=1800&q=80') center/cover no-repeat;
}
.hero-grid-lines {
  position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(0,200,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,.02) 1px, transparent 1px);
  background-size: 64px 64px;
}
.hero-main {
  flex: 1;
  max-width: 1360px; margin: 0 auto; padding: 70px 28px 24px;
  display: grid; grid-template-columns: 1fr 520px; gap: 40px; align-items: center;
  position: relative; z-index: 2; width: 100%;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(232,96,10,0.12); border: 1px solid rgba(232,96,10,0.3);
  padding: 6px 16px; border-radius: 4px; margin-bottom: 22px;
  font-size: 11px; font-weight: 700; letter-spacing: 2px; color: var(--or); text-transform: uppercase;
}
.ebdot { width: 7px; height: 7px; background: var(--or); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
h1.htitle {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(46px, 5.5vw, 80px);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -2px;
  margin-bottom: 22px;
}
h1.htitle .ot { color: var(--or); display: block; }
h1.htitle .wt { color: #fff; display: block; }
.hero-sub {
  font-size: 18px; color: rgba(255,255,255,0.62);
  margin-bottom: 10px; line-height: 1.55;
  font-family: 'Montserrat', sans-serif; font-weight: 500;
}
.hero-sub strong { color: var(--or); font-weight: 700; }
.hero-quals { display: flex; gap: 22px; margin: 18px 0 32px; flex-wrap: wrap; }
.hq { display: flex; align-items: center; gap: 7px; font-size: 14px; font-weight: 600; color: rgba(255,255,255,.72); }
.hq-ic { font-size: 18px; }
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.btn-hprimary {
  background: var(--or); color: #fff;
  padding: 15px 32px; border-radius: 7px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase;
  transition: .2s; display: inline-flex; align-items: center; gap: 9px;
  box-shadow: 0 6px 28px rgba(232,96,10,.45);
}
.btn-hprimary:hover { background: var(--or2); transform: translateY(-2px); box-shadow: 0 10px 36px rgba(232,96,10,.6); }
.btn-houtline {
  background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.35);
  padding: 15px 32px; border-radius: 7px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase;
  transition: .2s; display: inline-flex; align-items: center; gap: 9px;
}
.btn-houtline:hover { border-color: #fff; background: rgba(255,255,255,.08); }

/* Hero Canvas (particle animation) */
.hero-right { position: relative; display: flex; align-items: center; justify-content: center; }
#heroCanvas {
  width: 100%; height: 460px;
  border-radius: 16px;
  background: transparent;
}

/* 3 SERVICE MINI CARDS */
.hero-cards {
  position: relative; z-index: 2;
  max-width: 1360px; margin: 0 auto; padding: 0 28px 48px;
  display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; width: 100%;
}
.hsc {
  background: rgba(15,21,32,0.94);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px; padding: 22px 20px;
  transition: .3s; cursor: pointer;
  backdrop-filter: blur(12px);
  position: relative; overflow: hidden;
}
.hsc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; transition: .3s; }
.hsc-h::before { background: var(--cyan); }
.hsc-it::before { background: var(--cyan); }
.hsc-b::before { background: var(--or); }
.hsc:hover { transform: translateY(-4px); box-shadow: 0 20px 48px rgba(0,0,0,.5); border-color: rgba(255,255,255,.18); }
.hsc-top { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.hsc-icbox {
  width: 52px; height: 52px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; font-size: 26px; flex-shrink: 0;
}
.ic-cyan { background: rgba(0,200,255,.1); border: 1px solid rgba(0,200,255,.2); }
.ic-orange { background: rgba(232,96,10,.12); border: 1px solid rgba(232,96,10,.25); }
.hsc-brand { font-size: 9px; font-weight: 700; letter-spacing: 2px; color: rgba(255,255,255,.3); text-transform: uppercase; }
.hsc-name { font-size: 18px; font-weight: 800; letter-spacing: .3px; margin-top: 1px; }
.hsc-name.c { color: var(--cyan); } .hsc-name.o { color: var(--or); }
.hsc-sub { font-size: 12.5px; color: rgba(255,255,255,.45); margin-bottom: 14px; font-weight: 500; }
.hsc-list { list-style: none; display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.hsc-list li { font-size: 13px; color: rgba(255,255,255,.65); display: flex; align-items: center; gap: 8px; }
.ck { color: var(--or); font-weight: 800; flex-shrink: 0; }
.ck.cc { color: var(--cyan); }
.hsc-btn {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  width: 100%; padding: 9px; border-radius: 6px;
  font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; border: none; transition: .2s;
}
.hsc-btn-c { background: rgba(0,200,255,.12); color: var(--cyan); border: 1px solid rgba(0,200,255,.25); }
.hsc-btn-c:hover { background: rgba(0,200,255,.22); }
.hsc-btn-o { background: var(--or); color: #fff; }
.hsc-btn-o:hover { background: var(--or2); }

/* === STATS BAR === */
.stats-bar {
  background: var(--dark3);
  border-top: 1px solid var(--bd); border-bottom: 1px solid var(--bd);
  padding: 0 28px;
}
.stats-inner {
  max-width: 1360px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4,1fr);
}
.stat {
  display: flex; align-items: center; gap: 16px; padding: 24px 20px;
  border-right: 1px solid var(--bd); transition: .3s;
}
.stat:last-child { border-right: none; }
.stat:hover { background: rgba(232,96,10,.04); }
.stat-ic {
  width: 52px; height: 52px; border-radius: 10px;
  background: rgba(232,96,10,.1); border: 1px solid rgba(232,96,10,.2);
  display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0;
}
.stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 38px; font-weight: 900; line-height: 1; color: var(--or); letter-spacing: -1px;
}
.stat-num sup { font-size: 22px; }
.stat-label { font-size: 12px; color: rgba(255,255,255,.45); text-transform: uppercase; letter-spacing: .8px; margin-top: 3px; font-weight: 600; }
.hero-strip {
  background: var(--dark2); border-top: 1px solid var(--bd);
  padding: 18px 28px;
}
.strip-inner {
  max-width: 1360px; margin: 0 auto; width: 100%;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px;
}
.strip-text { font-size: 17px; font-weight: 700; }
.strip-text span { color: var(--or); }

/* === TICKER === */
.ticker-wrap { background: #080B12; border-bottom: 1px solid var(--bd); padding: 15px 0; overflow: hidden; }
.ticker-track { display: flex; animation: tickScroll 24s linear infinite; width: max-content; }
.ticker-item { display: flex; align-items: center; gap: 14px; padding: 0 36px; font-size: 11.5px; font-weight: 700; letter-spacing: 2px; color: rgba(255,255,255,.3); text-transform: uppercase; white-space: nowrap; }
.t-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--or); flex-shrink: 0; }
@keyframes tickScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* === SECTION COMMONS === */
section { padding: 88px 28px; position: relative; }
.si { max-width: 1360px; margin: 0 auto; }
.tag { display: inline-flex; align-items: center; gap: 10px; font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--or); margin-bottom: 12px; }
.tag::before { content: ''; display: block; width: 24px; height: 2px; background: var(--or); border-radius: 2px; }
.stitle { font-family: 'Montserrat', sans-serif; font-size: clamp(28px,3.5vw,44px); font-weight: 800; line-height: 1.1; letter-spacing: -0.8px; margin-bottom: 14px; }
.stitle span { color: var(--or); }
.ssub { font-size: 15.5px; color: rgba(255,255,255,.5); max-width: 580px; line-height: 1.75; font-weight: 400; }
.ch { text-align: center; } .ch .ssub { margin: 0 auto; }
.bg2 { background: var(--dark2); } .bg3 { background: var(--dark3); }

/* === SERVICES === */
#services { background: var(--dark2); }
.svc-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 48px; flex-wrap: wrap; gap: 20px; }
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-bottom: 20px; }
.svc-card {
  background: var(--card); border: 1px solid var(--bd); border-radius: 12px;
  padding: 30px 26px; position: relative; overflow: hidden; transition: .3s;
}
.svc-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg,var(--or),var(--amber)); opacity: 0; transition: .3s; }
.svc-card:hover { transform: translateY(-5px); box-shadow: 0 24px 56px rgba(0,0,0,.4); border-color: var(--bd-o); }
.svc-card:hover::after { opacity: 1; }
.svc-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(232,96,10,.1); border: 1px solid rgba(232,96,10,.2); color: var(--or); padding: 3px 10px; border-radius: 100px; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 16px; }
.svc-ico {
  width: 56px; height: 56px; border-radius: 12px; display: flex; align-items: center; justify-content: center;
  font-size: 28px; margin-bottom: 16px; animation: iconFloat 3s ease-in-out infinite;
}
@keyframes iconFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
.si-1{background:rgba(232,96,10,.12);animation-delay:0s} .si-2{background:rgba(0,200,255,.1);animation-delay:.35s}
.si-3{background:rgba(245,166,35,.1);animation-delay:.7s} .si-4{background:rgba(139,92,246,.1);animation-delay:1.05s}
.si-5{background:rgba(239,68,68,.1);animation-delay:1.4s} .si-6{background:rgba(6,182,212,.1);animation-delay:1.75s}
.svc-title { font-family: 'Montserrat', sans-serif; font-size: 20px; font-weight: 800; margin-bottom: 10px; letter-spacing: -.3px; }
.svc-desc { color: rgba(255,255,255,.48); font-size: 13.5px; line-height: 1.65; margin-bottom: 18px; }
.svc-list { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 20px; }
.svc-list li { font-size: 13px; color: rgba(255,255,255,.58); display: flex; align-items: flex-start; gap: 8px; }
.svc-list li::before { content: '✓'; color: var(--or); font-weight: 800; flex-shrink: 0; margin-top: 1px; }
.svc-learn { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: var(--or); letter-spacing: .8px; text-transform: uppercase; transition: .2s; }
.svc-learn:hover { gap: 10px; }
.svc-cta-box { text-align: center; padding: 20px; background: rgba(255,255,255,.02); border: 1px solid var(--bd); border-radius: 8px; font-size: 14px; color: rgba(255,255,255,.4); }
.svc-cta-box a { color: var(--or); font-weight: 700; }

/* === INDUSTRIES === */
#industries { background: var(--dark); }
.ind-wrap { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 40px; }
.ind-pill { padding: 9px 18px; border: 1px solid rgba(255,255,255,.09); border-radius: 5px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.5); cursor: pointer; transition: .2s; background: rgba(255,255,255,.02); display: flex; align-items: center; gap: 8px; }
.ind-pill:hover { border-color: var(--or); color: #fff; background: rgba(232,96,10,.07); }

/* === WHY US === */
#why { background: var(--dark2); }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; margin-top: 48px; align-items: start; }
.why-big { font-family: 'Montserrat', sans-serif; font-size: clamp(30px,3.5vw,46px); font-weight: 800; letter-spacing: -.8px; line-height: 1.1; margin-bottom: 18px; }
.why-big span { color: var(--or); }
.why-p { color: rgba(255,255,255,.48); font-size: 15px; line-height: 1.75; margin-bottom: 18px; }
.pillar { display: flex; gap: 14px; padding: 16px; background: rgba(255,255,255,.025); border: 1px solid var(--bd); border-radius: 10px; margin-bottom: 12px; transition: .3s; }
.pillar:hover { border-color: var(--bd-o); background: rgba(232,96,10,.04); transform: translateX(4px); }
.pl-ic { width: 46px; height: 46px; border-radius: 9px; background: rgba(232,96,10,.1); display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.pl-t { font-weight: 800; font-size: 15px; margin-bottom: 3px; letter-spacing: -.2px; }
.pl-d { font-size: 13px; color: rgba(255,255,255,.42); line-height: 1.55; }
.cmp { width: 100%; border-collapse: collapse; border-radius: 12px; overflow: hidden; box-shadow: 0 8px 40px rgba(0,0,0,.35); }
.cmp th,.cmp td { padding: 13px 16px; text-align: center; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.05); }
.cmp thead { background: var(--dark3); }
.cmp thead th { font-weight: 700; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.5); }
.cmp thead .em { background: rgba(232,96,10,.18); color: var(--or); }
.cmp tbody tr:hover td { background: rgba(255,255,255,.02); }
.cmp tbody td { background: rgba(14,19,32,.9); }
.cmp td.em { background: rgba(232,96,10,.04); }
.cmp .feat { text-align: left; color: rgba(255,255,255,.6); font-weight: 500; padding-left: 18px; }
.tick { color: #22C55E; font-weight: 800; } .cross { color: #EF4444; font-weight: 800; }

/* === PROCESS === */
#process { background: var(--dark); }
.proc-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; margin-top: 52px; position: relative; }
.proc-row::before { content: ''; position: absolute; top: 26px; left: 12%; right: 12%; height: 2px; background: linear-gradient(90deg,var(--or),var(--amber)); z-index: 0; }
.pstep { text-align: center; padding: 0 16px; position: relative; z-index: 1; }
.pcirc { width: 52px; height: 52px; border-radius: 50%; background: var(--dark2); border: 2px solid var(--or); display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; font-family: 'Montserrat', sans-serif; font-size: 20px; font-weight: 900; color: var(--or); transition: .3s; }
.pstep:hover .pcirc { background: var(--or); color: #fff; box-shadow: 0 0 0 8px rgba(232,96,10,.15); }
.ptitle { font-family: 'Montserrat', sans-serif; font-size: 16px; font-weight: 800; margin-bottom: 8px; letter-spacing: -.2px; }
.pdesc { font-size: 13px; color: rgba(255,255,255,.42); line-height: 1.65; padding: 0 4px; }

/* === PACKAGES === */
#packages { background: var(--dark2); }
.pkg-scroll { overflow-x: auto; margin-top: 40px; }
.pkg-t { width: 100%; border-collapse: collapse; min-width: 780px; }
.pkg-t th,.pkg-t td { padding: 13px 16px; text-align: center; border-bottom: 1px solid rgba(255,255,255,.05); font-size: 13.5px; }
.pkg-t .feat { text-align: left; color: rgba(255,255,255,.58); font-weight: 500; padding-left: 18px; }
.pkg-t thead th { font-weight: 700; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; padding: 18px 16px; background: var(--dark3); color: rgba(255,255,255,.45); }
.pkg-t thead .pop { background: rgba(232,96,10,.14); color: var(--or); border-bottom: 2px solid var(--or); }
.pkg-t tbody td { background: rgba(14,19,32,.9); }
.pkg-t tbody td.pop { background: rgba(232,96,10,.04); }
.pop-lbl { display: inline-block; background: var(--or); color: #fff; font-size: 9px; font-weight: 800; padding: 2px 8px; border-radius: 100px; letter-spacing: .5px; text-transform: uppercase; margin-bottom: 4px; }
.pkg-btn { background: var(--or); color: #fff; padding: 9px 18px; border-radius: 6px; font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; transition: .2s; }
.pkg-btn:hover { background: var(--or2); transform: translateY(-1px); }
.pkg-btn.ot { background: transparent; border: 1.5px solid rgba(255,255,255,.2); color: rgba(255,255,255,.55); }
.pkg-btn.ot:hover { border-color: var(--or); color: var(--or); }

/* === GUARANTEE === */
#guarantee { background: linear-gradient(135deg,#08050F,#0F0A05); border-top: 1px solid var(--bd); border-bottom: 1px solid var(--bd); }
.g-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-top: 48px; }
.g-card { text-align: center; padding: 30px 18px; border: 1px solid rgba(255,255,255,.06); border-radius: 10px; background: rgba(255,255,255,.02); transition: .3s; }
.g-card:hover { border-color: var(--bd-o); background: rgba(232,96,10,.04); transform: translateY(-3px); }
.g-ic { font-size: 42px; margin-bottom: 12px; display: block; }
.g-lbl { display: inline-block; background: rgba(232,96,10,.18); border: 1px solid rgba(232,96,10,.3); color: var(--or); padding: 3px 12px; border-radius: 100px; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 9px; }
.g-title { font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 800; margin-bottom: 7px; letter-spacing: -.3px; }
.g-desc { font-size: 13px; color: rgba(255,255,255,.42); line-height: 1.6; }

/* === TESTIMONIALS === */
#testi { background: var(--dark); }
.t-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 40px; }
.t-card { background: var(--card); border: 1px solid var(--bd); border-radius: 12px; padding: 26px; transition: .3s; position: relative; overflow: hidden; }
.t-card::before { content: '❝'; position: absolute; top: 14px; right: 18px; font-size: 60px; color: rgba(232,96,10,.08); font-family: serif; line-height: 1; }
.t-card:hover { border-color: var(--bd-o); box-shadow: 0 16px 40px rgba(0,0,0,.35); }
.t-stars { color: #F59E0B; font-size: 15px; letter-spacing: 2px; margin-bottom: 12px; }
.t-text { font-size: 14px; color: rgba(255,255,255,.58); line-height: 1.7; margin-bottom: 18px; font-style: italic; }
.t-auth { display: flex; align-items: center; gap: 12px; }
.t-av { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg,var(--or),var(--amber)); display: flex; align-items: center; justify-content: center; font-size: 17px; font-weight: 800; flex-shrink: 0; }
.t-name { font-weight: 700; font-size: 14px; }
.t-role { font-size: 12px; color: rgba(255,255,255,.32); margin-top: 1px; }
.t-score { margin-left: auto; font-size: 13px; font-weight: 800; color: var(--or); }

/* === FAQ === */
#faq { background: var(--dark2); }
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 40px; }
.faq-item { border: 1px solid var(--bd); border-radius: 9px; overflow: hidden; background: var(--card); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 15px 18px; cursor: pointer; font-weight: 700; font-size: 14px; transition: .2s; }
.faq-q:hover, .faq-q.open { background: rgba(232,96,10,.07); color: var(--or); }
.farr { font-size: 20px; transition: .3s; flex-shrink: 0; }
.faq-q.open .farr { transform: rotate(45deg); }
.faq-a { display: none; padding: 0 18px 14px; font-size: 13.5px; color: rgba(255,255,255,.48); line-height: 1.7; border-top: 1px solid var(--bd); }
.faq-a.open { display: block; }

/* === OFFICES SECTION === */
#offices { background: var(--dark3); }
.offices-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 40px; }
.office-card { background: var(--card); border: 1px solid var(--bd); border-radius: 14px; overflow: hidden; transition: .3s; }
.office-card:hover { border-color: var(--bd-o); transform: translateY(-4px); box-shadow: 0 20px 48px rgba(0,0,0,.4); }
.office-map { height: 200px; overflow: hidden; position: relative; background: #0D1525; }
.office-map iframe { width: 100%; height: 100%; border: none; filter: grayscale(20%) brightness(0.85); }
.office-info { padding: 20px 22px; }
.office-flag { font-size: 32px; margin-bottom: 8px; }
.office-country-code { font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--or); margin-bottom: 4px; }
.office-country { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 20px; letter-spacing: -.3px; margin-bottom: 12px; }
.office-detail { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 13.5px; color: rgba(255,255,255,.55); }
.office-detail a { color: rgba(255,255,255,.55); transition: .2s; }
.office-detail a:hover { color: var(--or); }
.office-detail .od-ic { font-size: 15px; flex-shrink: 0; }
.office-wa-btn { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 14px; width: 100%; padding: 10px; border-radius: 7px; background: rgba(37,211,102,.12); border: 1px solid rgba(37,211,102,.25); color: #25D366; font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; transition: .2s; }
.office-wa-btn:hover { background: rgba(37,211,102,.22); }

/* === CONTACT === */
#contact { background: var(--dark); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.35fr; gap: 56px; margin-top: 48px; align-items: start; }
.ci-head { font-family: 'Montserrat', sans-serif; font-size: clamp(26px,3vw,38px); font-weight: 800; letter-spacing: -.8px; line-height: 1.1; margin-bottom: 14px; }
.ci-head span { color: var(--or); }
.ci-sub { color: rgba(255,255,255,.45); font-size: 15px; line-height: 1.7; margin-bottom: 28px; }
.ci-item { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 18px; }
.ci-ico { width: 46px; height: 46px; background: rgba(232,96,10,.12); border: 1px solid rgba(232,96,10,.25); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0; }
.ci-lbl { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.28); }
.ci-val { font-size: 15px; font-weight: 700; color: #fff; margin-top: 1px; }
.ci-val a { color: #fff; } .ci-val a:hover { color: var(--or); }
.cform { background: var(--card); border: 1px solid var(--bd); border-radius: 14px; padding: 34px; }
.f2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fg { margin-bottom: 16px; }
.fg label { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 6px; }
.fg label .req { color: var(--or); }
.fg input,.fg select,.fg textarea {
  width: 100%; background: rgba(255,255,255,.04); border: 1.5px solid rgba(255,255,255,.09);
  border-radius: 8px; padding: 11px 13px; color: #fff; font-family: 'Inter', sans-serif; font-size: 14px;
  outline: none; transition: .2s; -webkit-appearance: none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus {
  border-color: var(--or); background: rgba(232,96,10,.05);
  box-shadow: 0 0 0 3px rgba(232,96,10,.1);
}
.fg input::placeholder,.fg textarea::placeholder { color: rgba(255,255,255,.18); }
.fg select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-color: rgba(255,255,255,.04); padding-right: 38px; cursor: pointer; }
.fg select option { background: #111827; color: #fff; }
.fg textarea { resize: vertical; min-height: 90px; }
.field-err { font-size: 11px; color: #FCA5A5; margin-top: 4px; display: none; }
.fsubmit {
  width: 100%; background: var(--or); color: #fff; border: none;
  padding: 15px; border-radius: 9px;
  font-family: 'Montserrat', sans-serif; font-size: 14px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase;
  cursor: pointer; transition: .2s;
  box-shadow: 0 6px 24px rgba(232,96,10,.3);
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.fsubmit:hover { background: var(--or2); transform: translateY(-2px); box-shadow: 0 10px 32px rgba(232,96,10,.5); }
.fsubmit:disabled { opacity: .6; transform: none; cursor: wait; }
.success-box { display: none; margin-top: 14px; background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.3); border-radius: 9px; padding: 14px; color: #86EFAC; font-size: 14px; text-align: center; font-weight: 600; animation: fadeIn .4s ease; }
.error-box { display: none; margin-top: 14px; background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.3); border-radius: 9px; padding: 14px; color: #FCA5A5; font-size: 14px; text-align: center; font-weight: 600; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.wa-note { text-align: center; margin-top: 12px; font-size: 12px; color: rgba(255,255,255,.25); }
.wa-note a { color: #25D366; font-weight: 700; }

/* === CTA BAND === */
.cta-band { background: linear-gradient(135deg,rgba(232,96,10,.14),rgba(245,166,35,.07)); border-top: 1px solid rgba(232,96,10,.2); border-bottom: 1px solid rgba(232,96,10,.2); padding: 56px 28px; }
.cta-in { max-width: 1360px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap; }
.cta-h { font-family: 'Montserrat', sans-serif; font-size: clamp(26px,3.5vw,46px); font-weight: 800; letter-spacing: -.8px; line-height: 1.1; }
.cta-h span { color: var(--or); }
.cta-meta { font-size: 13px; color: rgba(255,255,255,.3); margin-top: 8px; }
.cta-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* === FOOTER === */
footer { background: #050810; border-top: 1px solid var(--bd); padding: 60px 28px 26px; }
.fi { max-width: 1360px; margin: 0 auto; }
.ftop { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 44px; margin-bottom: 44px; }
.fb { display: flex; flex-direction: column; }
.fb .footer-logo { height: 42px; width: auto; object-fit: contain; display: block; margin-bottom: 10px; }
.fb .ft { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,.25); font-weight: 600; margin-bottom: 12px; }
.fb p { color: rgba(255,255,255,.32); font-size: 13.5px; line-height: 1.7; max-width: 300px; margin-bottom: 16px; flex: 1; }
.frating { display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: 8px; padding: 9px 14px; width: fit-content; }
.fstars { color: #F59E0B; font-size: 13px; }
.frt { font-size: 12px; color: rgba(255,255,255,.32); }
.frt strong { color: rgba(255,255,255,.65); }
.fcol h4 { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 16px; }
.fcol ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.fcol ul li a { color: rgba(255,255,255,.38); font-size: 13.5px; transition: .2s; display: flex; align-items: center; gap: 7px; }
.fcol ul li a:hover { color: var(--or); }
.fsoc-icons { display: flex; gap: 10px; margin-top: 14px; }
.fsoc-icons a { width: 36px; height: 36px; border-radius: 8px; border: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.35); text-decoration: none; font-size: 15px; font-weight: 700; transition: .2s; }
.fsoc-icons a:hover { border-color: var(--or); color: var(--or); }
.fbot { border-top: 1px solid rgba(255,255,255,.05); padding-top: 22px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px; }
.fbot p { color: rgba(255,255,255,.2); font-size: 13px; }

/* === WHATSAPP FLOAT === */
.wa-btn {
  position: fixed; bottom: 28px; right: 28px; z-index: 900;
  width: 60px; height: 60px; border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 28px rgba(37,211,102,.5);
  text-decoration: none; transition: .3s;
}
.wa-btn::before { content: ''; position: absolute; inset: -5px; border-radius: 50%; border: 2px solid rgba(37,211,102,.35); animation: waRing 2.5s ease-in-out infinite; }
@keyframes waRing { 0%,100%{transform:scale(1);opacity:.8} 50%{transform:scale(1.25);opacity:0} }
.wa-btn svg { width: 30px; height: 30px; fill: #fff; }
.wa-btn:hover { transform: scale(1.1); }
.wa-tooltip { position: absolute; right: 70px; top: 50%; transform: translateY(-50%); background: #fff; color: #1a1a1a; padding: 6px 12px; border-radius: 8px; font-size: 12px; font-weight: 700; white-space: nowrap; box-shadow: 0 4px 16px rgba(0,0,0,.2); opacity: 0; pointer-events: none; transition: .2s; }
.wa-btn:hover .wa-tooltip { opacity: 1; }

/* === MOBILE NAV === */
.mob-nav { display: none; position: fixed; inset: 0; background: rgba(5,8,15,.97); z-index: 999; flex-direction: column; align-items: center; justify-content: center; gap: 22px; backdrop-filter: blur(20px); }
.mob-nav.open { display: flex; }
.mob-nav a { color: #fff; font-size: 22px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; transition: .2s; font-family: 'Montserrat', sans-serif; }
.mob-nav a:hover { color: var(--or); }
.mob-close { position: absolute; top: 22px; right: 26px; background: none; border: none; color: #fff; font-size: 28px; cursor: pointer; }

/* === SCROLL REVEAL === */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-l { opacity: 0; transform: translateX(-24px); transition: opacity .55s ease, transform .55s ease; }
.reveal-l.visible { opacity: 1; transform: translateX(0); }
.reveal-r { opacity: 0; transform: translateX(24px); transition: opacity .55s ease, transform .55s ease; }
.reveal-r.visible { opacity: 1; transform: translateX(0); }

/* === RESPONSIVE === */
@media(max-width:1200px) {
  .hero-main { grid-template-columns: 1fr; }
  #heroCanvas { height: 300px; }
  .why-grid { grid-template-columns: 1fr; }
  .ftop { grid-template-columns: 1fr 1fr; gap: 28px; }
}
@media(max-width:1024px) {
  .hero-cards { grid-template-columns: 1fr 1fr; }
  .svc-grid { grid-template-columns: 1fr 1fr; }
  .g-grid { grid-template-columns: 1fr 1fr; }
  .t-grid { grid-template-columns: 1fr 1fr; }
  .offices-grid { grid-template-columns: 1fr 1fr; }
  .stats-inner { grid-template-columns: 1fr 1fr; }
  .stat { border-right: none; border-bottom: 1px solid var(--bd); }
}
@media(max-width:900px) {
  .nav-links, .nav-phone { display: none; }
  .hbg { display: flex; }
  .proc-row { grid-template-columns: 1fr 1fr; gap: 28px; }
  .proc-row::before { display: none; }
  .contact-grid { grid-template-columns: 1fr; }
  .faq-grid { grid-template-columns: 1fr; }
  .cta-in { flex-direction: column; }
  .offices-grid { grid-template-columns: 1fr; }
}
@media(max-width:640px) {
  section { padding: 60px 20px; }
  .hero-main { padding: 50px 20px 16px; }
  .hero-cards { grid-template-columns: 1fr; padding: 0 20px 40px; }
  .svc-grid { grid-template-columns: 1fr; }
  .t-grid { grid-template-columns: 1fr; }
  .g-grid { grid-template-columns: 1fr; }
  .ftop { grid-template-columns: 1fr; }
  .fbot { flex-direction: column; align-items: flex-start; }
  .f2 { grid-template-columns: 1fr; }
  h1.htitle { font-size: 44px; }
}
