/* ═══════════════════════════════════
   NxtVision Theme — Main Stylesheet
   File: css/style.css
   Usage: <link rel="stylesheet" href="css/style.css">
═══════════════════════════════════ */

:root{
  --bg:#f4f7fb;--bg2:#e8eef8;
  --ink:#0d2744;--ink2:#1e3a5f;--muted:#5a7390;
  --accent:#1976a8;--accent-dark:#0d5c87;--accent-light:#e4f1f9;
  --accent2:#2196c4;--accent2-light:#dcf0f9;
  --navy:#0d2744;--border:#cddaed;--card:#ffffff;
  --font-head:'Fraunces',Georgia,serif;
  --font-body:'Cabinet Grotesk','Inter',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.65;font-size:16px}

/* ── UTILITIES ── */
.container{max-width:1180px;margin:0 auto;padding:0 5vw}
section{padding:5rem 5vw}
.sec-tag{display:inline-block;font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:0.3rem 0.85rem;border-radius:999px;margin-bottom:1rem}
.sec-title{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.15;margin-bottom:1.25rem;color:var(--ink)}
.sec-sub{color:var(--muted);font-size:1.05rem;max-width:560px;line-height:1.7;margin-bottom:2.5rem}
.btn-primary{display:inline-flex;align-items:center;gap:0.5rem;background:var(--accent);color:#fff;padding:0.85rem 2rem;border-radius:8px;font-weight:700;font-size:0.95rem;text-decoration:none;transition:background 0.2s,transform 0.15s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;gap:0.5rem;background:transparent;color:var(--accent);padding:0.85rem 2rem;border-radius:8px;font-weight:700;font-size:0.95rem;text-decoration:none;border:2px solid var(--accent);transition:all 0.2s;cursor:pointer}
.btn-outline:hover{background:var(--accent-light)}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:rgba(244,247,251,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:68px;display:flex;align-items:center;padding:0 5vw;gap:2rem}
.logo-wrap{display:flex;align-items:center;text-decoration:none;cursor:pointer;flex-shrink:0}
.logo-wrap img{height:44px;width:auto;object-fit:contain;display:block}
.nav-links{display:flex;list-style:none;gap:0.25rem;margin-left:auto}
.nav-links a{color:var(--ink2);text-decoration:none;font-size:0.9rem;font-weight:500;padding:0.45rem 0.9rem;border-radius:6px;transition:background 0.18s,color 0.18s;cursor:pointer}
.nav-links a:hover,.nav-links a.active{background:var(--accent-light);color:var(--accent)}
.nav-social{display:flex;gap:0.4rem;align-items:center;margin-left:0.5rem}
.nav-social a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--muted);transition:color 0.2s,background 0.2s}
.nav-social a:hover{color:var(--accent);background:var(--accent-light)}
.btn-nav{background:var(--accent);color:#fff;border:none;padding:0.55rem 1.3rem;border-radius:7px;font-weight:700;font-size:0.88rem;cursor:pointer;transition:background 0.2s;margin-left:0.5rem;white-space:nowrap}
.btn-nav:hover{background:var(--accent-dark)}
@media(max-width:768px){
  .nav-links li:not(:first-child){display:none}
  .nav-social{display:none}
}

/* ── PAGE ROUTING ── */
.page{display:none}
.page.active{display:block}

/* ── HERO ── */
.hero{min-height:88vh;display:flex;align-items:center;padding:5rem 5vw 4rem;background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg) 60%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 40%,rgba(33,150,196,0.12) 0%,transparent 65%);pointer-events:none}
.hero-content{max-width:640px;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(25,118,168,0.12);border:1px solid rgba(25,118,168,0.25);color:var(--accent);font-size:0.78rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.4rem 1rem;border-radius:999px;margin-bottom:1.5rem}
.hero h1{font-family:var(--font-head);font-size:clamp(2.6rem,5.5vw,4rem);font-weight:800;line-height:1.1;color:var(--ink);margin-bottom:1.4rem}
.hero p{color:var(--muted);font-size:1.1rem;line-height:1.75;margin-bottom:2.5rem;max-width:520px}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.5rem;margin-top:4rem;flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat-n{font-family:var(--font-head);font-size:2.2rem;font-weight:800;color:var(--accent);line-height:1}
.stat-l{font-size:0.8rem;color:var(--muted);font-weight:500;margin-top:0.3rem;text-transform:uppercase;letter-spacing:0.06em}

