/* ============================================================
   RIDEWAVE.TECH — Shared Stylesheet v2.2
   Paleta: Dark Navy #1C2333 · Cyan #00D4CC · Silver #C8D0DC
   Design System: Glassmorphism + Glow
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800;900&family=Inter:wght@300;400;500;600&display=swap');

html { scroll-behavior: smooth; }

:root {
  --navy:   #1C2333;
  --slate:  #263040;
  --black:  #0D1117;
  --cyan:   #00D4CC;
  --cyan-glow: #00FFEE;
  --cyan-dark: #00A39C;
  --white:  #FFFFFF;
  --silver: #C8D0DC;
  --gray:   #6B7A8D;
  --light:  #F5F7FA;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--silver);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}

/* ── Typography ── */
h1,h2,h3,h4 { font-family: 'Montserrat', Arial Black, sans-serif; color: var(--white); line-height: 1.1; }
h1 { font-size: clamp(2.4rem, 6vw, 5rem); font-weight: 900; letter-spacing: -0.02em; }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 800; }
h3 { font-size: clamp(1.1rem, 2vw, 1.5rem); font-weight: 700; }
h4 { font-size: 1rem; font-weight: 700; color: var(--cyan); text-transform: uppercase; letter-spacing: 0.15em; }
p  { line-height: 1.7; }

a { color: var(--cyan); text-decoration: none; transition: color .2s; }
a:hover { color: var(--cyan-glow); }

/* ── Layout ── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 clamp(1rem, 5vw, 3rem); }
.section { padding: clamp(4rem, 8vw, 7rem) 0; }
.section-alt   { background: var(--navy); }
.section-dark  { background: var(--slate); }
.section-light { background: #F8FAFC; color: #1C2333; }
.section-light h2,
.section-light h3 { color: #1C2333; }

/* ── Nav — Glassmorphism ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  transition: background .35s, padding .35s, border-color .35s, box-shadow .35s, backdrop-filter .35s;
  padding: 1.5rem 0;
  border-bottom: 1px solid rgba(0,212,204,.08);
  background: rgba(13,17,23,.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
nav.scrolled {
  background: rgba(13,17,23,.88);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: .9rem 0;
  border-color: rgba(0,212,204,.22);
  box-shadow: 0 4px 32px rgba(0,0,0,.35), 0 1px 0 rgba(0,212,204,.08), 0 0 60px rgba(0,0,0,.2);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
}
.nav-logo {
  display: flex; align-items: center; gap: .75rem; cursor: pointer;
  text-decoration: none;
}
.nav-logo svg { width: 38px; height: 38px; flex-shrink: 0; }
.nav-logo-text { display: flex; flex-direction: column; line-height: 1; text-decoration: none; }
.nav-logo-text .wordmark {
  font-family: 'Montserrat', sans-serif; font-weight: 900;
  font-size: 1.15rem; letter-spacing: -.02em; color: var(--white);
  text-transform: uppercase;
}
.nav-logo-text .tagline {
  font-size: .5rem; letter-spacing: .35em; color: var(--cyan);
  font-weight: 700; text-transform: uppercase; margin-top: 1px;
}
/* ── Logo canonical classes (all pages) ── */
.nav-logo-ridewave {
  font-family: 'Montserrat', Arial Black, sans-serif; font-weight: 900;
  font-size: 1.25rem; letter-spacing: .08em; color: #fff; text-transform: uppercase;
}
.nav-logo-tech {
  font-family: 'Montserrat', Arial, sans-serif; font-weight: 600;
  font-size: .52rem; letter-spacing: .22em; color: #00D4CC;
  text-transform: uppercase; margin-top: 1px;
}
.nav-links {
  display: flex; align-items: center; gap: 2rem;
  list-style: none; font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
}
.nav-links a { color: var(--silver); }
.nav-links a:hover { color: var(--cyan); }
.nav-links .nav-highlight {
  padding: .5rem 1.2rem;
  border: 1px solid var(--cyan);
  color: var(--cyan);
  border-radius: 2px;
  transition: background .2s, color .2s;
}
.nav-links .nav-highlight:hover { background: var(--cyan); color: var(--black); }
/* Lang switcher */
.lang-switcher { display: flex; gap: .5rem; margin-left: .5rem; }
.lang-btn {
  background: none; border: none; cursor: pointer;
  font-size: .62rem; font-weight: 800; letter-spacing: .08em;
  color: var(--gray); padding: .2rem .4rem; border-radius: 2px;
  font-family: 'Montserrat', sans-serif; text-transform: uppercase;
  transition: color .2s;
}
.lang-btn.active { color: var(--cyan); border-bottom: 1px solid var(--cyan); }
.lang-btn:hover { color: var(--silver); }

