
:root {
  /* Logo controls: increase/decrease these 3 values if needed */
  --header-logo-height: 82px;
  --header-logo-max-width: 360px;
  --header-logo-y: 0px;
  --hero-logo-width: 300px;
  --bg:#02040d;
  --cyan:#00d9ff;
  --blue:#1264ff;
  --violet:#7b2cff;
  --magenta:#f000ff;
  --text:#f8fbff;
  --muted:#a8b5c7;
  --line:rgba(255,255,255,.12);
  --glass:rgba(255,255,255,.065);
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:140px; }
body {
  font-family: Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
body:before {
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  background:
    radial-gradient(circle at 15% 15%, rgba(0,217,255,.18), transparent 28%),
    radial-gradient(circle at 85% 20%, rgba(240,0,255,.16), transparent 30%),
    radial-gradient(circle at 50% 90%, rgba(18,100,255,.18), transparent 35%),
    linear-gradient(180deg,#02040d 0%,#050914 45%,#02040d 100%);
}
body:after {
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(0,217,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,0,255,.04) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.65), transparent 75%);
}
a { color:inherit; text-decoration:none; }
.wrap { width:min(1180px, calc(100% - 38px)); margin:auto; }
.scanlines {
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  opacity:.22;
  background:repeating-linear-gradient(90deg, transparent 0 110px, rgba(255,255,255,.08) 111px, transparent 112px);
}
header {
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter:blur(18px);
  background:rgba(2,4,13,.68);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav {
  height:118px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
.brand { display:flex; align-items:center; min-width:380px; overflow:visible; }
.brand img {
  height: var(--header-logo-height);
  width: auto;
  max-width: var(--header-logo-max-width);
  object-fit: contain;
  transform: translateY(var(--header-logo-y));
  clip-path: none;
  filter: drop-shadow(0 0 18px rgba(160,210,255,.18));
}
nav { display:flex; gap:28px; color:#d8e2ef; font-size:14px; }
nav a:hover { color:var(--cyan); }
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 22px;
  border-radius:999px;
  font-weight:800;
  border:1px solid var(--line);
  transition:.22s ease;
  cursor:pointer;
}
.btn.primary {
  color:#02040d;
  border:0;
  background:linear-gradient(90deg,#e9fbff,#7ddcff,#5d7cff);
  box-shadow:0 18px 55px rgba(0,217,255,.16),0 10px 35px rgba(93,124,255,.12);
}
.btn.ghost { background:rgba(255,255,255,.055); }
.btn:hover { transform:translateY(-2px); }

.hero {
  min-height:calc(100vh - 126px);
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:58px;
  align-items:center;
  padding:70px 0;
}
.kicker {
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:#dffbff;
  font-size:14px;
  border:1px solid rgba(0,217,255,.25);
  background:rgba(0,217,255,.08);
  padding:10px 16px;
  border-radius:999px;
  margin-bottom:26px;
}
.kicker span {
  width:8px;
  height:8px;
  border-radius:99px;
  background:var(--cyan);
  box-shadow:0 0 18px var(--cyan);
}
h1 {
  font-size:clamp(44px,5.8vw,72px);
  line-height:.9;
  letter-spacing:-3px;
  font-weight:950;
}
.gradient-text {
  background:linear-gradient(90deg,var(--cyan),#52a8ff,var(--magenta));
  -webkit-background-clip:text;
  color:transparent;
}
.hero p {
  color:#c8d3e2;
  line-height:1.85;
  font-size:18px;
  max-width:650px;
  margin:28px 0 34px;
}
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }

.orbit-card {
  position:relative;
  min-height:500px;
  border-radius:38px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.10), transparent 12%),
    radial-gradient(circle at 25% 25%, rgba(80,140,255,.12), transparent 24%),
    radial-gradient(circle at 82% 70%, rgba(150,80,255,.10), transparent 26%),
    linear-gradient(145deg,rgba(7,13,30,.92),rgba(2,4,13,.86));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.025),0 32px 90px rgba(0,0,0,.46);
}
.orbit-card:before {
  content:"";
  position:absolute;
  inset:58px;
  border-radius:50%;
  border:1px solid rgba(180,210,255,.18);
  box-shadow:0 0 70px rgba(150,190,255,.08), inset 0 0 60px rgba(255,255,255,.035);
  transform:rotate(-18deg) skew(10deg);
}
.orbit-card:after {
  content:"";
  position:absolute;
  width:520px;
  height:175px;
  border:1px solid rgba(210,225,255,.24);
  border-left-color:rgba(120,170,255,.38);
  border-bottom-color:rgba(160,130,255,.28);
  border-radius:50%;
  left:-12px;
  top:162px;
  transform:rotate(-24deg);
  filter:drop-shadow(0 0 14px rgba(150,190,255,.16));
}
.logo-display {
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  padding:76px;
  text-align:center;
}
.logo-display img {
  width: min(var(--hero-logo-width), 64%);
  filter: drop-shadow(0 0 20px rgba(170,205,255,.22));
}

.orbit-card .space-dot {
  position:absolute;
  width:3px;
  height:3px;
  border-radius:50%;
  background:rgba(255,255,255,.72);
  box-shadow:0 0 12px rgba(255,255,255,.45);
}
.orbit-card .space-dot:nth-child(1){left:18%;top:22%}
.orbit-card .space-dot:nth-child(2){left:72%;top:18%;opacity:.55}
.orbit-card .space-dot:nth-child(3){left:84%;top:62%;opacity:.45}
.orbit-card .space-dot:nth-child(4){left:35%;top:76%;opacity:.5}
.orbit-card .space-dot:nth-child(5){left:58%;top:34%;opacity:.35}

.tag {
  position:absolute;
  border:1px solid rgba(220,235,255,.12);
  background:rgba(5,10,22,.72);
  border-radius:16px;
  padding:10px 12px;
  color:#d7e2f3;
  font-size:12px;
  backdrop-filter:blur(12px);
  animation: tagFloat 5.5s ease-in-out infinite;
}
.tag:nth-child(1){left:28px;top:45px}
.tag:nth-child(2){right:28px;top:90px}
.tag:nth-child(3){left:38px;bottom:54px}
.tag:nth-child(4){right:38px;bottom:42px}

.stats {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  padding:20px 0 70px;
}
.stat {
  border:1px solid var(--line);
  background:var(--glass);
  border-radius:26px;
  padding:24px;
}
.stat b { font-size:36px; color:var(--cyan); }
.stat p { margin-top:8px; color:var(--muted); font-size:14px; line-height:1.5; }