/* ── MARQUEE ── */
.marquee-wrap{background:var(--accent);padding:0.75rem 0;overflow:hidden}
.marquee-track{display:flex;gap:2.5rem;animation:marquee 30s linear infinite;white-space:nowrap}
.marquee-track span{color:rgba(255,255,255,0.9);font-size:0.82rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
.marquee-track .dot{color:rgba(255,255,255,0.4)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SERVICES ── */
#services{background:var(--bg2)}
.services-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1.5rem}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:2rem;transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s;position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-light),transparent 60%);opacity:0;transition:opacity 0.25s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(13,39,68,0.12);border-color:var(--accent)}
.svc-card:hover::before{opacity:1}
.svc-num{font-size:0.7rem;font-weight:800;letter-spacing:0.12em;color:var(--accent);margin-bottom:0.75rem;position:relative}
.svc-icon{font-size:2rem;margin-bottom:0.75rem;position:relative}
.svc-card h3{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--ink);margin-bottom:0.6rem;position:relative}
.svc-card p{color:var(--muted);font-size:0.9rem;line-height:1.65;position:relative}

/* ── ABOUT ── */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.value-list{display:flex;flex-direction:column;gap:1.25rem;margin-top:2rem}
.val{padding:1.2rem 1.4rem;background:var(--card);border:1px solid var(--border);border-radius:10px}
.val h4{font-weight:700;font-size:0.92rem;margin-bottom:0.35rem;color:var(--ink)}
.val p{color:var(--muted);font-size:0.87rem;line-height:1.6}
.skill-item{margin-bottom:1.25rem}
.skill-top{display:flex;justify-content:space-between;margin-bottom:0.4rem}
.skill-nm{font-weight:600;font-size:0.88rem;color:var(--ink)}
.skill-pc{font-size:0.82rem;color:var(--muted)}
.skill-bar{height:7px;background:var(--bg2);border-radius:999px;overflow:hidden}
.skill-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px;width:0;transition:width 1.2s cubic-bezier(.4,0,.2,1)}

/* ── TIMELINE ── */
#history{background:var(--bg2)}
.timeline{display:flex;flex-direction:column;gap:0;max-width:720px;margin:0 auto;position:relative}
.timeline::before{content:'';position:absolute;left:80px;top:0;bottom:0;width:2px;background:var(--border)}
.tl-item{display:flex;gap:0;align-items:flex-start;padding:0 0 2.5rem 0;position:relative}
.tl-date{min-width:80px;font-family:var(--font-head);font-size:0.8rem;font-weight:700;color:var(--accent);text-align:center;padding-top:0.35rem;line-height:1.2}
.tl-dot{width:14px;height:14px;background:var(--accent);border-radius:50%;border:3px solid var(--bg2);flex-shrink:0;margin-top:0.4rem;position:relative;z-index:1}
.tl-body{padding-left:1.25rem}
.tl-body h4{font-weight:700;color:var(--ink);margin-bottom:0.3rem;font-size:0.97rem}
.tl-body p{color:var(--muted);font-size:0.88rem;line-height:1.6}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2.5rem}
.testi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:2rem;position:relative}
.testi-q{font-family:var(--font-head);font-size:3rem;color:var(--accent-light);line-height:1;margin-bottom:-0.5rem}
.stars{color:#f59e0b;font-size:0.9rem;margin-bottom:0.75rem}
.testi p{color:var(--muted);font-size:0.9rem;line-height:1.65;margin-bottom:1rem}
.testi-name{font-weight:700;font-size:0.88rem;color:var(--ink)}
.testi-role{font-size:0.8rem;color:var(--muted)}

/* ── FOOTER ── */
footer{background:var(--navy);padding:4rem 5vw 2rem;color:rgba(200,215,255,0.7)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{color:rgba(200,215,255,0.5);font-size:0.85rem;margin-top:1rem;line-height:1.7;max-width:260px}
.footer-social{display:flex;gap:0.6rem;margin-top:1.5rem}
.footer-social a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;color:rgba(200,215,255,0.5);border:1px solid rgba(200,215,255,0.15);text-decoration:none;transition:all 0.2s}
.footer-social a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
.footer-col h5{font-family:var(--font-head);font-weight:700;font-size:0.85rem;letter-spacing:0.03em;margin-bottom:1.25rem;color:rgba(250,252,255,0.9)}
.footer-col a{display:block;color:rgba(200,210,240,0.55);text-decoration:none;font-size:0.85rem;margin-bottom:0.6rem;transition:color 0.2s;cursor:pointer}
.footer-col a:hover{color:#7eb3ff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid rgba(200,215,255,0.1);font-size:0.8rem;flex-wrap:wrap;gap:1rem}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{color:rgba(200,210,240,0.35);text-decoration:none;transition:color 0.2s;cursor:pointer}
.footer-legal a:hover{color:rgba(220,230,255,0.75)}

/* PAGE HERO */
.page-hero{padding:4.5rem 5vw 3rem;background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg) 70%);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(33,150,196,0.10) 0%,transparent 65%);pointer-events:none}
.page-hero-inner{max-width:760px;position:relative}
.page-tag{display:inline-block;font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);background:rgba(25,118,168,0.12);border:1px solid rgba(25,118,168,0.2);padding:0.3rem 0.9rem;border-radius:999px;margin-bottom:1.2rem}
.page-title{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.2rem);font-weight:800;line-height:1.1;color:var(--ink);margin-bottom:0.75rem}
.page-meta{color:var(--muted);font-size:0.88rem}
.page-meta span{margin:0 0.4rem;opacity:0.5}