/* ── Hamburger (2-line minimal) ── */
.hamburger {
  display: none; flex-direction: column; align-items: flex-end;
  justify-content: center; gap: 6px; background: none; border: none;
  cursor: pointer; width: 44px; height: 44px; z-index: 1100;
}
.hamburger span {
  display: block; height: 2px; background: var(--cyan); border-radius: 2px;
  transition: all .3s ease;
  transform-origin: center;
}
.hamburger span:nth-child(1) { width: 28px; }
.hamburger span:nth-child(2) { width: 18px; }
.hamburger.open span:nth-child(1) { width: 22px; transform: translateY(4px) rotate(-45deg); }
.hamburger.open span:nth-child(2) { width: 22px; transform: translateY(-4px) rotate(45deg); }

/* ── Mobile overlay menu ── */
.mobile-menu {
  display: none; position: fixed; top: 0; left: 0;
  width: 100%; height: 100vh;
  background: rgba(13,17,23,.98);
  backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px);
  z-index: 1000; flex-direction: column; align-items: center;
  justify-content: flex-start; gap: 30px;
  padding: 80px 20px; box-sizing: border-box; overflow-y: auto;
  text-align: center;
}
.mobile-menu.open { display: flex; }

/* ── Nav links inside mobile menu ── */
.mob-nav {
  display: flex !important; flex-direction: column; align-items: center;
  gap: 20px; width: 100%;
}
.mob-nav a {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.2rem; font-weight: 800;
  color: var(--silver); text-transform: uppercase; letter-spacing: .04em;
  text-decoration: none; padding: .75rem 0; width: 100%;
  border-bottom: 1px solid rgba(0,212,204,.08); transition: color .2s;
}
.mob-nav a:last-child { border-bottom: none; }
.mob-nav a:hover, .mob-nav a:focus { color: var(--cyan); }

/* ── Lang switcher inside mobile menu ── */
.mob-lang { display: flex; gap: 1rem; }

/* ── Social icons inside mobile menu ── */
.mob-social {
  display: flex !important; gap: 20px; align-items: center;
  justify-content: center; margin-top: auto; padding-bottom: 30px;
  border-top: 1px solid rgba(0,212,204,.08); width: 100%; padding-top: 1.5rem;
}
.mob-social a {
  display: flex; align-items: center; justify-content: center;
  min-width: 44px; min-height: 44px; color: var(--silver); transition: color .2s, filter .2s;
}
.mob-social a:hover { color: var(--cyan); filter: drop-shadow(0 0 8px var(--cyan)); }

/* ── Unified icon sizing (footer + mobile menu) ── */
.nav-social svg, .social-links svg, .mob-social svg {
  width: 22px !important; height: 22px !important;
  flex-shrink: 0; display: block; transition: all .3s;
}