section { padding:82px 0; }
.section-head { max-width:790px; margin-bottom:38px; }
.eyebrow {
  color:var(--cyan);
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:12px;
  margin-bottom:14px;
}
.eyebrow.dark { color:#02040d; }
h2 {
  font-size:clamp(36px,5vw,58px);
  line-height:1;
  letter-spacing:-2.5px;
}
.section-head p,
.about p,
.work p {
  color:#c8d3e2;
  line-height:1.85;
  margin-top:20px;
}
.cards {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.card {
  position:relative;
  overflow:hidden;
  min-height:465px;
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border-radius:30px;
  padding:28px;
}
.card:before {
  content:"";
  position:absolute;
  inset:-1px;
  background:linear-gradient(135deg,rgba(0,217,255,.18),transparent 35%,rgba(240,0,255,.14));
  opacity:0;
  transition:.25s;
}
.card:hover:before { opacity:1; }
.card>* { position:relative; z-index:1; }
.icon {
  width:56px;
  height:56px;
  border-radius:20px;
  display:grid;
  place-items:center;
  margin-bottom:22px;
  background:rgba(0,217,255,.1);
  border:1px solid rgba(0,217,255,.2);
  font-size:25px;
}
.card h3 { font-size:24px; margin-bottom:14px; }
.card p,
.card li {
  color:#c7d2e2;
  line-height:1.75;
}
ul {
  list-style:none;
  margin-top:20px;
  display:grid;
  gap:10px;
}
li:before {
  content:"✓";
  color:var(--cyan);
  font-weight:900;
  margin-right:10px;
}

.about {
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:42px;
  align-items:center;
}
.founder-photo {
  position:relative;
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(0,217,255,.13),rgba(240,0,255,.09));
  border-radius:34px;
  padding:76px;
  overflow:hidden;
}
.founder-photo img {
  width:100%;
  display:block;
  border-radius:26px;
  aspect-ratio:3.7/5;
  object-fit:cover;
  object-position:center top;
  filter:saturate(1.05) contrast(1.04);
}
.photo-glow {
  position:absolute;
  inset:auto 20px 20px 20px;
  height:130px;
  background:linear-gradient(to top, rgba(0,217,255,.18), transparent);
  pointer-events:none;
  border-radius:26px;
}
.founder-content strong { color:white; }
.badges {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:13px;
  margin-top:26px;
}
.badge {
  border:1px solid var(--line);
  background:rgba(255,255,255,.055);
  border-radius:18px;
  padding:15px;
  color:#edf6ff;
}

.work-box {
  border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(0,217,255,.08),rgba(240,0,255,.06));
  border-radius:34px;
  padding:42px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:34px;
  align-items:center;
}
.chips {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.chip {
  border:1px solid var(--line);
  background:rgba(2,4,13,.55);
  border-radius:18px;
  padding:16px;
  color:#d6e3f5;
}

.booking-section {
  border-radius:34px;
  padding:44px;
  color:#02040d;
  background:linear-gradient(135deg,var(--cyan),#3d7bff,var(--magenta));
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:36px;
  align-items:start;
}
.booking-copy p {
  color:rgba(2,4,13,.78);
  line-height:1.8;
  margin-top:18px;
}
.mini-contact {
  display:grid;
  gap:10px;
  margin-top:28px;
  font-weight:800;
}
.booking-form {
  background:rgba(255,255,255,.9);
  border-radius:26px;
  padding:24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  box-shadow:0 24px 70px rgba(0,0,0,.18);
}
.booking-form label {
  display:grid;
  gap:8px;
  color:#07111f;
  font-size:12px;
  font-weight:900;
}
.booking-form .full { grid-column:1 / -1; }
.booking-form input,
.booking-form select,
.booking-form textarea {
  width:100%;
  border:1px solid rgba(2,4,13,.16);
  border-radius:15px;
  min-height:48px;
  padding:0 14px;
  font:inherit;
  background:white;
  color:#07111f;
  outline:none;
}
.booking-form textarea {
  padding:14px;
  min-height:120px;
  resize:vertical;
}
.booking-form input:focus,
.booking-form select:focus,
.booking-form textarea:focus {
  border-color:#1264ff;
  box-shadow:0 0 0 4px rgba(18,100,255,.12);
}
.btn.submit {
  grid-column:1 / -1;
  border:0;
  min-height:54px;
  color:white;
  background:#02040d;
}
.booking-form small {
  grid-column:1 / -1;
  color:#475569;
  text-align:center;
}

footer {
  padding:34px 0 60px;
  color:#78869a;
  text-align:center;
}

@media(max-width:980px){
  nav,.nav>.btn{display:none}
  .nav{height:90px}
  .brand img{width:300px;transform:scale(1.05)}
  .hero,.about,.work-box,.booking-section{grid-template-columns:1fr}
  .orbit-card{min-height:410px}
  .stats,.cards{grid-template-columns:1fr 1fr}
  h1{letter-spacing:-2px}
}
@media(max-width:560px){
  .wrap{width:min(100% - 28px,1180px)}
  .brand img{width:240px;transform:scale(1.02)}
  .hero{padding:45px 0}
  .stats,.cards,.badges,.chips,.booking-form{grid-template-columns:1fr}
  .booking-section{padding:28px}
  .tag{display:none}
  .logo-display img{width:min(260px,68%)}
}


/* Anchor positioning fix for sticky header */
section[id] {
  scroll-margin-top: 140px;
}

/* Overall entrance animation */
.hero-content,
.orbit-card,
.stat,
.card,
.founder-photo,
.founder-content,
.work-box,
.booking-section {
  animation: softReveal .85s ease both;
}
.orbit-card { animation-delay:.08s; }
.stat:nth-child(2), .card:nth-child(2) { animation-delay:.08s; }
.stat:nth-child(3), .card:nth-child(3) { animation-delay:.14s; }
.stat:nth-child(4) { animation-delay:.20s; }

@keyframes softReveal {
  from { opacity:0; transform:translateY(22px); }
  to { opacity:1; transform:translateY(0); }
}

/* Space motion layer */
.orbit-card {
  isolation:isolate;
}
.orbit-card:before {
  animation: orbitPulse 7s ease-in-out infinite alternate;
}
.orbit-card:after {
  animation: orbitFloat 9s ease-in-out infinite;
}
.logo-display img {
  animation: logoHover 6s ease-in-out infinite;
}
.tag {
  animation: tagFloat 5.5s ease-in-out infinite;
}
.tag:nth-child(2) { animation-delay:.7s; }
.tag:nth-child(3) { animation-delay:1.2s; }
.tag:nth-child(4) { animation-delay:1.8s; }
.orbit-card .space-dot {
  animation: starTwinkle 3.8s ease-in-out infinite alternate;
}
.orbit-card .space-dot:nth-child(2) { animation-delay:.6s; }
.orbit-card .space-dot:nth-child(3) { animation-delay:1.1s; }
.orbit-card .space-dot:nth-child(4) { animation-delay:1.7s; }
.orbit-card .space-dot:nth-child(5) { animation-delay:2.2s; }

@keyframes orbitPulse {
  from { transform:rotate(-18deg) skew(10deg) scale(.98); opacity:.55; }
  to { transform:rotate(-14deg) skew(10deg) scale(1.03); opacity:.95; }
}
@keyframes orbitFloat {
  0%,100% { transform:rotate(-24deg) translateY(0); }
  50% { transform:rotate(-20deg) translateY(-10px); }
}
@keyframes logoHover {
  0%,100% { transform:translateY(0) scale(1); }
  50% { transform:translateY(-8px) scale(1.025); }
}
@keyframes tagFloat {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(-8px); }
}
@keyframes starTwinkle {
  from { opacity:.25; transform:scale(.75); }
  to { opacity:.95; transform:scale(1.3); }
}

@media (prefers-reduced-motion: reduce) {
  *, *:before, *:after {
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* Founder section refinement */
.founder-content h2 {
  font-size: clamp(32px, 4.1vw, 48px);
  line-height: 1.04;
  letter-spacing: -1.8px;
}
.founder-content p {
  margin-top: 16px;
}
.about {
  align-items: center;
}

.card,
.stat,
.badge,
.chip {
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.card:hover,
.stat:hover,
.badge:hover,
.chip:hover {
  transform: translateY(-5px);
  border-color: rgba(210,225,255,.28);
}

@media(max-width:980px){
  html { scroll-padding-top:110px; }
  section[id] { scroll-margin-top:110px; }
}


/* Exact nav landing points */
.anchor-point {
  scroll-margin-top: 150px;
}

/* Founder photo: smaller frame gap, image dominates the card */
.founder-photo {
  padding: 6px !important;
  align-self: center;
  max-width: 470px;
  margin-inline: auto;
}
.founder-photo img {
  border-radius: 24px;
  aspect-ratio: 4/5 !important;
  width: 100%;
}
.photo-glow {
  inset: auto 8px 8px 8px;
  border-radius: 24px;
}

/* Founder title smaller + cleaner balance */
.founder-content h2 {
  font-size: clamp(28px, 3.45vw, 40px) !important;
  line-height: 1.08 !important;
  letter-spacing: -1.1px !important;
}
.founder-content p {
  font-size: 15.5px;
  line-height: 1.78;
}
.badges {
  margin-top: 20px;
}

/* Orbiting nodes / planet effect */
.orbit-nodes {
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
}
.node {
  position:absolute;
  width:12px;
  height:12px;
  border-radius:50%;
  background: radial-gradient(circle, #ffffff 0 15%, #c7ecff 20%, #7aa7ff 45%, rgba(122,167,255,.12) 72%);
  box-shadow: 0 0 18px rgba(210,235,255,.65), 0 0 42px rgba(80,140,255,.22);
  transform-origin: 190px 72px;
}
.node:after {
  content:"";
  position:absolute;
  inset:-7px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.22);
  opacity:.45;
}
.n1 { left:50%; top:50%; animation: planetOrbit1 9s linear infinite; }
.n2 { left:50%; top:50%; width:9px; height:9px; transform-origin:-165px 58px; animation: planetOrbit2 12s linear infinite reverse; opacity:.82; }
.n3 { left:50%; top:50%; width:7px; height:7px; transform-origin:120px -115px; animation: planetOrbit3 7s linear infinite; opacity:.72; }
.n4 { left:50%; top:50%; width:10px; height:10px; transform-origin:-95px -82px; animation: planetOrbit4 10.5s linear infinite; opacity:.88; }

.spark {
  position:absolute;
  width:0;
  height:0;
  border-radius:50%;
  background:white;
  box-shadow: 0 0 0 rgba(255,255,255,0);
  opacity:0;
}
.s1 { left:60%; top:42%; animation: collisionSpark1 9s ease-in-out infinite; }
.s2 { left:37%; top:58%; animation: collisionSpark2 12s ease-in-out infinite; }

@keyframes planetOrbit1 {
  from { transform: rotate(0deg) translateX(172px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(172px) rotate(-360deg); }
}
@keyframes planetOrbit2 {
  from { transform: rotate(0deg) translateX(148px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(148px) rotate(-360deg); }
}
@keyframes planetOrbit3 {
  from { transform: rotate(0deg) translateX(104px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(104px) rotate(-360deg); }
}
@keyframes planetOrbit4 {
  from { transform: rotate(0deg) translateX(128px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(128px) rotate(-360deg); }
}
@keyframes collisionSpark1 {
  0%, 42%, 48%, 100% { opacity:0; width:0; height:0; box-shadow:0 0 0 rgba(0,0,0,0); }
  45% { opacity:1; width:9px; height:9px; box-shadow:0 0 28px rgba(255,255,255,.9), 0 0 65px rgba(125,220,255,.55); }
}
@keyframes collisionSpark2 {
  0%, 58%, 64%, 100% { opacity:0; width:0; height:0; box-shadow:0 0 0 rgba(0,0,0,0); }
  61% { opacity:1; width:7px; height:7px; box-shadow:0 0 24px rgba(255,255,255,.9), 0 0 55px rgba(180,130,255,.5); }
}

/* Keep logo behind nodes, still visible */
.logo-display {
  z-index:1;
}
.floating-tags {
  position:relative;
  z-index:3;
}

@media(max-width:980px){
  .anchor-point { scroll-margin-top: 118px; }
  .founder-photo { max-width: 430px; }
  .node { transform-origin: 130px 50px; }
  @keyframes planetOrbit1 {
    from { transform: rotate(0deg) translateX(130px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(130px) rotate(-360deg); }
  }
  @keyframes planetOrbit2 {
    from { transform: rotate(0deg) translateX(112px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(112px) rotate(-360deg); }
  }
  @keyframes planetOrbit3 {
    from { transform: rotate(0deg) translateX(85px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(85px) rotate(-360deg); }
  }
  @keyframes planetOrbit4 {
    from { transform: rotate(0deg) translateX(100px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(100px) rotate(-360deg); }
  }
}

@media(max-width:560px){
  .anchor-point { scroll-margin-top: 105px; }
  .founder-photo { max-width: 360px; }
  .node, .spark { display:none; }
}

/* Responsive logo fit */
@media(max-width:980px){
  :root {
    --header-logo-height: 70px;
    --header-logo-max-width: 300px;
    --hero-logo-width: 260px;
  }
}
@media(max-width:560px){
  :root {
    --header-logo-height: 58px;
    --header-logo-max-width: 230px;
    --hero-logo-width: 220px;
  }
}


/* ===== PiKTeK V8 final logo fit using new tight logo ===== */
:root {
  --header-logo-height: 76px;
  --header-logo-max-width: 430px;
  --header-logo-y: 0px;
  --hero-logo-width: 310px;
}

.nav {
  height: 118px;
}
.brand {
  min-width: 420px !important;
  overflow: visible !important;
}
.brand img {
  height: var(--header-logo-height) !important;
  width: auto !important;
  max-width: var(--header-logo-max-width) !important;
  object-fit: contain !important;
  transform: translateY(var(--header-logo-y)) !important;
  clip-path: none !important;
  filter: drop-shadow(0 0 18px rgba(120,190,255,.22)) !important;
}

.logo-display img {
  width: min(var(--hero-logo-width), 66%) !important;
  height: auto !important;
  filter: drop-shadow(0 0 20px rgba(170,205,255,.22)) !important;
}

/* ===== Orbit tags forced visible and repositioned ===== */
.floating-tags {
  position: absolute !important;
  inset: 0 !important;
  z-index: 5 !important;
  pointer-events: none !important;
}
.tag {
  position: absolute !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border: 1px solid rgba(220,235,255,.16) !important;
  background: rgba(5,10,22,.78) !important;
  border-radius: 16px !important;
  padding: 10px 13px !important;
  color: #d7e2f3 !important;
  font-size: 12px !important;
  backdrop-filter: blur(12px);
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
  animation: tagFloat 5.5s ease-in-out infinite;
}
.tag-cloud { left: 28px !important; top: 42px !important; }
.tag-digital { right: 28px !important; top: 74px !important; }
.tag-auto { left: 44px !important; bottom: 64px !important; }
.tag-web { right: 42px !important; bottom: 62px !important; }

/* ===== More creative modern hover + motion layer ===== */
.btn {
  position: relative;
  overflow: hidden;
}
.btn:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.38), transparent);
  transform: translateX(-120%);
  transition: transform .55s ease;
}
.btn:hover:before {
  transform: translateX(120%);
}

.card:after {
  content: "";
  position: absolute;
  width: 120px;
  height: 120px;
  right: -45px;
  bottom: -45px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,217,255,.18), transparent 65%);
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;
}
.card:hover:after {
  opacity: 1;
  transform: scale(1.35);
}
.card:hover .icon {
  transform: rotate(-6deg) scale(1.08);
  box-shadow: 0 0 30px rgba(0,217,255,.16);
}
.icon {
  transition: transform .25s ease, box-shadow .25s ease;
}

.stat:hover b {
  text-shadow: 0 0 22px rgba(0,217,255,.38);
}
.chip:hover {
  background: rgba(255,255,255,.075) !important;
}
.chip:before {
  content: "✦";
  color: rgba(0,217,255,.85);
  margin-right: 8px;
}

.founder-photo:hover img {
  transform: scale(1.025);
}
.founder-photo img {
  transition: transform .45s ease, filter .45s ease;
}
.founder-photo:hover {
  box-shadow: 0 28px 90px rgba(0,217,255,.10), 0 20px 70px rgba(240,0,255,.08);
}

.booking-form input:hover,
.booking-form select:hover,
.booking-form textarea:hover {
  border-color: rgba(18,100,255,.35);
}

/* extra stars */
.orbit-card .space-dot {
  animation: starTwinkle 2.8s ease-in-out infinite alternate !important;
}

@media(max-width:980px){
  :root {
    --header-logo-height: 66px;
    --header-logo-max-width: 320px;
    --hero-logo-width: 265px;
  }
  .brand { min-width: 300px !important; }
  .tag-cloud { left: 18px !important; top: 34px !important; }
  .tag-digital { right: 18px !important; top: 62px !important; }
  .tag-auto { left: 24px !important; bottom: 54px !important; }
  .tag-web { right: 24px !important; bottom: 52px !important; }
}
@media(max-width:560px){
  :root {
    --header-logo-height: 54px;
    --header-logo-max-width: 230px;
    --hero-logo-width: 220px;
  }
  .brand { min-width: 230px !important; }
  .tag {
    display: none !important;
  }
}


/* ===== PiKTeK V9 header polish ===== */
:root {
  --header-logo-height: 86px;
  --header-logo-max-width: 470px;
  --hero-logo-width: 320px;
}

.nav {
  height: 128px;
}

.brand {
  gap: 16px !important;
  min-width: 560px !important;
}

.brand-copy {
  display: grid;
  gap: 4px;
  padding-left: 14px;
  border-left: 1px solid rgba(220,235,255,.16);
  line-height: 1.05;
}

.brand-copy strong {
  font-size: 15px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #f5fbff;
  text-shadow: 0 0 18px rgba(0,217,255,.20);
}

.brand-copy small {
  font-size: 11px;
  color: #9fb0c8;
  letter-spacing: .04em;
  white-space: nowrap;
}

.brand img {
  height: var(--header-logo-height) !important;
  max-width: var(--header-logo-max-width) !important;
}

@media(max-width:1100px){
  .brand-copy {
    display: none;
  }
  .brand {
    min-width: 360px !important;
  }
}

@media(max-width:980px){
  :root {
    --header-logo-height: 72px;
    --header-logo-max-width: 340px;
    --hero-logo-width: 270px;
  }
  .nav {
    height: 104px;
  }
}

@media(max-width:560px){
  :root {
    --header-logo-height: 58px;
    --header-logo-max-width: 250px;
    --hero-logo-width: 220px;
  }
  .nav {
    height: 90px;
  }
}


/* ===== PiKTeK V10 refinements ===== */

/* Header label update balance */
.brand-copy strong {
  color: #ffffff;
}

/* Interactive orbit tags with tooltip */
.tag {
  cursor: pointer;
  font-weight: 800;
  border: 1px solid rgba(220,235,255,.18) !important;
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.tag:hover,
.tag:focus {
  transform: translateY(-7px) scale(1.03);
  border-color: rgba(255,255,255,.36) !important;
  background: rgba(10,18,38,.92) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.28), 0 0 24px rgba(125,200,255,.14);
  outline: none;
}
.tag::after {
  content: attr(data-tip);
  position: absolute;
  width: 260px;
  left: 50%;
  bottom: calc(100% + 14px);
  transform: translateX(-50%) translateY(10px) scale(.96);
  padding: 14px 15px;
  border-radius: 18px;
  color: #eaf4ff;
  background:
    linear-gradient(145deg, rgba(12,20,42,.96), rgba(5,10,22,.94));
  border: 1px solid rgba(220,235,255,.16);
  box-shadow: 0 24px 65px rgba(0,0,0,.35), 0 0 35px rgba(0,217,255,.10);
  font-size: 12px;
  line-height: 1.55;
  font-weight: 600;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  white-space: normal;
  text-align: left;
  backdrop-filter: blur(16px);
}
.tag::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: calc(100% + 6px);
  width: 12px;
  height: 12px;
  transform: translateX(-50%) rotate(45deg) translateY(8px);
  background: rgba(12,20,42,.96);
  border-right: 1px solid rgba(220,235,255,.14);
  border-bottom: 1px solid rgba(220,235,255,.14);
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;
}
.tag:hover::after,
.tag:focus::after,
.tag:hover::before,
.tag:focus::before {
  opacity: 1;
}
.tag:hover::after,
.tag:focus::after {
  transform: translateX(-50%) translateY(0) scale(1);
}
.tag:hover::before,
.tag:focus::before {
  transform: translateX(-50%) rotate(45deg) translateY(0);
}
.tag-auto::after,
.tag-web::after {
  bottom: auto;
  top: calc(100% + 14px);
}
.tag-auto::before,
.tag-web::before {
  bottom: auto;
  top: calc(100% + 6px);
}

/* Founder section tighter and more symmetric */
.about {
  grid-template-columns: .92fr 1.08fr !important;
  gap: 28px !important;
}
.founder-photo {
  max-width: 440px !important;
}
.founder-content p {
  font-size: 15px !important;
  line-height: 1.68 !important;
  margin-top: 12px !important;
}
.founder-content h2 {
  font-size: clamp(27px, 3.2vw, 38px) !important;
}

/* Founder badges: smaller, bold, one-line when possible */
.badges {
  gap: 10px !important;
  margin-top: 16px !important;
}
.badge {
  font-size: 12.5px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  white-space: nowrap;
  padding: 12px 13px !important;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Solution chips: smaller, bold, one-line */
.chip {
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  white-space: nowrap;
  padding: 14px 14px !important;
  overflow: hidden;
  text-overflow: ellipsis;
}
.chips {
  gap: 10px !important;
}

/* Booking/contact creative circuit background */
.booking-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.28), transparent 18%),
    linear-gradient(135deg,#67e9ff,#4b76ff,#d936ff) !important;
}
.booking-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: .28;
  background:
    linear-gradient(90deg, transparent 0 42px, rgba(2,4,13,.45) 43px, transparent 44px),
    linear-gradient(0deg, transparent 0 42px, rgba(2,4,13,.38) 43px, transparent 44px);
  background-size: 86px 86px;
  mask-image: radial-gradient(circle at 70% 40%, black, transparent 72%);
}
.booking-section::after {
  content: "";
  position: absolute;
  right: -80px;
  top: -70px;
  width: 460px;
  height: 460px;
  z-index: -1;
  opacity: .34;
  background:
    radial-gradient(circle at center, transparent 0 35%, rgba(2,4,13,.55) 36% 37%, transparent 38% 52%, rgba(2,4,13,.42) 53% 54%, transparent 55%),
    conic-gradient(from 20deg, transparent 0 12%, rgba(2,4,13,.45) 12% 13%, transparent 13% 31%, rgba(2,4,13,.35) 31% 32%, transparent 32% 62%, rgba(2,4,13,.42) 62% 63%, transparent 63%);
  border-radius: 50%;
  animation: circuitSpin 18s linear infinite;
}
@keyframes circuitSpin {
  to { transform: rotate(360deg); }
}
.booking-form {
  position: relative;
  overflow: hidden;
}
.booking-form::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 15%, rgba(18,100,255,.08), transparent 20%),
    radial-gradient(circle at 88% 85%, rgba(240,0,255,.08), transparent 24%);
  pointer-events: none;
}

/* Better mobile wrapping */
@media(max-width:980px){
  .about {
    grid-template-columns: 1fr !important;
    gap: 26px !important;
  }
  .badge,
  .chip {
    white-space: normal;
  }
  .tag::after {
    width: 220px;
  }
}
@media(max-width:560px){
  .tag::after,
  .tag::before {
    display: none;
  }
}


/* ===== PiKTeK V11 fixes ===== */

/* Real orbit tooltip panel: not clipped above/below, always visible inside the card */
.orbit-tooltip {
  position: absolute;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%) translateY(10px);
  width: min(420px, calc(100% - 56px));
  z-index: 7;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(12,20,42,.94), rgba(5,10,22,.90));
  border: 1px solid rgba(220,235,255,.16);
  box-shadow: 0 24px 65px rgba(0,0,0,.32), 0 0 35px rgba(0,217,255,.10);
  color: #eaf4ff;
  opacity: .92;
  transition: opacity .25s ease, transform .25s ease, border-color .25s ease;
  backdrop-filter: blur(16px);
  pointer-events: none;
}
.orbit-tooltip.active {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  border-color: rgba(255,255,255,.26);
}
.orbit-tooltip strong {
  display: block;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.orbit-tooltip p {
  margin: 0;
  color: #b9c7da;
  font-size: 12.5px;
  line-height: 1.55;
}
.tag.active {
  border-color: rgba(255,255,255,.42) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.28), 0 0 30px rgba(125,200,255,.18);
}