/* ── POLICY PAGES ── */
/* .page-hero{padding:4rem 5vw 2rem;background:linear-gradient(135deg,var(--accent-light),var(--bg))}
.page-hero-inner{max-width:700px} */
.policy-tag{display:inline-block;font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:0.3rem 0.85rem;border-radius:999px;margin-bottom:1rem}
.policy-title{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.12;color:var(--ink);margin-bottom:0.75rem}
.policy-meta{color:var(--muted);font-size:0.88rem}
.policy-body{max-width:780px;margin:0 auto;padding:3rem 5vw 4rem}
.policy-body h2{font-family:var(--font-head);font-weight:700;font-size:1.35rem;color:var(--ink);margin:2.5rem 0 0.75rem}
.policy-body p{color:var(--muted);line-height:1.75;margin-bottom:1rem;font-size:0.97rem}
.policy-body ul{color:var(--muted);line-height:1.75;margin:0.75rem 0 1rem 1.5rem;font-size:0.97rem}
.policy-body li{margin-bottom:0.4rem}
.policy-box{background:var(--accent-light);border-left:4px solid var(--accent);border-radius:0 10px 10px 0;padding:1rem 1.5rem;margin-bottom:2rem}
.policy-box p{margin:0;color:var(--ink);font-weight:500}
.policy-divider{border:none;border-top:1px solid var(--border);margin:3rem 0 2rem}

/* ── CONTACT PAGE ── */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:3rem 5vw 0}
.contact-form-wrap{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem;margin-bottom:1rem}
.form-group label{font-size:0.82rem;font-weight:600;color:var(--ink)}
.form-group input,.form-group textarea,.form-group select{border:1.5px solid var(--border);border-radius:8px;padding:0.7rem 1rem;font-size:0.95rem;font-family:var(--font-body);color:var(--ink);background:var(--bg);transition:border-color 0.2s,box-shadow 0.2s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(25,118,168,0.12)}
.form-group textarea{resize:vertical;min-height:120px}
.form-status{margin-top:0.75rem;font-size:0.88rem;display:none}
.form-status.ok{color:#16a34a;display:block}
.form-status.err{color:#dc2626;display:block}
.contact-info{display:flex;flex-direction:column;gap:1.5rem;padding-top:1rem}
.info-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem}
.info-card h4{font-weight:700;font-size:0.92rem;color:var(--ink);margin-bottom:0.75rem}
.info-card p,.info-card a{color:var(--muted);font-size:0.88rem;line-height:1.65;text-decoration:none;display:block}
.contact-social-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem}
.soc-btn{display:flex;align-items:center;gap:0.6rem;padding:0.75rem 1rem;border-radius:9px;font-size:0.82rem;font-weight:600;text-decoration:none;transition:all 0.2s;border:1.5px solid var(--border);color:var(--ink);background:var(--card)}
.soc-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}