/* ── Hero ── */
.hero {
  min-height: 100vh; display: flex; align-items: center;
  position: relative; overflow: hidden; padding-top: 5rem;
}
.hero-canvas {
  position: absolute; inset: 0; opacity: .18; pointer-events: none;
}
.hero-content { position: relative; z-index: 2; }
.hero-badge {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: .4rem 1rem; border-radius: 100px;
  border: 1px solid rgba(0,212,204,.3); background: rgba(0,212,204,.06);
  font-size: .68rem; font-weight: 700; letter-spacing: .25em; text-transform: uppercase;
  color: var(--cyan); margin-bottom: 1.5rem;
}
.hero-badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); animation: pulse 2s infinite; }
.hero h1 .accent { color: var(--cyan); }
.hero-sub {
  font-size: clamp(.95rem, 1.5vw, 1.15rem); color: var(--silver);
  max-width: 600px; margin: 1.5rem 0 2.5rem;
}
.hero-sub .mono { font-family: 'Roboto Mono', monospace; color: var(--gray); font-size: .85em; }
.btn-group { display: flex; flex-wrap: wrap; gap: 1rem; }
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 2rem; font-family: 'Montserrat', sans-serif;
  font-size: .75rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  border-radius: 2px; cursor: pointer; transition: all .2s; border: none;
  text-decoration: none;
}
.btn-primary {
  background: var(--cyan); color: var(--black);
  box-shadow: 0 0 32px rgba(0,212,204,.35);
}
.btn-primary:hover { background: var(--cyan-glow); color: var(--black); box-shadow: 0 0 48px rgba(0,255,238,.5); }
.btn-outline {
  background: transparent; color: var(--cyan);
  border: 1px solid rgba(0,212,204,.5);
}
.btn-outline:hover { background: rgba(0,212,204,.1); border-color: var(--cyan); color: var(--cyan); }

/* ── Badges / Pills ── */
.badge {
  display: inline-block; padding: .25rem .75rem; border-radius: 2px;
  font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
}
.badge-exclusive { background: rgba(0,212,204,.15); color: var(--cyan); border: 1px solid var(--cyan); }
.badge-partner   { background: rgba(107,122,141,.15); color: var(--gray); border: 1px solid var(--gray); }
.badge-active    { background: rgba(0,212,204,.1); color: var(--cyan); }
.badge-showcase  { background: rgba(107,122,141,.1); color: var(--gray); }

/* ── Cards — Glassmorphism + Glow ── */
.card {
  background: rgba(28,35,51,.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0,212,204,.13);
  border-radius: 14px; padding: 2rem;
  transition: border-color .3s, transform .3s, box-shadow .3s, background .3s;
  position: relative; overflow: hidden;
}
.card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,212,204,.03) 0%, transparent 55%);
  pointer-events: none;
}
.card:hover {
  border-color: rgba(0,212,204,.5);
  transform: translateY(-4px);
  background: rgba(28,35,51,.7);
  box-shadow: 0 0 0 1px rgba(0,212,204,.1), 0 0 28px rgba(0,212,204,.18), 0 16px 48px rgba(0,0,0,.5);
}
.card-icon {
  width: 48px; height: 48px; border-radius: 10px;
  background: rgba(0,212,204,.12); display: flex; align-items: center; justify-content: center;
  color: var(--cyan); margin-bottom: 1.2rem;
  box-shadow: 0 0 16px rgba(0,212,204,.12);
}
.card-title { font-size: 1.1rem; margin-bottom: .6rem; color: var(--white); }
.card-desc  { font-size: .9rem; color: var(--silver); line-height: 1.7; }

/* Solution cards (big) — Glassmorphism + Glow */
.sol-card {
  background: rgba(28,35,51,.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(0,212,204,.15);
  border-radius: 18px; padding: 2.5rem; position: relative; overflow: hidden;
  transition: all .35s;
}
.sol-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,212,204,.05) 0%, transparent 60%);
  pointer-events: none;
}
.sol-card:hover {
  border-color: rgba(0,212,204,.55);
  box-shadow: 0 0 36px rgba(0,212,204,.22), 0 20px 64px rgba(0,0,0,.6);
  transform: translateY(-4px);
}
.sol-card.featured { border-color: rgba(0,212,204,.35); }
.sol-card .sol-logo { height: 44px; object-fit: contain; object-position: left; margin-bottom: 1.2rem; }
.sol-card .sol-desc { font-size: .93rem; margin: .8rem 0 1.5rem; }
.sol-card .sol-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.sol-card .tag {
  font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: .2rem .65rem; background: rgba(0,212,204,.08); color: var(--cyan); border-radius: 2px;
}

/* ── Section header ── */
.section-header { margin-bottom: 3.5rem; }
.section-header h4 { margin-bottom: .5rem; }
.section-header h2 { margin-bottom: 1rem; }
.section-header p { font-size: 1rem; max-width: 560px; }