/* Disable old pseudo tooltip so it doesn't get clipped */
.tag::before,
.tag::after {
  display: none !important;
  content: none !important;
}

/* Founder and solution tags: no ellipsis/dots */
.badge {
  font-size: 11.2px !important;
  font-weight: 850 !important;
  line-height: 1.18 !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  padding: 11px 10px !important;
  letter-spacing: -.15px;
}
.chip {
  font-size: 11.8px !important;
  font-weight: 850 !important;
  line-height: 1.12 !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  padding: 13px 11px !important;
  letter-spacing: -.1px;
}
.badges {
  grid-template-columns: 1fr 1fr !important;
}
.chips {
  grid-template-columns: 1fr 1fr !important;
}

/* Stronger animated electronic circuit in booking background */
.booking-section {
  position: relative;
  overflow: hidden;
}
.circuit-flow {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .82;
}
.c-line {
  position: absolute;
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(2,4,13,.46), rgba(255,255,255,.55), rgba(2,4,13,.38), transparent);
  border-radius: 999px;
  box-shadow: 0 0 18px rgba(255,255,255,.35);
  animation: circuitMove 4.5s linear infinite;
}
.l1 { width: 58%; left: 6%; top: 18%; }
.l2 { width: 46%; right: 8%; top: 36%; animation-delay: .7s; }
.l3 { width: 66%; left: 14%; bottom: 24%; animation-delay: 1.4s; }
.l4 { width: 40%; right: 18%; bottom: 12%; animation-delay: 2s; }

.c-line::before,
.c-line::after {
  content: "";
  position: absolute;
  width: 2px;
  height: 64px;
  background: linear-gradient(180deg, transparent, rgba(2,4,13,.38), rgba(255,255,255,.42), transparent);
  top: -31px;
  border-radius: 999px;
}
.c-line::before { left: 22%; }
.c-line::after { right: 18%; }