/* ── CHATBOT ── */
.chat-fab{position:fixed;bottom:2rem;right:2rem;width:58px;height:58px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 6px 24px rgba(13,39,68,0.25);z-index:999;display:flex;align-items:center;justify-content:center;transition:transform 0.2s,box-shadow 0.2s;position:fixed}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 10px 32px rgba(13,39,68,0.35)}
.chat-badge-dot{position:absolute;top:8px;right:6px;background:#ef4444;color:#fff;font-size:0.52rem;font-weight:800;padding:1px 4px;border-radius:999px}
.chat-window{position:fixed;bottom:5.5rem;right:2rem;width:360px;max-height:520px;background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 60px rgba(13,39,68,0.2);display:flex;flex-direction:column;z-index:998;overflow:hidden;opacity:0;pointer-events:none;transform:translateY(12px) scale(0.97);transition:all 0.25s cubic-bezier(.4,0,.2,1)}
.chat-window.open{opacity:1;pointer-events:all;transform:none}
.chat-hdr{background:var(--accent);color:#fff;padding:1rem 1.25rem;display:flex;align-items:center;gap:0.75rem}
.chat-av{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.chat-hdr-info h4{font-size:0.9rem;font-weight:700}
.chat-hdr-info p{font-size:0.73rem;opacity:0.8}
.chat-x{margin-left:auto;background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;opacity:0.8;padding:0.2rem}
.chat-x:hover{opacity:1}
.chat-msgs{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:0.75rem}
.msg{max-width:82%;padding:0.65rem 0.95rem;border-radius:14px;font-size:0.88rem;line-height:1.55}
.msg.bot{background:var(--bg2);color:var(--ink);align-self:flex-start;border-bottom-left-radius:4px}
.msg.user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-typing{display:flex;gap:4px;padding:0.65rem 0.95rem;background:var(--bg2);border-radius:14px;align-self:flex-start;border-bottom-left-radius:4px}
.dt{width:7px;height:7px;background:var(--muted);border-radius:50%;animation:bounce 1.2s infinite}
.dt:nth-child(2){animation-delay:0.2s}
.dt:nth-child(3){animation-delay:0.4s}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.chat-quick{display:flex;flex-wrap:wrap;gap:0.5rem;padding:0 1rem 0.75rem}
.qb{background:var(--accent-light);color:var(--accent);border:1px solid rgba(25,118,168,0.25);border-radius:999px;padding:0.35rem 0.85rem;font-size:0.78rem;font-weight:600;cursor:pointer;transition:background 0.18s}
.qb:hover{background:var(--accent);color:#fff}
.chat-in-row{display:flex;gap:0.5rem;padding:0.75rem 1rem 1rem;border-top:1px solid var(--border)}
.chat-input{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:0.55rem 0.9rem;font-size:0.88rem;font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.chat-input:focus{border-color:var(--accent)}
.chat-send{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:0.55rem 0.9rem;cursor:pointer;font-size:1rem;transition:background 0.2s}
.chat-send:hover{background:var(--accent-dark)}

/* ── COOKIE BANNER ── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--navy);color:rgba(220,230,255,0.85);padding:1rem 5vw;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;z-index:1000;border-top:2px solid var(--accent);flex-wrap:wrap;transform:translateY(0);transition:transform 0.35s}
.cookie-banner.hidden{transform:translateY(110%)}
.cookie-banner p{font-size:0.88rem;line-height:1.5;max-width:680px}
.cookie-banner a{color:var(--accent2);text-decoration:underline;cursor:pointer}
.cookie-btns{display:flex;gap:0.75rem;flex-shrink:0}
.cookie-accept{background:var(--accent);color:#fff;border:none;padding:0.55rem 1.4rem;border-radius:7px;font-weight:700;font-size:0.88rem;cursor:pointer;transition:background 0.2s}
.cookie-accept:hover{background:var(--accent-dark)}
.cookie-decline{background:transparent;color:rgba(200,210,240,0.6);border:1px solid rgba(200,210,240,0.25);padding:0.55rem 1.1rem;border-radius:7px;font-size:0.88rem;cursor:pointer;transition:all 0.2s}
.cookie-decline:hover{border-color:rgba(200,210,240,0.5);color:rgba(220,230,255,0.85)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.in{opacity:1;transform:none}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .about-layout{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .contact-layout{grid-template-columns:1fr}
}
@media(max-width:600px){
  .footer-top{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .contact-social-grid{grid-template-columns:1fr 1fr}
  .hero-stats{gap:1.5rem}
  .chat-window{width:calc(100vw - 2rem);right:1rem}
}

/* ── HERO VISUAL ── */
.hero{display:flex;align-items:center;gap:4rem;justify-content:space-between}
.hero-content{flex:0 0 auto;max-width:580px}
.hero-visual{flex:1;min-width:340px;max-width:480px;position:relative;height:480px;display:flex;align-items:center;justify-content:center}
.hv-orbit{position:relative;width:260px;height:260px}
.hv-globe{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.hv-globe-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(25,118,168,0.25)}
.hv-globe-ring.r1{inset:-12px;animation:spin 18s linear infinite}
.hv-globe-ring.r2{inset:-32px;border-color:rgba(33,150,196,0.18);animation:spin 26s linear infinite reverse}
.hv-globe-ring.r3{inset:-55px;border-color:rgba(25,118,168,0.10);animation:spin 38s linear infinite}
.hv-globe-core{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,var(--accent-light),var(--bg2));border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:4rem;box-shadow:0 8px 40px rgba(25,118,168,0.18),inset 0 2px 8px rgba(255,255,255,0.8)}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Orbiting dots */
.hv-dot{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--accent)}
.hv-dot.d1{top:-6px;left:50%;transform:translateX(-50%);animation:orbit1 18s linear infinite;box-shadow:0 0 8px var(--accent)}
.hv-dot.d2{right:-6px;top:50%;transform:translateY(-50%);animation:orbit2 26s linear infinite;background:var(--accent2);box-shadow:0 0 8px var(--accent2)}
.hv-dot.d3{bottom:-6px;left:50%;transform:translateX(-50%);animation:orbit3 18s linear infinite;opacity:0.7}
.hv-dot.d4{left:-6px;top:50%;transform:translateY(-50%);animation:orbit4 26s linear infinite;background:var(--accent2);opacity:0.7}
@keyframes orbit1{from{top:-6px;left:50%}25%{top:50%;left:calc(100% + 6px)}50%{top:calc(100% + 6px);left:50%}75%{top:50%;left:-6px}to{top:-6px;left:50%}}
@keyframes orbit2{from{right:-6px;top:50%}25%{top:calc(100% + 6px);right:50%}50%{top:50%;right:calc(100% + 6px)}75%{top:-6px;right:50%}to{right:-6px;top:50%}}
@keyframes orbit3{from{bottom:-6px;left:50%}25%{bottom:50%;left:-6px}50%{bottom:calc(100% + 6px);left:50%}75%{bottom:50%;left:calc(100% + 6px)}to{bottom:-6px;left:50%}}
@keyframes orbit4{from{left:-6px;top:50%}25%{top:-6px;left:50%}50%{top:50%;left:calc(100% + 6px)}75%{top:calc(100% + 6px);left:50%}to{left:-6px;top:50%}}

/* Floating service cards */
.hv-card{position:absolute;display:flex;align-items:center;gap:0.6rem;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:0.65rem 0.9rem;box-shadow:0 6px 24px rgba(13,39,68,0.1);white-space:nowrap;animation:float 4s ease-in-out infinite}
.hv-card-icon{font-size:1.4rem}
.hv-card-title{font-size:0.8rem;font-weight:700;color:var(--ink);line-height:1.2}
.hv-card-sub{font-size:0.7rem;color:var(--muted)}
.fc1{top:20px;left:-30px;animation-delay:0s}
.fc2{top:20px;right:-20px;animation-delay:1s}
.fc3{bottom:60px;left:-40px;animation-delay:2s}
.fc4{bottom:60px;right:-20px;animation-delay:0.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Badge floats */
.hv-badge-float{position:absolute;background:var(--accent);color:#fff;border-radius:10px;padding:0.5rem 0.85rem;text-align:center;box-shadow:0 4px 16px rgba(25,118,168,0.3)}
.hv-bf-num{font-family:'Fraunces',Georgia,serif;font-size:1.2rem;font-weight:800;line-height:1}
.hv-bf-lbl{font-size:0.65rem;opacity:0.9;margin-top:0.15rem}
.bf1{top:50%;left:-70px;transform:translateY(-50%);animation:float 5s ease-in-out infinite}
.bf2{top:-20px;right:50%;transform:translateX(50%);animation:float 5s ease-in-out infinite 1.5s;background:var(--ink)}

/* Tech chips */
.hv-dots-grid{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);display:flex;gap:0.4rem;flex-wrap:wrap;justify-content:center;max-width:280px}
.hv-tech-chip{background:var(--bg2);border:1px solid var(--border);color:var(--muted);font-size:0.7rem;font-weight:600;padding:0.25rem 0.7rem;border-radius:999px;transition:all 0.2s}
.hv-tech-chip:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}

@media(max-width:900px){
  .hero{flex-direction:column;gap:2rem}
  .hero-visual{display:none}
}