/* ── Stats ── */
.stats-row { display: flex; flex-wrap: wrap; gap: 2rem; }
.stat { text-align: left; }
.stat .num { font-family: 'Montserrat', sans-serif; font-size: 2.5rem; font-weight: 900; color: var(--cyan); line-height: 1; }
.stat .lbl { font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--gray); margin-top: .3rem; }

/* ── Grid helpers ── */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.5rem; }

/* ── CTA Banner ── */
.cta-banner {
  background: linear-gradient(135deg, var(--navy) 0%, var(--slate) 100%);
  border: 1px solid rgba(0,212,204,.2); border-radius: 16px;
  padding: clamp(2rem, 5vw, 4rem); text-align: center;
  position: relative; overflow: hidden;
}
.cta-banner::before {
  content: ''; position: absolute; top: -50%; left: 50%; transform: translateX(-50%);
  width: 600px; height: 300px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(0,212,204,.1) 0%, transparent 70%);
  pointer-events: none;
}
.cta-banner h2 { margin-bottom: 1rem; }
.cta-banner p { margin-bottom: 2rem; max-width: 500px; margin-left: auto; margin-right: auto; }

/* ── Job cards ── */
.job-card {
  background: var(--navy); border: 1px solid rgba(0,212,204,.1);
  border-radius: 12px; padding: 1.5rem 2rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  transition: all .25s;
}
.job-card:hover { border-color: rgba(0,212,204,.4); transform: translateX(4px); }
.job-card.vitrine { opacity: .7; }
.job-info { flex: 1; }
.job-title { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 1rem; color: var(--white); margin-bottom: .3rem; }
.job-meta { display: flex; gap: .75rem; flex-wrap: wrap; }
.job-meta span { font-size: .72rem; color: var(--gray); font-weight: 600; letter-spacing: .05em; }
.job-meta span::before { content: '·'; margin-right: .75rem; color: var(--gray); }
.job-meta span:first-child::before { display: none; }

/* ── Form ── */
.form-group { display: flex; flex-direction: column; gap: .5rem; }
label { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--gray); }
input, textarea, select {
  background: rgba(255,255,255,.04); border: 1px solid rgba(0,212,204,.15);
  color: var(--white); padding: .85rem 1.1rem; border-radius: 4px;
  font-family: 'Inter', sans-serif; font-size: .9rem;
  outline: none; transition: border-color .2s;
}
input:focus, textarea:focus, select:focus { border-color: var(--cyan); }
select option { background: var(--navy); }
textarea { resize: vertical; min-height: 130px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }

/* ── Footer ── */
footer {
  background: var(--black); border-top: 1px solid rgba(0,212,204,.12);
  padding: 3rem 0 1.5rem;
}
.footer-inner {
  display: flex; flex-direction: column; gap: 2rem;
}
.footer-top {
  display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; gap: 2rem;
}
.footer-links { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.footer-links a { font-size: .78rem; color: var(--gray); font-weight: 500; }
.footer-links a:hover { color: var(--cyan); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.05); padding-top: 1.5rem;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}
.footer-info { display: flex; flex-direction: column; gap: .25rem; }
.footer-copy { font-size: .75rem; color: var(--gray); }
.footer-address {
  font-size: .7rem; color: rgba(107,122,141,.7); letter-spacing: .02em;
}

/* ── Back to top ── */
#btt {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 900;
  width: 42px; height: 42px; border-radius: 4px;
  background: rgba(13,17,23,.9); border: 1px solid rgba(0,212,204,.3);
  color: var(--cyan); cursor: pointer; display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: all .3s;
  backdrop-filter: blur(8px);
}
#btt.visible { opacity: 1; pointer-events: auto; }
#btt:hover { background: rgba(0,212,204,.1); border-color: var(--cyan); }

/* ── Social Links (Footer) ── */
.social-links {
  display: flex; align-items: center; justify-content: center;
  gap: 1.5rem; flex-wrap: nowrap;
}
.social-links a {
  display: flex; align-items: center; justify-content: center;
  color: var(--silver); text-decoration: none;
  min-width: 44px; min-height: 44px; /* touch target */
  transition: color .2s, filter .2s;
}
.social-links a:hover {
  color: var(--cyan);
  filter: drop-shadow(0 0 8px var(--cyan));
}
.social-links svg {
  width: 24px; height: 24px;
  max-width: 24px; flex-shrink: 0; display: block;
}