.c-pulse {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 18px rgba(255,255,255,.95), 0 0 45px rgba(2,4,13,.5);
  animation: pulseTravel 5s ease-in-out infinite;
}
.p1 { left: 10%; top: 18%; }
.p2 { left: 44%; top: 36%; animation-delay: 1s; }
.p3 { right: 20%; bottom: 24%; animation-delay: 2.1s; }

@keyframes circuitMove {
  from { background-position: -260px 0; filter: brightness(.95); }
  50% { filter: brightness(1.35); }
  to { background-position: 260px 0; filter: brightness(.95); }
}
@keyframes pulseTravel {
  0%, 100% { transform: translateX(0) scale(.9); opacity: .45; }
  45% { transform: translateX(180px) scale(1.25); opacity: 1; }
  65% { transform: translateX(240px) translateY(58px) scale(.9); opacity: .62; }
}

/* Keep form readable above circuit layer */
.booking-copy,
.booking-form {
  position: relative;
  z-index: 2;
}

@media(max-width:980px){
  .badge,
  .chip {
    white-space: normal !important;
    overflow: visible !important;
  }
  .orbit-tooltip {
    bottom: 22px;
    width: min(360px, calc(100% - 42px));
  }
}
@media(max-width:560px){
  .orbit-tooltip {
    display: none;
  }
  .c-line {
    opacity: .5;
  }
}


/* ===== PiKTeK V12: click-only orbit + motherboard communication layer ===== */

/* Click-only: remove hover trigger visuals, keep hover as simple affordance only */
.tag:hover {
  transform: translateY(-3px) scale(1.01) !important;
}
.tag:hover::before,
.tag:hover::after {
  display: none !important;
}
.tag.active {
  transform: translateY(-7px) scale(1.04) !important;
  background: rgba(10,18,38,.96) !important;
  border-color: rgba(255,255,255,.45) !important;
}

/* Make tooltip look like a selected info module */
.orbit-tooltip {
  min-height: 82px;
}
.orbit-tooltip.active {
  box-shadow:
    0 24px 65px rgba(0,0,0,.35),
    0 0 38px rgba(0,217,255,.14),
    inset 0 0 0 1px rgba(255,255,255,.04);
}

/* Motherboard/circuit communication visual */
.motherboard-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: .88;
  overflow: hidden;
}

.chip-core {
  position: absolute;
  right: 12%;
  top: 20%;
  width: 92px;
  height: 92px;
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(2,4,13,.36), rgba(2,4,13,.08)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.16) 0 2px, transparent 2px 10px);
  border: 2px solid rgba(2,4,13,.38);
  box-shadow:
    0 0 32px rgba(255,255,255,.22),
    inset 0 0 24px rgba(255,255,255,.12);
  animation: chipPulse 3.2s ease-in-out infinite;
}

.chip-core::before,
.chip-core::after {
  content: "";
  position: absolute;
  background: repeating-linear-gradient(90deg, rgba(2,4,13,.55) 0 4px, transparent 4px 10px);
  opacity: .55;
}
.chip-core::before {
  left: -34px;
  right: -34px;
  height: 10px;
  top: 50%;
  transform: translateY(-50%);
}
.chip-core::after {
  top: -34px;
  bottom: -34px;
  width: 10px;
  left: 50%;
  transform: translateX(-50%);
  background: repeating-linear-gradient(180deg, rgba(2,4,13,.55) 0 4px, transparent 4px 10px);
}

.trace {
  position: absolute;
  height: 3px;
  background: linear-gradient(90deg, rgba(2,4,13,.58), rgba(255,255,255,.6), rgba(2,4,13,.42));
  border-radius: 999px;
  box-shadow: 0 0 20px rgba(255,255,255,.25);
  opacity: .72;
}
.trace::after {
  content: "";
  position: absolute;
  right: -7px;
  top: -5px;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: rgba(255,255,255,.72);
  box-shadow: 0 0 22px rgba(255,255,255,.75), 0 0 40px rgba(2,4,13,.24);
}

.t1 { width: 42%; left: 8%; top: 24%; animation: traceGlow 3.8s ease-in-out infinite; }
.t2 { width: 34%; left: 18%; top: 44%; transform: rotate(90deg); transform-origin: left center; animation: traceGlow 4.4s ease-in-out infinite .4s; }
.t3 { width: 48%; left: 26%; top: 63%; animation: traceGlow 4.1s ease-in-out infinite .8s; }
.t4 { width: 30%; right: 14%; top: 58%; transform: rotate(90deg); transform-origin: right center; animation: traceGlow 4.9s ease-in-out infinite 1.2s; }
.t5 { width: 38%; left: 7%; bottom: 14%; animation: traceGlow 3.9s ease-in-out infinite 1.5s; }
.t6 { width: 28%; right: 25%; bottom: 31%; animation: traceGlow 4.7s ease-in-out infinite 1.8s; }

.node-dot {
  position: absolute;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: rgba(255,255,255,.78);
  box-shadow: 0 0 18px rgba(255,255,255,.8), 0 0 42px rgba(2,4,13,.24);
  animation: nodePulse 2.8s ease-in-out infinite;
}
.d1 { left: 8%; top: 23%; }
.d2 { left: 43%; top: 43%; animation-delay:.4s; }
.d3 { left: 26%; top: 62%; animation-delay:.8s; }
.d4 { right: 16%; top: 57%; animation-delay:1.1s; }
.d5 { left: 43%; bottom: 13%; animation-delay:1.5s; }

.data-packet {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 0 18px rgba(255,255,255,.9), 0 0 42px rgba(0,217,255,.28);
}
.dp1 { left: 8%; top: 23%; animation: packetRoute1 5s linear infinite; }
.dp2 { left: 30%; top: 62%; animation: packetRoute2 6.2s linear infinite .8s; }
.dp3 { right: 16%; top: 57%; animation: packetRoute3 5.6s linear infinite 1.4s; }

@keyframes chipPulse {
  0%,100% { transform: scale(1); filter: brightness(1); }
  50% { transform: scale(1.035); filter: brightness(1.2); }
}
@keyframes traceGlow {
  0%,100% { opacity:.38; filter: brightness(.85); }
  50% { opacity:.9; filter: brightness(1.35); }
}
@keyframes nodePulse {
  0%,100% { transform: scale(.85); opacity:.55; }
  50% { transform: scale(1.18); opacity:1; }
}
@keyframes packetRoute1 {
  0% { transform: translate(0,0); opacity:0; }
  12% { opacity:1; }
  45% { transform: translate(235px,0); opacity:1; }
  70% { transform: translate(235px,125px); opacity:.9; }
  100% { transform: translate(430px,125px); opacity:0; }
}
@keyframes packetRoute2 {
  0% { transform: translate(0,0); opacity:0; }
  15% { opacity:1; }
  55% { transform: translate(280px,0); opacity:1; }
  100% { transform: translate(440px,-145px); opacity:0; }
}
@keyframes packetRoute3 {
  0% { transform: translate(0,0); opacity:0; }
  18% { opacity:1; }
  58% { transform: translate(-190px,0); opacity:1; }
  100% { transform: translate(-340px,120px); opacity:0; }
}

/* make old circuit-flow lines blend with motherboard instead of hiding behind form */
.circuit-flow {
  opacity: .95 !important;
}
.c-line {
  z-index: 1;
  opacity: .55;
}
.c-pulse {
  z-index: 2;
}

@media(max-width:760px){
  .chip-core {
    width: 72px;
    height: 72px;
    right: 8%;
  }
  .trace,
  .node-dot,
  .data-packet {
    opacity: .55;
  }
}


/* ===== PiKTeK V13 critical orbit click fix + cleaner panel ===== */

/* The previous issue: parent had pointer-events:none, so buttons could not receive click */
.floating-tags {
  pointer-events: auto !important;
  z-index: 20 !important;
}

.tag {
  pointer-events: auto !important;
  cursor: pointer !important;
  user-select: none;
}

/* Move tags away from the info panel and keep all clickable */
.tag-cloud { left: 34px !important; top: 34px !important; }
.tag-digital { right: 34px !important; top: 34px !important; }
.tag-auto { left: 34px !important; bottom: 152px !important; }
.tag-web { right: 34px !important; bottom: 152px !important; }

/* Info panel appears lower, smaller, and no longer blocks tag clicks */
.orbit-tooltip {
  bottom: 24px !important;
  width: min(360px, calc(100% - 70px)) !important;
  min-height: 72px !important;
  padding: 14px 16px !important;
  opacity: .78 !important;
  z-index: 12 !important;
  pointer-events: none !important;
}
.orbit-tooltip.active {
  opacity: 1 !important;
}
.orbit-tooltip strong {
  font-size: 12px !important;
}
.orbit-tooltip p {
  font-size: 12px !important;
  line-height: 1.45 !important;
}

/* Make selected tag obvious */
.tag.active {
  color: #ffffff !important;
  background: rgba(18,28,58,.98) !important;
  border-color: rgba(255,255,255,.5) !important;
  box-shadow:
    0 18px 45px rgba(0,0,0,.30),
    0 0 30px rgba(0,217,255,.18),
    inset 0 0 0 1px rgba(255,255,255,.06) !important;
}

/* Better click feedback */
.tag:active {
  transform: translateY(-2px) scale(.98) !important;
}

/* ===== Microchip / processor style contact background ===== */
.booking-section {
  position: relative;
  overflow: hidden;
}

.chip-board-visual {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .92;
}

.main-chip {
  position: absolute;
  right: 9%;
  top: 18%;
  width: 150px;
  height: 150px;
  border-radius: 26px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.22), transparent 32%),
    linear-gradient(145deg, rgba(2,4,13,.42), rgba(2,4,13,.12));
  border: 2px solid rgba(2,4,13,.52);
  box-shadow:
    0 0 42px rgba(255,255,255,.24),
    inset 0 0 30px rgba(255,255,255,.14);
  animation: mainChipGlow 3.2s ease-in-out infinite;
}

.main-chip::before {
  content: "PiK";
  position: absolute;
  inset: 22px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.62);
  font-weight: 900;
  letter-spacing: .12em;
  font-size: 22px;
  background: rgba(2,4,13,.12);
}