/* ── Footer Brand Line ── */
.footer-brand {
  font-size: .72rem; color: var(--gray); margin: 0;
}
.footer-brand a {
  color: var(--silver); text-decoration: underline; text-underline-offset: 3px;
  transition: color .2s;
}
.footer-brand a:hover { color: var(--cyan); }

/* ── LGPD Banner ── */
#lgpd-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
  background: rgba(28,35,51,.97); backdrop-filter: blur(20px);
  border-top: 1px solid rgba(0,212,204,.2);
  padding: 1.2rem 2rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
  transform: translateY(0); transition: transform .4s, opacity .4s;
}
#lgpd-banner.hidden { transform: translateY(110%); opacity: 0; pointer-events: none; }
#lgpd-banner p { font-size: .8rem; color: var(--silver); flex: 1; min-width: 220px; }
#lgpd-banner a { color: var(--cyan); }
.lgpd-btns { display: flex; gap: .75rem; flex-wrap: wrap; }
.lgpd-accept {
  padding: .5rem 1.4rem; background: var(--cyan); color: var(--black);
  border: none; border-radius: 3px; font-size: .75rem; font-weight: 800;
  letter-spacing: .08em; text-transform: uppercase; cursor: pointer;
  font-family: 'Montserrat', sans-serif;
}
.lgpd-essential {
  padding: .5rem 1.4rem; background: transparent; color: var(--silver);
  border: 1px solid rgba(200,208,220,.3); border-radius: 3px; font-size: .75rem; font-weight: 600;
  letter-spacing: .05em; text-transform: uppercase; cursor: pointer;
  font-family: 'Montserrat', sans-serif;
}

/* ── Animations ── */
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.4;} }
@keyframes fade-up { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:none;} }

.rv { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s ease; }
.rv.animate { opacity: 0; transform: translateY(20px); }
.rv.visible { opacity: 1; transform: none; }
.rv-d1 { transition-delay: .1s; }
.rv-d2 { transition-delay: .2s; }
.rv-d3 { transition-delay: .3s; }
.rv-d4 { transition-delay: .4s; }

/* ── Utility ── */
.text-cyan   { color: var(--cyan); }
.text-silver { color: var(--silver); }
.text-gray   { color: var(--gray); }
.text-white  { color: var(--white); }
.text-center { text-align: center; }
.mt-1 { margin-top: .5rem; }  .mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; } .mt-4 { margin-top: 2rem; }
.mb-1 { margin-bottom: .5rem; } .mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(0,212,204,.3), transparent); margin: 3rem 0; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .stats-row { gap: 1.5rem; }
  .job-card { flex-direction: column; align-items: flex-start; }
  .footer-top { flex-direction: column; }
}
@media (max-width: 600px) {
  .btn-group { flex-direction: column; }
  .btn { justify-content: center; }
}
@media (max-width: 768px) {
  /* ── Footer mobile ── */
  .footer-bottom {
    flex-direction: column; align-items: center; text-align: center;
  }
  .footer-brand { text-align: center; }
  .social-links { gap: 1.5rem; }
  .social-links svg { width: 22px; height: 22px; max-width: 22px; }
}

/* ── Breadcrumb nav (landing pages) ── */
.breadcrumb {
  display: flex; align-items: center; gap: .5rem;
  font-size: .72rem; color: var(--gray); font-weight: 600; letter-spacing: .05em;
  text-transform: uppercase; margin-bottom: 1.5rem;
}
.breadcrumb a { color: var(--cyan); }
.breadcrumb .sep { color: var(--gray); }

/* ── Feature list ── */
.feature-list { list-style: none; display: flex; flex-direction: column; gap: .9rem; }
.feature-list li {
  display: flex; align-items: flex-start; gap: .75rem; font-size: .93rem;
}
.feature-list li::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--cyan); margin-top: .55rem; flex-shrink: 0;
}