.main-chip::after {
  content: "";
  position: absolute;
  inset: -16px;
  background:
    repeating-linear-gradient(90deg, transparent 0 10px, rgba(2,4,13,.50) 10px 14px, transparent 14px 24px),
    repeating-linear-gradient(0deg, transparent 0 10px, rgba(2,4,13,.42) 10px 14px, transparent 14px 24px);
  mask:
    linear-gradient(#000 0 0) top / 100% 14px no-repeat,
    linear-gradient(#000 0 0) bottom / 100% 14px no-repeat,
    linear-gradient(#000 0 0) left / 14px 100% no-repeat,
    linear-gradient(#000 0 0) right / 14px 100% no-repeat;
  opacity: .65;
}

.route {
  position: absolute;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(2,4,13,.52), rgba(255,255,255,.58), rgba(2,4,13,.42));
  box-shadow: 0 0 18px rgba(255,255,255,.24);
  opacity: .72;
}

.route::before,
.route::after {
  content: "";
  position: absolute;
  width: 13px;
  height: 13px;
  top: -5px;
  border-radius: 50%;
  background: rgba(255,255,255,.72);
  box-shadow: 0 0 20px rgba(255,255,255,.78);
}
.route::before { left: -4px; }
.route::after { right: -4px; }

.r1 { width: 44%; left: 8%; top: 22%; animation: routeGlow 3.6s ease-in-out infinite; }
.r2 { width: 38%; left: 18%; top: 40%; animation: routeGlow 4.2s ease-in-out infinite .4s; }
.r3 { width: 54%; left: 7%; top: 66%; animation: routeGlow 3.9s ease-in-out infinite .8s; }
.r4 { width: 30%; right: 18%; top: 62%; transform: rotate(90deg); transform-origin: right center; animation: routeGlow 4.8s ease-in-out infinite 1.1s; }
.r5 { width: 34%; left: 26%; bottom: 16%; animation: routeGlow 4.1s ease-in-out infinite 1.5s; }
.r6 { width: 28%; right: 28%; bottom: 34%; animation: routeGlow 4.5s ease-in-out infinite 1.9s; }

.signal {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: #ffffff;
  box-shadow: 0 0 18px rgba(255,255,255,.95), 0 0 46px rgba(2,4,13,.42);
  opacity: 0;
}
.sg1 { left: 8%; top: 21.4%; animation: signalRouteA 5s linear infinite; }
.sg2 { left: 18%; top: 39.4%; animation: signalRouteB 5.8s linear infinite .7s; }
.sg3 { left: 8%; top: 65.4%; animation: signalRouteC 6.2s linear infinite 1.2s; }
.sg4 { right: 26%; bottom: 33.4%; animation: signalRouteD 5.4s linear infinite 1.8s; }

@keyframes mainChipGlow {
  0%,100% { transform: scale(1); filter: brightness(1); }
  50% { transform: scale(1.025); filter: brightness(1.2); }
}
@keyframes routeGlow {
  0%,100% { opacity:.42; filter:brightness(.85); }
  50% { opacity:.95; filter:brightness(1.35); }
}
@keyframes signalRouteA {
  0% { transform: translateX(0); opacity:0; }
  10% { opacity:1; }
  80% { transform: translateX(370px); opacity:1; }
  100% { transform: translateX(450px); opacity:0; }
}
@keyframes signalRouteB {
  0% { transform: translateX(0); opacity:0; }
  10% { opacity:1; }
  75% { transform: translateX(310px); opacity:1; }
  100% { transform: translateX(420px) translateY(-70px); opacity:0; }
}
@keyframes signalRouteC {
  0% { transform: translateX(0); opacity:0; }
  10% { opacity:1; }
  70% { transform: translateX(420px); opacity:1; }
  100% { transform: translateX(540px) translateY(-120px); opacity:0; }
}
@keyframes signalRouteD {
  0% { transform: translateX(0); opacity:0; }
  10% { opacity:1; }
  100% { transform: translateX(-260px); opacity:0; }
}

/* Tone down older circuit layer so the processor visual leads */
.motherboard-layer {
  opacity: .34 !important;
}
.c-line,
.c-pulse {
  opacity: .28 !important;
}

@media(max-width:980px){
  .tag-auto { bottom: 138px !important; }
  .tag-web { bottom: 138px !important; }
  .orbit-tooltip {
    width: min(330px, calc(100% - 44px)) !important;
  }
  .main-chip {
    width: 112px;
    height: 112px;
    right: 6%;
  }
}
@media(max-width:560px){
  .orbit-tooltip {
    display: block !important;
    bottom: 18px !important;
    width: calc(100% - 30px) !important;
  }
  .floating-tags .tag {
    display: none !important;
  }
}


/* ===== V14: smaller orbit info panel (more circular balance) ===== */
.orbit-tooltip {
  width: min(260px, calc(100% - 90px)) !important;
  padding: 12px 14px !important;
  border-radius: 18px !important;
  bottom: 34px !important;
  text-align: center;
}

.orbit-tooltip strong {
  font-size: 11.5px !important;
  letter-spacing: .06em !important;
}

.orbit-tooltip p {
  font-size: 11.5px !important;
  line-height: 1.4 !important;
}

/* Make it feel more centered inside orbit */
.orbit-card {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Reduce dominance visually */
.orbit-tooltip.active {
  transform: translateX(-50%) translateY(-4px) scale(.96) !important;
  box-shadow:
    0 18px 45px rgba(0,0,0,.28),
    0 0 20px rgba(0,217,255,.08) !important;
}



/* ===== V15: orbit tooltip as slim rectangular bar below orbit ===== */
.orbit-tooltip {
  width: min(460px, calc(100% - 70px)) !important;
  min-height: auto !important;
  padding: 10px 18px !important;
  border-radius: 16px !important;
  bottom: 18px !important;
  text-align: left !important;
  background: linear-gradient(145deg, rgba(7,14,30,.92), rgba(3,7,18,.86)) !important;
  border: 1px solid rgba(220,235,255,.14) !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.22), 0 0 18px rgba(120,180,255,.06) !important;
}

.orbit-tooltip strong {
  font-size: 10.5px !important;
  letter-spacing: .09em !important;
  margin-bottom: 4px !important;
}

.orbit-tooltip p {
  font-size: 10.8px !important;
  line-height: 1.35 !important;
}

.orbit-tooltip.active {
  transform: translateX(-50%) translateY(0) scale(1) !important;
}

/* Lift lower tags slightly so the rectangle has breathing room */
.tag-auto { bottom: 122px !important; }
.tag-web { bottom: 122px !important; }


/* ===== V15: cleaner contact background, focus motion in empty area ===== */
.booking-section {
  background:
    linear-gradient(135deg, rgba(103,233,255,.98), rgba(75,118,255,.96), rgba(217,54,255,.95)) !important;
}

/* Blur/dim tech graphics behind the text/form area */
.booking-section::before {
  opacity: .14 !important;
  filter: blur(1.5px) !important;
  mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.35) 50%, black 72%) !important;
}

.booking-section::after {
  opacity: .12 !important;
  filter: blur(2px) !important;
}

/* Keep the main microchip away from form/text and focused in the empty lower-right visual area */
.chip-board-visual {
  opacity: .95 !important;
  mask-image: linear-gradient(90deg, transparent 0%, transparent 45%, black 63%, black 100%);
}

.main-chip {
  right: 7% !important;
  top: auto !important;
  bottom: 10% !important;
  width: 128px !important;
  height: 128px !important;
  opacity: .82 !important;
}

/* Move circuit routes lower/right, away from readable content */
.r1 { width: 32% !important; left: auto !important; right: 20% !important; top: auto !important; bottom: 42% !important; }
.r2 { width: 28% !important; left: auto !important; right: 26% !important; top: auto !important; bottom: 30% !important; }
.r3 { width: 38% !important; left: auto !important; right: 12% !important; top: auto !important; bottom: 18% !important; }
.r4 { width: 24% !important; right: 12% !important; top: auto !important; bottom: 44% !important; }
.r5 { width: 26% !important; left: auto !important; right: 30% !important; bottom: 10% !important; }
.r6 { width: 22% !important; right: 18% !important; bottom: 58% !important; }

/* Make older circuit traces subtle so they don't confuse the copy */
.motherboard-layer,
.c-line,
.c-pulse {
  opacity: .12 !important;
  filter: blur(1.5px) !important;
}

/* Data signals are the focus */
.signal,
.data-packet {
  opacity: .88;
  filter: none !important;
}

.booking-copy,
.booking-form {
  position: relative;
  z-index: 5 !important;
}

.booking-form {
  backdrop-filter: blur(12px);
  background: rgba(255,255,255,.92) !important;
}

@media(max-width:980px){
  .orbit-tooltip {
    width: min(380px, calc(100% - 46px)) !important;
    bottom: 16px !important;
  }
  .tag-auto, .tag-web { bottom: 112px !important; }
  .chip-board-visual {
    mask-image: linear-gradient(180deg, transparent 0%, black 42%, black 100%);
  }
}

@media(max-width:560px){
  .orbit-tooltip {
    width: calc(100% - 28px) !important;
    text-align: center !important;
  }
}


/* ===== V18 Performance Optimization (Fix Scroll Lag) ===== */

/* Reduce heavy blur effects */
.booking-form {
  backdrop-filter: blur(6px) !important;
}

/* Reduce opacity layers */
.chip-board-visual,
.circuit-flow {
  opacity: .6 !important;
}

/* Simplify animations */
.signal,
.data-packet {
  animation-duration: 7s !important;
}

/* Reduce shadow complexity */
.route,
.main-chip {
  box-shadow: 0 0 12px rgba(255,255,255,.25) !important;
}

/* Disable unnecessary filters */
.motherboard-layer,
.c-line,
.c-pulse {
  filter: none !important;
}

/* Use GPU acceleration */
.booking-section,
.orbit-card {
  will-change: transform;
  transform: translateZ(0);
}

/* Reduce animation load on scroll-heavy areas */
@media (prefers-reduced-motion: no-preference) {
  .route,
  .signal,
  .data-packet {
    animation-timing-function: linear;
  }
}

/* Mobile optimization */
@media(max-width:768px){
  .chip-board-visual,
  .circuit-flow {
    display: none !important;
  }
}


/* ===== V19: mobile orbit tags fix + branded loading intro ===== */

/* Branded opening screen */
.site-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 18px;
  background:
    radial-gradient(circle at 50% 40%, rgba(0,217,255,.16), transparent 28%),
    radial-gradient(circle at 65% 60%, rgba(240,0,255,.12), transparent 30%),
    #02040d;
  transition: opacity .5s ease, visibility .5s ease;
}
.site-loader.hide {
  opacity: 0;
  visibility: hidden;
}
.loader-orbit {
  position: relative;
  width: 220px;
  height: 220px;
  display: grid;
  place-items: center;
}
.loader-orbit img {
  width: 170px;
  height: auto;
  filter: drop-shadow(0 0 24px rgba(0,217,255,.28));
}
.loader-orbit span {
  position: absolute;
  inset: 20px;
  border-radius: 50%;
  border: 1px solid rgba(220,235,255,.18);
  animation: loaderSpin 3.5s linear infinite;
}
.loader-orbit span:nth-child(2) {
  inset: 38px;
  transform: rotate(60deg);
  border-color: rgba(0,217,255,.22);
  animation-duration: 4.6s;
}
.loader-orbit span:nth-child(3) {
  inset: 54px;
  transform: rotate(-35deg);
  border-color: rgba(240,0,255,.20);
  animation-duration: 5.2s;
}
.site-loader p {
  color: #b9c7da;
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
}
@keyframes loaderSpin {
  to { transform: rotate(360deg); }
}

/* Fix orbit tags: clickable on all devices */
.floating-tags {
  pointer-events: auto !important;
  z-index: 20 !important;
}
.tag {
  pointer-events: auto !important;
  cursor: pointer !important;
  user-select: none;
}

/* Keep the tooltip slim and below the orbit, not covering it */
.orbit-tooltip {
  width: min(460px, calc(100% - 70px)) !important;
  min-height: auto !important;
  padding: 10px 18px !important;
  border-radius: 16px !important;
  bottom: 18px !important;
  text-align: left !important;
  z-index: 12 !important;
  pointer-events: none !important;
}
.orbit-tooltip strong {
  font-size: 10.5px !important;
  letter-spacing: .09em !important;
  margin-bottom: 4px !important;
}
.orbit-tooltip p {
  font-size: 10.8px !important;
  line-height: 1.35 !important;
}
.orbit-tooltip.active {
  opacity: 1 !important;
  transform: translateX(-50%) translateY(0) scale(1) !important;
}

/* Tag positions */
.tag-cloud { left: 34px !important; top: 34px !important; }
.tag-digital { right: 34px !important; top: 34px !important; }
.tag-auto { left: 34px !important; bottom: 122px !important; }
.tag-web { right: 34px !important; bottom: 122px !important; }

.tag.active {
  color: #ffffff !important;
  background: rgba(18,28,58,.98) !important;
  border-color: rgba(255,255,255,.5) !important;
  box-shadow:
    0 18px 45px rgba(0,0,0,.30),
    0 0 30px rgba(0,217,255,.18),
    inset 0 0 0 1px rgba(255,255,255,.06) !important;
}

/* Mobile: show tags again instead of hiding them */
@media(max-width:560px){
  .floating-tags {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    position: absolute !important;
    left: 14px !important;
    right: 14px !important;
    bottom: 110px !important;
    top: auto !important;
    inset: auto 14px 110px 14px !important;
    pointer-events: auto !important;
  }

  .floating-tags .tag {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    display: inline-flex !important;
    justify-content: center;
    width: 100%;
    font-size: 10.5px !important;
    padding: 8px 8px !important;
    white-space: nowrap;
  }

  .orbit-tooltip {
    display: block !important;
    bottom: 18px !important;
    width: calc(100% - 28px) !important;
    text-align: center !important;
    padding: 9px 12px !important;
  }

  .orbit-tooltip p {
    font-size: 10.5px !important;
  }

  .loader-orbit {
    width: 180px;
    height: 180px;
  }
  .loader-orbit img {
    width: 140px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .site-loader,
  .loader-orbit span {
    animation: none !important;
    transition: none !important;
  }
}


/* ===== V20: robust loader fix ===== */
.site-loader.hide {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}



/* ===== V21: Mobile orbit tags compact fix ===== */
@media(max-width:560px){
  .orbit-card {
    min-height: 520px !important;
    overflow: hidden !important;
  }

  .logo-display {
    padding: 42px 26px 150px 26px !important;
  }

  .logo-display img {
    width: min(250px, 72%) !important;
  }

  .floating-tags {
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 22 !important;
    pointer-events: auto !important;
  }

  .floating-tags .tag {
    position: absolute !important;
    display: inline-flex !important;
    width: auto !important;
    max-width: 150px !important;
    min-height: 34px !important;
    padding: 7px 10px !important;
    border-radius: 999px !important;
    font-size: 9.6px !important;
    line-height: 1 !important;
    letter-spacing: .01em !important;
    white-space: nowrap !important;
    transform: none !important;
  }

  .tag-cloud {
    left: 16px !important;
    top: 42px !important;
  }

  .tag-digital {
    right: 16px !important;
    top: 78px !important;
  }

  .tag-auto {
    left: 18px !important;
    bottom: 148px !important;
  }

  .tag-web {
    right: 18px !important;
    bottom: 148px !important;
  }

  .tag.active {
    transform: translateY(-3px) scale(1.02) !important;
  }

  .orbit-tooltip {
    display: block !important;
    bottom: 22px !important;
    width: calc(100% - 34px) !important;
    padding: 10px 12px !important;
    border-radius: 16px !important;
    text-align: center !important;
  }

  .orbit-tooltip strong {
    font-size: 10px !important;
  }

  .orbit-tooltip p {
    font-size: 10px !important;
    line-height: 1.35 !important;
  }

  .orbit-card:before {
    inset: 42px !important;
  }

  .orbit-card:after {
    width: 440px !important;
    height: 150px !important;
    left: -95px !important;
    top: 160px !important;
  }
}

@media(max-width:390px){
  .floating-tags .tag {
    max-width: 132px !important;
    font-size: 8.8px !important;
    padding: 7px 8px !important;
  }

  .tag-digital {
    top: 72px !important;
  }

  .logo-display img {
    width: min(225px, 70%) !important;
  }
}


/* ===== V22: ultra-small mobile orbit layout fix ===== */
/* For narrow mobile screens: stop trying to place tags around orbit.
   Convert them into a clean compact grid below the logo area. */
@media(max-width:430px){
  .orbit-card {
    min-height: 560px !important;
    padding-bottom: 0 !important;
  }

  .logo-display {
    padding: 38px 22px 230px 22px !important;
    align-items: start !important;
    padding-top: 120px !important;
  }

  .logo-display img {
    width: min(245px, 76%) !important;
  }

  .floating-tags {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 9px !important;
    position: absolute !important;
    left: 16px !important;
    right: 16px !important;
    top: auto !important;
    bottom: 112px !important;
    inset: auto 16px 112px 16px !important;
    z-index: 24 !important;
    pointer-events: auto !important;
  }

  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 38px !important;
    padding: 8px 8px !important;
    border-radius: 14px !important;
    font-size: 9.4px !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
    text-align: center !important;
    transform: none !important;
  }

  .tag.active {
    transform: translateY(-2px) scale(1.01) !important;
  }

  .orbit-tooltip {
    display: block !important;
    width: calc(100% - 32px) !important;
    left: 50% !important;
    bottom: 20px !important;
    padding: 9px 10px !important;
    border-radius: 14px !important;
    text-align: center !important;
  }

  .orbit-tooltip strong {
    font-size: 9.5px !important;
  }

  .orbit-tooltip p {
    font-size: 9.8px !important;
    line-height: 1.28 !important;
  }

  .orbit-card:before {
    inset: 44px !important;
    opacity: .6 !important;
  }

  .orbit-card:after {
    width: 420px !important;
    height: 145px !important;
    left: -105px !important;
    top: 180px !important;
    opacity: .5 !important;
  }
}

/* Extra tiny phones */
@media(max-width:360px){
  .orbit-card {
    min-height: 545px !important;
  }

  .logo-display {
    padding-top: 110px !important;
    padding-bottom: 225px !important;
  }

  .logo-display img {
    width: min(220px, 74%) !important;
  }

  .floating-tags {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    bottom: 104px !important;
    inset: auto 18px 104px 18px !important;
  }

  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    min-height: 32px !important;
    font-size: 9px !important;
    padding: 7px 8px !important;
  }

  .orbit-tooltip {
    bottom: 14px !important;
  }
}


/* ===== V23: iPhone 15 Pro / 390px mobile hero-orbit polish ===== */
/* Target common iPhone widths: 390–430px. Keep tags visible, compact, and usable. */
@media (min-width: 381px) and (max-width: 430px) {
  .hero {
    gap: 28px !important;
    padding: 34px 0 48px !important;
  }

  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
  }

  .hero-actions .btn {
    min-height: 54px !important;
    padding: 0 12px !important;
    font-size: 14px !important;
    white-space: nowrap !important;
  }

  .orbit-card {
    min-height: 560px !important;
    border-radius: 32px !important;
    overflow: hidden !important;
  }

  .logo-display {
    padding: 74px 18px 210px 18px !important;
    display: grid !important;
    place-items: center !important;
  }

  .logo-display img {
    width: min(265px, 78%) !important;
  }

  .floating-tags {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 9px !important;
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 108px !important;
    top: auto !important;
    inset: auto 18px 108px 18px !important;
    z-index: 35 !important;
    pointer-events: auto !important;
  }

  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    position: relative !important;
    display: flex !important;
    width: 100% !important;
    max-width: none !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 34px !important;
    padding: 7px 7px !important;
    border-radius: 13px !important;
    font-size: 9px !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
    text-align: center !important;
    transform: none !important;
  }

  .tag.active {
    transform: translateY(-2px) scale(1.01) !important;
  }

  .orbit-tooltip {
    display: block !important;
    width: calc(100% - 36px) !important;
    left: 50% !important;
    bottom: 18px !important;
    padding: 9px 10px !important;
    border-radius: 14px !important;
    text-align: center !important;
    z-index: 30 !important;
  }

  .orbit-tooltip strong {
    font-size: 9.5px !important;
    letter-spacing: .08em !important;
  }

  .orbit-tooltip p {
    font-size: 9.5px !important;
    line-height: 1.28 !important;
  }

  .orbit-card:before {
    inset: 42px !important;
    opacity: .55 !important;
  }

  .orbit-card:after {
    width: 430px !important;
    height: 150px !important;
    left: -74px !important;
    top: 178px !important;
    opacity: .55 !important;
  }

  .stats {
    gap: 14px !important;
  }

  .stat {
    padding: 22px !important;
  }
}

/* Slightly smaller devices remain stacked but cleaner */
@media(max-width:380px){
  .orbit-card {
    min-height: 570px !important;
  }

  .logo-display {
    padding-top: 92px !important;
  }

  .floating-tags {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    inset: auto 16px 112px 16px !important;
    gap: 8px !important;
  }

  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    font-size: 8.5px !important;
    min-height: 32px !important;
    padding: 7px 6px !important;
  }
}

/* Prevent any older rule from hiding tags on mobile */
@media(max-width:560px){
  .floating-tags .tag {
    display: flex !important;
  }
}


/* ===== V24: final mobile orbit fix + thank-you popup + WhatsApp ===== */

/* Mobile orbit tags: force clean grid below logo, never top-left overlap */
@media(max-width:560px){
  .orbit-card {
    min-height: 585px !important;
    position: relative !important;
  }

  .logo-display {
    padding: 82px 20px 235px 20px !important;
    display: grid !important;
    place-items: center !important;
  }

  .logo-display img {
    width: min(245px, 72%) !important;
  }

  .orbit-card .floating-tags {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 9px !important;
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    top: auto !important;
    bottom: 112px !important;
    inset: auto 18px 112px 18px !important;
    width: auto !important;
    height: auto !important;
    z-index: 40 !important;
    pointer-events: auto !important;
  }

  .orbit-card .floating-tags .tag,
  .orbit-card .tag-cloud,
  .orbit-card .tag-digital,
  .orbit-card .tag-auto,
  .orbit-card .tag-web {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    display: flex !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 36px !important;
    padding: 8px 6px !important;
    border-radius: 14px !important;
    font-size: 9px !important;
    line-height: 1.05 !important;
    text-align: center !important;
    justify-content: center !important;
    align-items: center !important;
    white-space: nowrap !important;
    transform: none !important;
  }

  .orbit-card .tag.active {
    transform: translateY(-2px) scale(1.01) !important;
  }

  .orbit-tooltip {
    width: calc(100% - 36px) !important;
    bottom: 20px !important;
    padding: 9px 11px !important;
    text-align: center !important;
    z-index: 35 !important;
  }
}