/* ── Compliance badges row ── */
.compliance-row { display: flex; flex-wrap: wrap; gap: .75rem; }
.compliance-badge {
  padding: .4rem 1rem; background: rgba(0,212,204,.07);
  border: 1px solid rgba(0,212,204,.2); border-radius: 4px;
  font-size: .72rem; font-weight: 700; letter-spacing: .1em; color: var(--cyan);
}

/* ── Tabs ── */
.tab-nav { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.tab-btn {
  padding: .5rem 1.2rem; background: transparent;
  border: 1px solid rgba(0,212,204,.15); border-radius: 4px;
  color: var(--silver); font-size: .75rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; cursor: pointer; font-family: 'Montserrat', sans-serif;
  transition: all .2s;
}
.tab-btn.active { background: var(--cyan); color: var(--black); border-color: var(--cyan); }
.tab-btn:hover:not(.active) { border-color: var(--cyan); color: var(--cyan); }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ── Process steps ── */
.steps { display: flex; flex-direction: column; gap: 0; }
.step { display: flex; gap: 1.5rem; position: relative; padding-bottom: 2rem; }
.step:last-child { padding-bottom: 0; }
.step-num {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%;
  background: rgba(0,212,204,.1); border: 2px solid var(--cyan);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-size: .85rem; font-weight: 900; color: var(--cyan);
}
.step-line {
  position: absolute; left: 21px; top: 44px; bottom: 0; width: 2px;
  background: linear-gradient(to bottom, rgba(0,212,204,.3), transparent);
}
.step:last-child .step-line { display: none; }
.step-content { padding-top: .5rem; }
.step-content h3 { font-size: 1rem; margin-bottom: .4rem; }
.step-content p { font-size: .88rem; color: var(--silver); }

/* ── Success message ── */
.form-success {
  display: none; padding: 2rem; border: 1px solid var(--cyan);
  border-radius: 8px; background: rgba(0,212,204,.07); text-align: center;
}
.form-success.show { display: block; }
.form-success svg { width: 40px; height: 40px; color: var(--cyan); margin: 0 auto 1rem; display: block; }

/* ═══════════════════════════════════════════════════════════
   XOne Data Cards — Animated Bar Charts
   ═══════════════════════════════════════════════════════════ */
.data-cards-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem;
}
.data-card {
  background: rgba(0,212,204,.04);
  border: 1px solid rgba(0,212,204,.2);
  border-radius: 8px; padding: 2rem 1.5rem;
  display: flex; flex-direction: column; gap: 1.5rem;
  backdrop-filter: blur(8px);
  transition: border-color .3s, box-shadow .3s;
}
.data-card:hover {
  border-color: rgba(0,212,204,.5);
  box-shadow: 0 0 32px rgba(0,212,204,.1);
}
.data-card-label {
  font-size: .65rem; font-weight: 800; letter-spacing: .22em;
  text-transform: uppercase; color: var(--cyan);
}
/* Bar chart container */
.data-card-bars {
  display: flex; align-items: flex-end; gap: 1.5rem;
  height: 80px; width: 100%;
}
.data-card-bars--triple { gap: .75rem; }
.bar-wrap {
  display: flex; flex-direction: column; align-items: center; gap: .4rem; flex: 1;
}
.bar-wrap span {
  font-size: .58rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--gray);
}
/* Bar base — starts at scaleY(0), animated to scaleY(1) on .bars-go */
.bar {
  width: 100%; border-radius: 3px 3px 0 0;
  background: rgba(200,208,220,.12);
  transform: scaleY(0); transform-origin: bottom;
  transition: transform .9s cubic-bezier(.4,0,.2,1) var(--d, 0s);
}
.bars-go .bar { transform: scaleY(1); }
.bar-active {
  background: linear-gradient(180deg, var(--cyan) 0%, rgba(0,212,204,.35) 100%);
  box-shadow: 0 0 14px rgba(0,212,204,.25);
}
.bar-muted {
  background: rgba(200,208,220,.18);
}
.bar-danger {
  background: linear-gradient(180deg, rgba(255,72,72,.7) 0%, rgba(255,72,72,.15) 100%);
}
/* Stat row */
.data-card-stat { display: flex; flex-direction: column; gap: .15rem; }
.data-card-number {
  font-family: 'Montserrat', sans-serif; font-size: 2.2rem; font-weight: 900;
  color: var(--cyan); line-height: 1;
}
.data-card-desc { font-size: .7rem; color: var(--gray); letter-spacing: .04em; }
@media (max-width: 900px) { .data-cards-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   Rezilient Availability Dashboard — 99.9% Neon Circle
   ═══════════════════════════════════════════════════════════ */
.avail-section { padding: 2rem 0 4rem; }
.avail-dashboard {
  display: flex; align-items: center; gap: 4rem;
  background: rgba(0,212,204,.03);
  border: 1px solid rgba(0,212,204,.12);
  border-radius: 12px; padding: 3rem;
  backdrop-filter: blur(8px);
}
.avail-ring-wrap {
  position: relative; flex-shrink: 0; width: 200px; height: 200px;
}
.avail-ring { width: 200px; height: 200px; }
/* Arc animates from full offset (invisible) to near-zero (99.9% fill) */
.avail-arc {
  stroke-dashoffset: 502.65;
  transition: stroke-dashoffset 2s cubic-bezier(.4,0,.2,1) .4s;
}
.avail-arc.arc-go { stroke-dashoffset: 0.5; }
.avail-ring-inner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
}
.avail-number {
  font-family: 'Montserrat', sans-serif; font-size: 2rem; font-weight: 900;
  color: var(--cyan);
  text-shadow: 0 0 24px rgba(0,212,204,.6);
  line-height: 1;
}
.avail-sublabel {
  font-size: .6rem; font-weight: 800; letter-spacing: .2em;
  text-transform: uppercase; color: var(--gray); margin-top: .3rem;
}
.avail-stats {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 1.25rem; flex: 1;
}
.avail-stat {
  background: rgba(0,212,204,.04);
  border: 1px solid rgba(0,212,204,.1);
  border-radius: 6px; padding: 1.25rem 1.5rem;
  transition: border-color .3s;
}
.avail-stat:hover { border-color: rgba(0,212,204,.3); }
.avail-stat-value {
  font-family: 'Montserrat', sans-serif; font-size: 1.5rem; font-weight: 900;
  color: var(--cyan); line-height: 1; margin-bottom: .35rem;
}
.avail-stat-label {
  font-size: .7rem; color: var(--silver); letter-spacing: .03em;
}
@media (max-width: 768px) {
  .avail-dashboard { flex-direction: column; gap: 2rem; padding: 2rem; text-align: center; }
  .avail-stats { grid-template-columns: repeat(2,1fr); width: 100%; }
}

/* ── Logo img no navbar ─────────────────── */
.nav-logo-img {
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 0 8px rgba(0,212,204,.3));
}
.orb-logo-img {
  width: 80px;
  height: auto;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

/* ═══════════════════════════════════════════════════════════
   Data Highlight — cyan left-border callout block
   ═══════════════════════════════════════════════════════════ */
.data-highlight {
  background: rgba(0,212,204,.05);
  border-left: 3px solid var(--cyan);
  padding: 1.5rem 2rem;
  border-radius: 0 10px 10px 0;
  margin: 1.5rem 0;
}
.data-highlight h3,
.data-highlight h4 { color: var(--cyan); margin-bottom: .5rem; }
.data-highlight p  { font-size: .92rem; color: var(--silver); margin: 0; }

/* ═══════════════════════════════════════════════════════════
   Glass Feature Card — glassmorphism elevated card
   ═══════════════════════════════════════════════════════════ */
.glass-feature-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 15px;
  padding: 2rem;
  transition: border-color .3s, box-shadow .3s, transform .3s;
}
.glass-feature-card:hover {
  border-color: rgba(0,212,204,.45);
  box-shadow: 0 0 28px rgba(0,212,204,.12);
  transform: translateY(-2px);
}
.glass-feature-card .card-icon { color: var(--cyan); margin-bottom: 1rem; }
.glass-feature-card .card-title { margin-bottom: .6rem; }
.glass-feature-card .card-desc  { font-size: .9rem; color: var(--silver); }