@media(max-width:380px){
  .orbit-card {
    min-height: 610px !important;
  }

  .logo-display {
    padding-top: 76px !important;
    padding-bottom: 300px !important;
  }

  .orbit-card .floating-tags {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    bottom: 114px !important;
    inset: auto 20px 114px 20px !important;
  }

  .orbit-card .floating-tags .tag,
  .orbit-card .tag-cloud,
  .orbit-card .tag-digital,
  .orbit-card .tag-auto,
  .orbit-card .tag-web {
    min-height: 31px !important;
    font-size: 8.8px !important;
    padding: 7px 8px !important;
  }
}

/* Modern thank-you modal */
.thank-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  background: rgba(2,4,13,.54);
  backdrop-filter: blur(12px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .28s ease, visibility .28s ease;
}

.thank-modal.show {
  opacity: 1;
  visibility: visible;
}

.thank-card {
  width: min(420px, calc(100% - 34px));
  border-radius: 28px;
  padding: 32px 28px;
  text-align: center;
  color: #f8fbff;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,217,255,.18), transparent 42%),
    linear-gradient(145deg, rgba(12,20,42,.96), rgba(5,10,22,.94));
  border: 1px solid rgba(220,235,255,.16);
  box-shadow: 0 28px 90px rgba(0,0,0,.42), 0 0 45px rgba(0,217,255,.12);
  transform: translateY(12px) scale(.96);
  animation: thankPop .38s ease forwards;
}

.thank-icon {
  width: 58px;
  height: 58px;
  margin: 0 auto 18px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #02040d;
  font-weight: 950;
  font-size: 28px;
  background: linear-gradient(90deg, #e9fbff, #7ddcff, #5d7cff);
  box-shadow: 0 0 30px rgba(0,217,255,.22);
}

.thank-card h3 {
  font-size: 28px;
  margin-bottom: 10px;
}

.thank-card p {
  color: #b9c7da;
  line-height: 1.65;
  font-size: 14px;
}

@keyframes thankPop {
  to { transform: translateY(0) scale(1); }
}

/* Floating WhatsApp button */
.whatsapp-float {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 999;
  min-width: 56px;
  height: 56px;
  padding: 0 18px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: white;
  font-weight: 900;
  font-size: 13px;
  background: linear-gradient(135deg, #25D366, #128C7E);
  box-shadow: 0 18px 45px rgba(18,140,126,.32);
  transition: transform .22s ease, box-shadow .22s ease;
}

.whatsapp-float::before {
  content: "☎";
  font-size: 18px;
}

.whatsapp-float:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 55px rgba(18,140,126,.42);
}

@media(max-width:560px){
  .whatsapp-float {
    right: 16px;
    bottom: 16px;
    height: 52px;
    min-width: 52px;
    padding: 0 14px;
  }
}


/* ===== V25: WhatsApp icon-only, left side, Egypt phone format ===== */
.whatsapp-float {
  left: 22px !important;
  right: auto !important;
  width: 58px !important;
  min-width: 58px !important;
  height: 58px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  font-size: 0 !important;
}

.whatsapp-float::before {
  content: "☏" !important;
  font-size: 25px !important;
  line-height: 1 !important;
}

.whatsapp-float span {
  display: none !important;
}

@media(max-width:560px){
  .whatsapp-float {
    left: 16px !important;
    right: auto !important;
    width: 52px !important;
    min-width: 52px !important;
    height: 52px !important;
  }
  .whatsapp-float::before {
    font-size: 23px !important;
  }
}


/* ===== V26: same-page AJAX form popup, no external thank-you page ===== */
.booking-form button[disabled] {
  opacity: .72;
  cursor: not-allowed;
  transform: none !important;
}

.thank-close {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 50%;
  color: #dbeafe;
  background: rgba(255,255,255,.08);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  transition: background .2s ease, transform .2s ease;
}

.thank-close:hover {
  background: rgba(255,255,255,.14);
  transform: rotate(90deg);
}

.thank-card {
  position: relative;
}

.thank-icon.error {
  background: linear-gradient(90deg, #fff1f2, #fb7185, #ef4444) !important;
  color: #02040d;
}


/* ===== V27: real WhatsApp icon ===== */
.whatsapp-float::before {
  content: "" !important;
  width: 24px;
  height: 24px;
  display: block;
  background: url('https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/whatsapp.svg') no-repeat center;
  background-size: contain;
  filter: invert(1); /* make it white */
}


/* ===== V28: WhatsApp moved into Contact section ===== */
.whatsapp-float {
  display: none !important;
}

.whatsapp-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: fit-content;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  color: #ffffff;
  font-weight: 900;
  font-size: 13px;
  background: linear-gradient(135deg, #25D366, #128C7E);
  box-shadow: 0 14px 32px rgba(18,140,126,.25);
  transition: transform .22s ease, box-shadow .22s ease;
}

.whatsapp-inline::before {
  content: "";
  width: 18px;
  height: 18px;
  display: block;
  background: url('https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/whatsapp.svg') no-repeat center;
  background-size: contain;
  filter: invert(1);
}

.whatsapp-inline:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 42px rgba(18,140,126,.34);
}

@media(max-width:560px){
  .whatsapp-inline {
    width: 100%;
    font-size: 12.5px;
  }
}


/* ===== V29: WhatsApp CTA final placement/style ===== */
.whatsapp-inline {
  margin-top: 4px;
  width: fit-content;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  color: #ffffff !important;
  background: #111827 !important;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 14px 34px rgba(2,4,13,.20);
}

.whatsapp-inline::before {
  width: 20px !important;
  height: 20px !important;
  background: url('https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/whatsapp.svg') no-repeat center !important;
  background-size: contain !important;
  filter: invert(57%) sepia(92%) saturate(477%) hue-rotate(88deg) brightness(98%) contrast(92%) !important;
}

.whatsapp-inline:hover {
  background: #02040d !important;
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(2,4,13,.28);
}

@media(max-width:560px){
  .whatsapp-inline {
    width: 100%;
  }
}


/* ===== V30: international phone validation + modal close fix ===== */
.iti {
  width: 100%;
}

.iti input {
  width: 100% !important;
}

.phone-label {
  position: relative;
}

.phone-error {
  display: none;
  margin-top: 5px;
  color: #ef4444 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

.phone-error.show {
  display: block;
}

.booking-form input.invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important;
}

.thank-modal.show {
  pointer-events: auto !important;
}

.thank-close {
  z-index: 3;
  display: grid !important;
  place-items: center;
}

.thank-close:focus {
  outline: 2px solid rgba(125,220,255,.55);
  outline-offset: 2px;
}

/* Make country dropdown look cleaner above dark/gradient page */
.iti__country-list {
  color: #07111f;
  border-radius: 14px;
  border: 1px solid rgba(2,4,13,.12);
  box-shadow: 0 18px 50px rgba(2,4,13,.22);
  z-index: 10001;
}

.iti__selected-country {
  border-radius: 13px 0 0 13px;
}

@media(max-width:560px){
  .iti__country-list {
    width: min(330px, calc(100vw - 34px));
  }
}


/* ===== V31: Loader anti-stuck fix ===== */
/* CSS-only fallback: loader fades automatically even if JavaScript fails */
.site-loader {
  animation: loaderAutoHide 1.35s ease 1.15s forwards !important;
}

@keyframes loaderAutoHide {
  to {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

/* Once hidden by JS, also remove interaction immediately */
.site-loader.hide {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Keep website available behind loader */
body {
  min-height: 100vh;
}


/* ===== V32: confirmed international phone validation + same-page popup ===== */
.iti {
  width: 100%;
}
.iti input {
  width: 100% !important;
}
.phone-label {
  position: relative;
}
.phone-error {
  display: none;
  margin-top: 5px;
  color: #ef4444 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}
.phone-error.show {
  display: block;
}
.booking-form input.invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important;
}
.thank-modal.show {
  pointer-events: auto !important;
}
.thank-close {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 50%;
  color: #dbeafe;
  background: rgba(255,255,255,.08);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  display: grid !important;
  place-items: center;
  z-index: 3;
  transition: background .2s ease, transform .2s ease;
}
.thank-close:hover {
  background: rgba(255,255,255,.14);
  transform: rotate(90deg);
}
.thank-close:focus {
  outline: 2px solid rgba(125,220,255,.55);
  outline-offset: 2px;
}
.thank-card {
  position: relative;
}
.thank-icon.error {
  background: linear-gradient(90deg, #fff1f2, #fb7185, #ef4444) !important;
  color: #02040d;
}
.iti__country-list {
  color: #07111f;
  border-radius: 14px;
  border: 1px solid rgba(2,4,13,.12);
  box-shadow: 0 18px 50px rgba(2,4,13,.22);
  z-index: 10001;
}
.iti__selected-country {
  border-radius: 13px 0 0 13px;
}
@media(max-width:560px){
  .iti__country-list {
    width: min(330px, calc(100vw - 34px));
  }
}


/* ===== V33: compact phone validation message, no layout shift ===== */
.phone-label {
  position: relative !important;
  padding-bottom: 0 !important;
}

.phone-error {
  position: absolute !important;
  left: 0 !important;
  bottom: -14px !important;
  margin-top: 0 !important;
  font-size: 9.5px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  color: #ef4444 !important;
  white-space: nowrap !important;
  z-index: 2;
}

.phone-error.show {
  display: block !important;
}

/* Prevent the form grid from jumping when validation appears */
.booking-form label.phone-label {
  min-height: auto !important;
}


/* ===== V34: strict country-based phone validation ===== */
.phone-error {
  font-size: 9.5px !important;
  bottom: -14px !important;
}


/* ===== V35: unified validation style for all form fields ===== */
.booking-form label {
  position: relative !important;
  padding-bottom: 15px !important;
}

.field-error,
.phone-error {
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  display: none;
  margin: 0 !important;
  font-size: 9.5px !important;
  line-height: 1 !important;
  font-weight: 750 !important;
  color: #ef4444 !important;
  white-space: nowrap !important;
  z-index: 2;
}

.field-error.show,
.phone-error.show {
  display: block !important;
}

.booking-form input.invalid,
.booking-form select.invalid,
.booking-form textarea.invalid,
.iti input.invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important;
}

.iti {
  width: 100%;
}

.iti input {
  width: 100% !important;
}

.iti__country-list {
  color: #07111f;
  border-radius: 14px;
  border: 1px solid rgba(2,4,13,.12);
  box-shadow: 0 18px 50px rgba(2,4,13,.22);
  z-index: 10001;
}

@media(max-width:560px){
  .field-error,
  .phone-error {
    font-size: 9px !important;
  }
}


/* =========================================================
   V39 MOBILE HOTFIX
   Fixes: WhatsApp CTA, mobile loader, thank popup, validation UI
   ========================================================= */

/* 1) WhatsApp CTA: always a visible button, not plain text */
.booking-section .mini-contact .whatsapp-inline,
.whatsapp-inline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: fit-content !important;
  min-height: 46px !important;
  padding: 0 18px !important;
  margin-top: 8px !important;
  border-radius: 999px !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  background: #02040d !important;
  border: 1px solid rgba(255,255,255,.20) !important;
  box-shadow: 0 14px 34px rgba(2,4,13,.22) !important;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease !important;
}

.booking-section .mini-contact .whatsapp-inline::before,
.whatsapp-inline::before {
  content: "" !important;
  width: 19px !important;
  height: 19px !important;
  display: inline-block !important;
  flex: 0 0 19px !important;
  background: url('https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/whatsapp.svg') no-repeat center !important;
  background-size: contain !important;
  filter: invert(57%) sepia(92%) saturate(477%) hue-rotate(88deg) brightness(98%) contrast(92%) !important;
}

.booking-section .mini-contact .whatsapp-inline:hover,
.whatsapp-inline:hover {
  transform: translateY(-3px) !important;
  background: #111827 !important;
  box-shadow: 0 18px 44px rgba(2,4,13,.30) !important;
}

/* 2) Loader: mobile logo must be fully visible and contained */
.site-loader {
  overflow: hidden !important;
}

.loader-orbit {
  width: 230px !important;
  height: 230px !important;
  overflow: visible !important;
}

.loader-orbit img {
  width: 185px !important;
  max-width: 185px !important;
  max-height: 95px !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  transform: none !important;
  clip-path: none !important;
}

@media(max-width:560px){
  .loader-orbit {
    width: 190px !important;
    height: 190px !important;
  }
  .loader-orbit img {
    width: 150px !important;
    max-width: 150px !important;
    max-height: 78px !important;
  }
  .site-loader p {
    font-size: 10px !important;
    letter-spacing: .16em !important;
    text-align: center !important;
    padding: 0 20px !important;
  }
}

/* 3) Thank you popup: always centered and compact */
.thank-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 22px !important;
  background: rgba(2,4,13,.62) !important;
  backdrop-filter: blur(10px) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: opacity .25s ease, visibility .25s ease !important;
}

.thank-modal.show {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.thank-card {
  position: relative !important;
  width: min(390px, calc(100vw - 44px)) !important;
  max-width: 390px !important;
  margin: 0 auto !important;
  border-radius: 24px !important;
  padding: 30px 24px 26px !important;
  text-align: center !important;
  color: #f8fbff !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,217,255,.18), transparent 42%),
    linear-gradient(145deg, rgba(12,20,42,.97), rgba(5,10,22,.95)) !important;
  border: 1px solid rgba(220,235,255,.16) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,.42), 0 0 45px rgba(0,217,255,.12) !important;
  transform: none !important;
}

.thank-icon {
  width: 54px !important;
  height: 54px !important;
  margin: 0 auto 16px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 50% !important;
  color: #02040d !important;
  font-weight: 950 !important;
  font-size: 26px !important;
  background: linear-gradient(90deg, #e9fbff, #7ddcff, #5d7cff) !important;
}

.thank-card h3 {
  font-size: 26px !important;
  line-height: 1.1 !important;
  margin: 0 0 10px !important;
}

.thank-card p {
  color: #b9c7da !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}

.thank-close {
  position: absolute !important;
  top: 12px !important;
  right: 14px !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 50% !important;
  color: #dbeafe !important;
  background: rgba(255,255,255,.08) !important;
  cursor: pointer !important;
  font-size: 22px !important;
  line-height: 1 !important;
  display: grid !important;
  place-items: center !important;
  z-index: 3 !important;
}

/* 4) Unified validation: small, left aligned, no huge center text */
.booking-form {
  align-items: start !important;
}

.booking-form label {
  position: relative !important;
  padding-bottom: 14px !important;
}

.booking-form .field-error,
.booking-form .phone-error,
.field-error,
.phone-error {
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  color: #ef4444 !important;
  text-align: left !important;
  white-space: nowrap !important;
  z-index: 2 !important;
}

.booking-form .field-error.show,
.booking-form .phone-error.show,
.field-error.show,
.phone-error.show {
  display: block !important;
}

.booking-form input.invalid,
.booking-form select.invalid,
.booking-form textarea.invalid,
.iti input.invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.10) !important;
}

.iti {
  width: 100% !important;
}

.iti input {
  width: 100% !important;
}

/* Mobile contact form spacing */
@media(max-width:560px){
  .booking-section .mini-contact .whatsapp-inline,
  .whatsapp-inline {
    width: 100% !important;
    min-height: 44px !important;
    font-size: 12.5px !important;
  }

  .booking-form label {
    padding-bottom: 13px !important;
  }

  .booking-form .field-error,
  .booking-form .phone-error,
  .field-error,
  .phone-error {
    font-size: 8.8px !important;
    bottom: 1px !important;
  }

  .thank-card {
    width: calc(100vw - 38px) !important;
    padding: 30px 22px 24px !important;
  }

  .thank-card h3 {
    font-size: 24px !important;
  }
}



/* =========================================================
   V40 MOBILE STABILIZED FINAL OVERRIDES
   Purpose: fix iPhone/mobile conflicts from older accumulated rules.
   ========================================================= */

/* Loader: safe on desktop, tiny/clean on mobile */
.site-loader {
  z-index: 99999 !important;
}
.site-loader.hide {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
@media(max-width: 768px) {
  .site-loader {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    padding: 0 24px !important;
    overflow: hidden !important;
  }
  .loader-orbit {
    width: 150px !important;
    height: 150px !important;
    display: grid !important;
    place-items: center !important;
    overflow: visible !important;
  }
  .loader-orbit img {
    width: 120px !important;
    height: auto !important;
    max-width: 120px !important;
    max-height: 62px !important;
    object-fit: contain !important;
    object-position: center !important;
    clip-path: none !important;
    transform: none !important;
  }
  .loader-orbit span {
    inset: 14px !important;
  }
  .loader-orbit span:nth-child(2) { inset: 28px !important; }
  .loader-orbit span:nth-child(3) { inset: 42px !important; }
  .site-loader p {
    font-size: 9px !important;
    letter-spacing: .12em !important;
    text-align: center !important;
    line-height: 1.3 !important;
    margin: 0 !important;
  }
}

/* Mobile orbit: always visible compact grid, never corner-stacked */
@media(max-width: 768px) {
  .orbit-card {
    position: relative !important;
    min-height: 540px !important;
    overflow: hidden !important;
    border-radius: 30px !important;
  }

  .logo-display {
    position: absolute !important;
    inset: 0 !important;
    display: grid !important;
    place-items: center !important;
    padding: 48px 22px 210px 22px !important;
    z-index: 1 !important;
  }
  .logo-display img {
    width: min(260px, 72vw) !important;
    height: auto !important;
    object-fit: contain !important;
  }

  .floating-tags {
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 102px !important;
    top: auto !important;
    inset: auto 18px 102px 18px !important;
    width: auto !important;
    height: auto !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    z-index: 50 !important;
    pointer-events: auto !important;
  }

  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    position: static !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    display: flex !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 34px !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 7px 6px !important;
    border-radius: 13px !important;
    font-size: 8.8px !important;
    line-height: 1.05 !important;
    text-align: center !important;
    white-space: nowrap !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .orbit-tooltip {
    position: absolute !important;
    left: 50% !important;
    bottom: 18px !important;
    transform: translateX(-50%) !important;
    width: calc(100% - 36px) !important;
    min-height: auto !important;
    padding: 9px 10px !important;
    border-radius: 14px !important;
    text-align: center !important;
    z-index: 45 !important;
    pointer-events: none !important;
  }
  .orbit-tooltip strong {
    font-size: 9px !important;
    letter-spacing: .08em !important;
    margin-bottom: 3px !important;
  }
  .orbit-tooltip p {
    font-size: 9.5px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
  }
}

@media(max-width: 360px) {
  .orbit-card { min-height: 570px !important; }
  .floating-tags {
    grid-template-columns: 1fr !important;
    bottom: 106px !important;
    inset: auto 18px 106px 18px !important;
  }
  .floating-tags .tag,
  .tag-cloud,
  .tag-digital,
  .tag-auto,
  .tag-web {
    min-height: 30px !important;
    font-size: 8.4px !important;
  }
}

/* Contact WhatsApp CTA: restore button on mobile and desktop */
.whatsapp-float { display: none !important; }
.booking-section .whatsapp-inline,
.whatsapp-inline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: fit-content !important;
  min-height: 46px !important;
  padding: 0 18px !important;
  margin-top: 8px !important;
  border-radius: 999px !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  background: #02040d !important;
  border: 1px solid rgba(255,255,255,.20) !important;
  box-shadow: 0 14px 34px rgba(2,4,13,.22) !important;
}
.booking-section .whatsapp-inline::before,
.whatsapp-inline::before {
  content: "" !important;
  width: 19px !important;
  height: 19px !important;
  display: inline-block !important;
  flex: 0 0 19px !important;
  background: url('https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/whatsapp.svg') no-repeat center !important;
  background-size: contain !important;
  filter: invert(57%) sepia(92%) saturate(477%) hue-rotate(88deg) brightness(98%) contrast(92%) !important;
}
@media(max-width: 768px) {
  .booking-section .whatsapp-inline,
  .whatsapp-inline {
    width: 100% !important;
    min-height: 44px !important;
    font-size: 12.5px !important;
  }
}

/* Thank popup: fixed centered modal, never bottom text */
.thank-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 100000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 22px !important;
  background: rgba(2,4,13,.62) !important;
  backdrop-filter: blur(10px) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
.thank-modal.show {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
.thank-card {
  position: relative !important;
  width: min(390px, calc(100vw - 44px)) !important;
  max-width: 390px !important;
  margin: 0 auto !important;
  border-radius: 24px !important;
  padding: 30px 24px 26px !important;
  text-align: center !important;
  color: #f8fbff !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,217,255,.18), transparent 42%),
    linear-gradient(145deg, rgba(12,20,42,.97), rgba(5,10,22,.95)) !important;
  border: 1px solid rgba(220,235,255,.16) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,.42), 0 0 45px rgba(0,217,255,.12) !important;
}
.thank-card h3 {
  font-size: 26px !important;
  line-height: 1.1 !important;
  margin: 0 0 10px !important;
}
.thank-card p {
  color: #b9c7da !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}
.thank-icon {
  width: 54px !important;
  height: 54px !important;
  margin: 0 auto 16px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 50% !important;
}
.thank-close {
  position: absolute !important;
  top: 12px !important;
  right: 14px !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  color: #dbeafe !important;
  background: rgba(255,255,255,.08) !important;
  cursor: pointer !important;
  font-size: 22px !important;
}

/* Validation: uniform small red line, no huge centered text */
.booking-form label {
  position: relative !important;
  padding-bottom: 14px !important;
}
.booking-form .field-error,
.booking-form .phone-error,
.field-error,
.phone-error {
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  color: #ef4444 !important;
  text-align: left !important;
  white-space: nowrap !important;
  z-index: 2 !important;
}
.booking-form .field-error.show,
.booking-form .phone-error.show,
.field-error.show,
.phone-error.show {
  display: block !important;
}
.booking-form input.invalid,
.booking-form select.invalid,
.booking-form textarea.invalid,
.iti input.invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.10) !important;
}

