/* ══════════════════════════════════════
   BGH.DEV — STYLESHEET v3
   ══════════════════════════════════════ */

:root {
  --lime:    #D9FF00;
  --black:   #000000;
  --dark:    #060606;
  --surf:    #0d0d0d;
  --border:  rgba(255,255,255,0.07);
  --borderh: rgba(255,255,255,0.14);
  --white:   #F0F0EB;
  --dim:     rgba(240,240,235,0.42);
  --mid:     #3a3a3a;
  --ff-d: 'Barlow Condensed', sans-serif;
  --ff-b: 'Space Grotesk', sans-serif;
  --ease: cubic-bezier(0.16,1,0.3,1);
}

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

html {
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: #1a1a1a #000;
}
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:#000; }
::-webkit-scrollbar-thumb { background:#222; }

body {
  background: var(--black);
  color: var(--white);
  font-family: var(--ff-b);
  font-size: 14px;
  line-height: 1.65;
  overflow-x: hidden;
  cursor: none;
}
a { text-decoration:none; color:inherit; }

/* ══ ORB LAYER (fixed, above content, below nav) ══ */
#orb-canvas {
  position: fixed; inset:0;
  width:100vw !important; height:100vh !important;
  z-index: 1; pointer-events: none;
}
.orb-glow, .orb-chr-r, .orb-chr-b {
  position: fixed; border-radius:50%;
  z-index: 1; pointer-events:none;
  transform: translate(-50%,-50%);
  opacity: 0;
  transition: width .7s var(--ease), height .7s var(--ease), opacity .5s,
              left .9s var(--ease), top .7s var(--ease);
}
.orb-glow {
  background: radial-gradient(circle, rgba(217,255,0,0.28) 0%, rgba(217,255,0,0.06) 50%, transparent 72%);
  filter: blur(55px);
  width: 280px; height: 280px;
}
.orb-chr-r {
  background: radial-gradient(circle, rgba(255,80,0,0.12) 0%, transparent 65%);
  filter: blur(70px); width:250px; height:250px;
}
.orb-chr-b {
  background: radial-gradient(circle, rgba(0,120,255,0.12) 0%, transparent 65%);
  filter: blur(70px); width:250px; height:250px;
}

/* ══ GRAIN ══ */
.grain-overlay {
  position:fixed; inset:0; z-index:9990;
  pointer-events:none; opacity:.055;
  background-size:200px 200px; background-repeat:repeat;
  mix-blend-mode:overlay;
}

/* ══ CURSOR ══ */
.cursor-dot {
  position:fixed; width:6px; height:6px;
  background:var(--lime); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .15s, height .15s;
}
.cursor-ring {
  position:fixed; width:28px; height:28px;
  border:1px solid rgba(217,255,0,.45); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), border-color .3s;
}
.cursor-dot.hov { width:10px; height:10px; }
.cursor-ring.hov { width:46px; height:46px; border-color:rgba(217,255,0,.2); }

/* ══ LOADER ══ */
.loader {
  position:fixed; inset:0; z-index:9500;
  background:var(--black);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .9s var(--ease);
}
.loader.out { opacity:0; pointer-events:none; }
.ld-inner { display:flex; flex-direction:column; align-items:center; gap:28px; }
.ld-logo { height:72px; width:auto; }
.ld-bar { width:200px; height:1px; background:rgba(255,255,255,.1); overflow:hidden; }
.ld-fill { height:100%; background:var(--lime); width:0; transition:width .08s linear; }
.ld-tag { font-size:10px; letter-spacing:.22em; color:var(--mid); text-transform:uppercase; }

/* ══ NAV ══ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 44px;
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  background:rgba(0,0,0,.6);
  transition:border-color .4s, background .4s;
}
nav.scrolled { border-color:var(--borderh); background:rgba(0,0,0,.85); }
.nav-l { font-size:11px; color:var(--mid); letter-spacing:.1em; }
.nav-logo-wrap { position:absolute; left:50%; transform:translateX(-50%); }
.nav-logo-img { height:36px; width:auto; display:block; }
.nav-r { display:flex; align-items:center; gap:24px; }
.nav-links { list-style:none; display:flex; gap:18px; }
.nav-links a {
  font-size:10px; letter-spacing:.2em; color:var(--mid);
  text-transform:uppercase; transition:color .2s;
}
.nav-links a:hover { color:var(--white); }
.nav-cta {
  font-family:var(--ff-d); font-size:12px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--black); background:var(--lime);
  padding:8px 18px; transition:opacity .2s;
}
.nav-cta:hover { opacity:.82; }

/* ══ MAIN & SECTIONS ══ */
main { position:relative; z-index:10; }

.sec {
  width:100%; min-height:100vh;
  display:flex; align-items:center;
  padding:100px 0;
  border-top:1px solid var(--border);
  position:relative;
}
.sec:first-child { border-top:none; }

.sec-inner { width:100%; padding:0 60px; }
.left-half  { max-width:680px; padding-left:60px; margin:0; }
.right-half { max-width:680px; padding-right:60px; margin:0 0 0 auto; }
.center-half { max-width:720px; margin:0 auto; text-align:center; }
.full-width { max-width:1300px; margin:0 auto; padding:0 60px; }

.sec-label {
  display:flex; gap:8px; align-items:center;
  font-size:10px; letter-spacing:.22em; color:var(--mid);
  text-transform:uppercase;
  padding-bottom:14px; margin-bottom:48px;
  border-bottom:1px solid var(--border);
}

.lime { color:var(--lime); }
.sep  { color:var(--mid); }

/* Reveal */
.reveal {
  opacity:0; transform:translateY(26px);
  transition: opacity .85s var(--ease), transform .85s var(--ease);
}
.reveal.on { opacity:1; transform:translateY(0); }

/* ══ HERO ══ */
#hero {
  height:100vh; min-height:600px;
  padding:0; align-items:stretch;
  border-top:none;
}
.hero-inner {
  display:flex; flex-direction:column;
  justify-content:space-between;
  padding:100px 60px 40px;
  max-width:680px; width:100%; height:100%;
}
.hero-meta {
  display:flex; align-items:center; gap:8px;
  font-size:10px; letter-spacing:.22em; color:var(--mid);
  text-transform:uppercase; margin-bottom:20px;
}
.hero-h1 {
  font-family:var(--ff-d); font-weight:900;
  font-size:clamp(56px, 9.5vw, 128px);
  line-height:.87; letter-spacing:-.01em;
  text-transform:uppercase;
  display:flex; flex-direction:column;
}
.hl { display:block; }

.hero-bottom {
  display:flex; flex-direction:column; gap:24px;
  padding-bottom:16px;
}
.hero-desc {
  font-size:13px; line-height:1.8; color:var(--dim); max-width:300px;
}
.hero-stats { display:flex; align-items:center; gap:0; }
.hs { display:flex; flex-direction:column; gap:3px; padding-right:28px; }
.hs-sep { width:1px; height:28px; background:var(--border); margin-right:28px; }
.hs-n {
  font-family:var(--ff-d); font-size:38px; font-weight:900;
  color:var(--white); line-height:1;
}
.hs-l { font-size:9px; letter-spacing:.2em; color:var(--mid); text-transform:uppercase; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }

/* Buttons */
.btn-lime {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-d); font-size:13px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--black); background:var(--lime);
  padding:13px 26px; transition:opacity .2s;
}
.btn-lime:hover { opacity:.85; }
.btn-xl { font-size:16px; padding:18px 40px; }

.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ff-d); font-size:13px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:var(--white);
  border-bottom:1px solid rgba(255,255,255,.2); padding-bottom:3px;
  transition:color .25s, border-color .25s;
}
.btn-ghost:hover { color:var(--lime); border-color:var(--lime); }

/* Hero decorations */
.h-deco { position:absolute; inset:0; pointer-events:none; }
.hd-line { position:absolute; background:rgba(255,255,255,.035); }
.hd-h1 { left:0; right:0; top:50%; height:1px; }
.hd-v1 { top:0; bottom:0; left:50%; width:1px; }
.hd-cross {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:18px; height:18px;
}
.hd-cross span { position:absolute; background:rgba(255,255,255,.22); }
.hd-cross span:first-child { left:0; right:0; top:50%; height:1px; }
.hd-cross span:last-child  { top:0; bottom:0; left:50%; width:1px; }
.hd-coords {
  position:absolute; top:80px; left:50%; transform:translateX(-50%);
  font-size:10px; letter-spacing:.14em; color:var(--mid);
  text-transform:uppercase; white-space:nowrap;
}
.hd-status {
  position:absolute; bottom:36px; left:60px;
  display:flex; align-items:center; gap:7px;
  font-size:10px; letter-spacing:.14em; color:var(--mid); text-transform:uppercase;
}
.hd-est {
  position:absolute; bottom:36px; right:60px;
  font-size:10px; letter-spacing:.14em; color:var(--mid); text-transform:uppercase;
}
.blink {
  display:inline-block; width:5px; height:5px;
  border-radius:50%; background:var(--lime);
  box-shadow:0 0 8px var(--lime);
  animation:blink 2s ease infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

.scr-ind {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:12px;
  font-size:9px; letter-spacing:.24em; color:var(--mid);
  text-transform:uppercase; pointer-events:none;
}
.scr-t { width:40px; height:1px; background:rgba(255,255,255,.12); overflow:hidden; }
.scr-f {
  height:100%; background:var(--lime);
  transform:translateX(-100%);
  animation:scrf 2.2s ease infinite;
}
@keyframes scrf { 0%{transform:translateX(-100%)} 50%{transform:translateX(0)} 100%{transform:translateX(100%)} }

/* ══ ABOUT ══ */
.manifesto-h {
  font-family:var(--ff-d); font-weight:700;
  font-size:clamp(24px,3.6vw,50px);
  line-height:1.12; text-transform:uppercase;
  color:var(--white); margin-bottom:28px;
}
.manifesto-h em { font-style:normal; color:var(--lime); }
.about-p { font-size:13px; line-height:1.85; color:var(--dim); margin-bottom:28px; max-width:480px; }
.about-tags { display:flex; flex-wrap:wrap; gap:10px; }
.atag {
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  border:1px solid var(--border); color:var(--dim); padding:6px 14px;
}

/* ══ SERVICES ACCORDION ══ */
.svc-item {
  border-top:1px solid var(--border); overflow:hidden;
  transition:border-color .3s;
}
.svc-item:last-child { border-bottom:1px solid var(--border); }
.svc-item.open { border-color:rgba(217,255,0,.18); }

.svc-head {
  display:flex; align-items:center; gap:24px;
  padding:24px 0; cursor:pointer; user-select:none;
}
.svc-head:hover .svc-n { color:var(--lime); }
.svc-head:hover .svc-ico i { background:var(--lime); }

.svc-n {
  font-family:var(--ff-d); font-size:12px; font-weight:700;
  letter-spacing:.1em; color:var(--mid); width:28px; flex-shrink:0;
  transition:color .3s;
}
.svc-name {
  font-family:var(--ff-d);
  font-size:clamp(20px, 2.8vw, 40px);
  font-weight:800; letter-spacing:.02em;
  text-transform:uppercase; line-height:1; flex:1;
}
.svc-hint { font-size:11px; color:var(--mid); flex-shrink:0; display:none; }
@media(min-width:900px) { .svc-hint { display:block; } }

.svc-ico { width:18px; height:18px; position:relative; flex-shrink:0; }
.svc-ico i {
  position:absolute; background:var(--white);
  transition:transform .45s var(--ease), opacity .3s, background .3s;
}
.svc-ico i:first-child { left:0; right:0; top:50%; height:1px; }
.svc-ico i:last-child  { top:0; bottom:0; left:50%; width:1px; }
.svc-item.open .svc-ico i:last-child { transform:rotate(90deg); opacity:0; }
.svc-item.open .svc-ico i { background:var(--lime); }

.svc-body { max-height:0; overflow:hidden; transition:max-height .8s var(--ease); }
.svc-item.open .svc-body { max-height:500px; }

.svc-bi {
  display:grid; grid-template-columns:1fr 1fr; gap:36px;
  padding:4px 0 32px 52px;
}
.svc-detail p { font-size:13px; line-height:1.85; color:var(--dim); margin-bottom:18px; max-width:300px; }
.svc-detail ul { list-style:none; display:flex; flex-direction:column; gap:7px; }
.svc-detail ul li {
  font-size:11px; letter-spacing:.1em; color:var(--white);
  text-transform:uppercase; display:flex; align-items:center; gap:10px;
}
.svc-detail ul li::before { content:'—'; color:var(--lime); }

/* Service visuals */
.svc-vis {
  border:1px solid var(--border); padding:16px;
  background:var(--surf); display:flex; flex-direction:column;
  justify-content:space-between; min-height:180px;
}
.vis-label { font-size:9px; letter-spacing:.2em; color:var(--mid); text-transform:uppercase; margin-top:10px; }

/* Brand vis */
.svb-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(2,1fr); gap:3px; flex:1;
}
.svb-cell {
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-d); font-size:16px; font-weight:900;
}
.svb-logo { color:var(--lime); font-size:20px; animation:pulse 2.5s ease infinite; }
.svb-aa   { font-size:26px; color:var(--white); }
.svb-mark { color:var(--lime); }
.c-lime   { background:var(--lime); animation:pulse 2s ease infinite; }
.c-dark   { background:#111; }
.c-white  { background:rgba(240,240,235,.08); }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.55} }

/* Web vis */
.sv-web { padding:0; overflow:hidden; }
.svw-bar {
  display:flex; align-items:center; gap:8px;
  background:#080808; padding:9px 12px;
  border-bottom:1px solid var(--border);
}
.svw-dots { display:flex; gap:5px; }
.svw-dots i { display:block; width:7px; height:7px; border-radius:50%; background:var(--mid); }
.svw-url { font-size:10px; color:var(--mid); margin-left:6px; }
.svw-body { padding:14px; display:flex; flex-direction:column; gap:5px; flex:1; }
.svw-l { height:2px; background:var(--surf); border-radius:1px; }
.l80{width:80%} .l100{width:100%} .l60{width:60%} .l90{width:90%} .l45{width:45%}
.lime-l { background:rgba(217,255,0,.28); }
.svw-code { font-size:10px; font-family:monospace; color:var(--dim); margin-top:8px; line-height:1.7; }
.kw{color:#8b7eff} .va{color:var(--white)} .st{color:var(--lime)} .fn{color:#87ceeb}

/* Exp vis */
.sve-dots { display:grid; grid-template-columns:repeat(8,1fr); gap:6px; flex:1; }
.sve-d { width:6px; height:6px; border-radius:50%; background:var(--mid); transition:background .3s, transform .3s; }
.sve-d.lit { background:var(--lime); transform:scale(1.8); }

/* Art vis */
.sva-pal { display:flex; gap:4px; }
.sva-s {
  flex:1; height:56px; display:flex; align-items:flex-end; padding:5px;
  border:1px solid rgba(255,255,255,.08);
}
.sva-s span { font-size:8px; letter-spacing:.06em; opacity:.6; }
.sva-type { display:flex; flex-direction:column; gap:3px; }
.sva-ta { font-family:var(--ff-d); font-size:40px; font-weight:900; color:var(--lime); line-height:1; }
.sva-tb { font-family:var(--ff-d); font-size:12px; font-weight:600; letter-spacing:.1em; color:var(--dim); }
.sva-tc { font-size:11px; color:var(--mid); font-weight:300; }

/* ══ WORK ══ */
.wk-item {
  padding:28px 0; position:relative;
  border-bottom:1px solid var(--border);
  transition:border-color .3s;
}
.wk-item:first-child { border-top:1px solid var(--border); }
.wk-hero { padding-bottom:36px; }

.wk-head { display:flex; align-items:flex-start; gap:20px; margin-bottom:14px; }
.wk-n {
  font-family:var(--ff-d); font-size:12px; font-weight:700;
  letter-spacing:.1em; color:var(--mid); padding-top:4px;
  transition:color .3s; flex-shrink:0; width:28px;
}
.wk-item:hover .wk-n { color:var(--lime); }
.wk-info { flex:1; }
.wk-tag { font-size:9px; letter-spacing:.2em; color:var(--lime); text-transform:uppercase; margin-bottom:6px; }
.wk-title {
  font-family:var(--ff-d); font-weight:900;
  font-size:clamp(26px,3.5vw,52px);
  text-transform:uppercase; line-height:.9;
  color:var(--white); transition:color .3s;
}
.wk-hero .wk-title { font-size:clamp(36px,5vw,72px); }
.wk-item:hover .wk-title { color:var(--lime); }
.wk-link {
  font-size:22px; color:var(--mid); flex-shrink:0;
  transition:color .3s, transform .3s;
}
.wk-link.dim { color:rgba(255,255,255,.1); }
.wk-item:hover .wk-link:not(.dim) { color:var(--lime); transform:translate(2px,-2px); }
.wk-desc { font-size:12px; color:var(--dim); line-height:1.75; margin-left:48px; max-width:440px; margin-bottom:14px; }
.wk-meta {
  display:flex; gap:24px; margin-left:48px;
  font-size:10px; letter-spacing:.1em; color:var(--mid); text-transform:uppercase;
}
.wk-bar {
  position:absolute; bottom:0; left:0;
  height:1px; background:var(--lime); width:0;
  transition:width .55s var(--ease);
}
.wk-item:hover .wk-bar { width:100%; }

/* ══ CLIENTS ══ */
.cli-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
}
.cli-card {
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:32px 20px; gap:14px;
  background:var(--surf); border:1px solid var(--border);
  transition:border-color .35s, background .35s;
  min-height:160px; position:relative; overflow:hidden;
}
.cli-card::after {
  content:''; position:absolute; inset:0;
  background:var(--lime-glow, rgba(217,255,0,0.04));
  opacity:0; transition:opacity .35s;
}
.cli-card:hover { border-color:rgba(217,255,0,.25); }
.cli-card:hover::after { opacity:1; }
.cli-card:hover .cli-domain { color:var(--lime); }

.cli-card img {
  max-width:130px; max-height:50px;
  width:auto; height:auto;
  object-fit:contain; filter:brightness(0) invert(1);
  opacity:.7; transition:opacity .35s;
}
.cli-card:hover img { opacity:1; }

.cli-featured { background:rgba(217,255,0,.03); border-color:rgba(217,255,0,.12); }
.cli-featured img { filter:none; opacity:.9; }
.cli-domain {
  font-size:9px; letter-spacing:.15em; color:var(--mid);
  text-transform:uppercase; transition:color .3s; text-align:center;
}

/* ══ CONTACT ══ */
.sec-contact { background:var(--dark); }
.contact-h {
  font-family:var(--ff-d); font-weight:900;
  font-size:clamp(80px,14vw,190px);
  text-transform:uppercase; line-height:.85;
  letter-spacing:-.015em; color:var(--white); margin-bottom:24px;
}
.contact-sub { font-size:15px; line-height:1.8; color:var(--dim); margin-bottom:44px; }
.contact-cta { display:flex; justify-content:center; margin-bottom:28px; }
.contact-note { font-size:10px; letter-spacing:.18em; color:var(--mid); text-transform:uppercase; }

/* ══ FOOTER (above orb z-index) ══ */
footer {
  position:relative; z-index:200;
  background:var(--black);
  border-top:1px solid var(--border);
}
.footer-inner {
  max-width:1300px; margin:0 auto;
  padding:28px 60px;
  display:flex; align-items:center; justify-content:space-between;
}
.footer-brand { display:flex; flex-direction:column; gap:5px; }
.footer-logo-img { height:28px; width:auto; }
.footer-coords { font-size:10px; color:var(--mid); letter-spacing:.1em; }
.footer-copy { font-size:10px; letter-spacing:.14em; color:var(--mid); text-transform:uppercase; }
.footer-links { display:flex; gap:20px; }
.footer-a {
  font-size:11px; letter-spacing:.16em; color:var(--mid);
  text-transform:uppercase; transition:color .2s;
}
.footer-a:hover { color:var(--white); }

/* ══ ORB JOURNEY — scroll containers ══ */
#orb-journey { position:relative; z-index:5; }
.orb-sec { height:90vh; width:100%; }

/* ══ ORB OVERLAY — slides centered on top of orb ══ */
#orb-overlay {
  position:fixed; inset:0;
  z-index:70;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
  opacity:0;
  transition:opacity .7s cubic-bezier(0.16,1,0.3,1);
}
#orb-overlay.visible {
  opacity:1;
  pointer-events:auto;
}

.orb-slide {
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  text-align:center;
  width:min(520px, 88vw);
  opacity:0; pointer-events:none;
  transition:opacity .15s ease;
}
.orb-slide.active {
  opacity:1; pointer-events:auto;
}

/* ── Staggered child entrance animations ── */
@keyframes osl-enter {
  from { opacity:0; transform:translateY(20px); filter:blur(6px); }
  to   { opacity:1; transform:translateY(0);    filter:blur(0);   }
}
.orb-slide.active .osl-tag        { animation:osl-enter .55s cubic-bezier(0.16,1,0.3,1)   0ms both; }
.orb-slide.active .osl-logo-wrap  { animation:osl-enter .65s cubic-bezier(0.16,1,0.3,1)  80ms both; }
.orb-slide.active .osl-name       { animation:osl-enter .72s cubic-bezier(0.16,1,0.3,1) 155ms both; }
.orb-slide.active .osl-domain     { animation:osl-enter .6s  cubic-bezier(0.16,1,0.3,1) 215ms both; }
.orb-slide.active .osl-desc       { animation:osl-enter .6s  cubic-bezier(0.16,1,0.3,1) 275ms both; }
.orb-slide.active .osl-line       { animation:osl-enter .45s cubic-bezier(0.16,1,0.3,1) 340ms both; }
/* Contact slide children */
.orb-slide.active .osl-headline   { animation:osl-enter .80s cubic-bezier(0.16,1,0.3,1)  50ms both; }
.orb-slide.active .osl-sub        { animation:osl-enter .65s cubic-bezier(0.16,1,0.3,1) 175ms both; }
.orb-slide.active .btn-lime       { animation:osl-enter .65s cubic-bezier(0.16,1,0.3,1) 275ms both; }
.orb-slide.active .contact-note-orb { animation:osl-enter .5s cubic-bezier(0.16,1,0.3,1) 370ms both; }

.osl-tag {
  font-size:9px; letter-spacing:.28em;
  color:#000; text-transform:uppercase;
  margin-bottom:24px;
}

.osl-logo-wrap {
  position:relative;
  display:flex; align-items:center; justify-content:center;
  height:90px; margin-bottom:22px;
}

.osl-img {
  max-height:64px; max-width:210px;
  object-fit:contain;
  filter:brightness(0);
  position:relative; z-index:1;
  opacity:.85;
}

.osl-name {
  font-family:var(--ff-d); font-weight:900;
  font-size:clamp(30px, 5vw, 56px);
  text-transform:uppercase; letter-spacing:.03em;
  color:#000; line-height:1;
  margin-bottom:10px;
}

.osl-domain {
  font-size:11px; letter-spacing:.2em;
  color:#111; text-transform:uppercase;
  margin-bottom:14px;
}

.osl-desc {
  font-size:13px; color:#111;
  line-height:1.75; max-width:300px;
  margin:0 auto;
}

.osl-line {
  width:36px; height:1px;
  background:rgba(0,0,0,.35);
  margin:20px auto 0;
}

/* Contact slide */
.osl-headline {
  font-family:var(--ff-d); font-weight:900;
  font-size:clamp(64px, 13vw, 140px);
  text-transform:uppercase; letter-spacing:-.01em;
  line-height:.86; color:#000;
  margin-bottom:20px;
}
.osl-sub {
  font-size:14px; color:#111;
  line-height:1.7; margin-bottom:36px;
}
.contact-note-orb {
  font-size:10px; letter-spacing:.2em;
  color:#333; text-transform:uppercase;
  margin-top:16px;
}

/* Progress dots — right side (inside #orb-overlay fixed container) */
.orb-progress {
  position:absolute; right:32px; top:50%;
  transform:translateY(-50%);
  display:flex; flex-direction:column; gap:10px;
  opacity:0; pointer-events:none;
  transition:opacity .5s;
}
#orb-overlay.visible .orb-progress { opacity:1; }

.op-dot {
  width:5px; height:5px; border-radius:50%;
  background:rgba(0,0,0,.25);
  transition:background .4s, transform .4s, box-shadow .4s;
}
.op-dot.active {
  background:#000;
  transform:scale(1.7);
}

/* Scroll cue inside overlay */
.orb-scr-cue {
  position:absolute; bottom:56px;
  left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column;
  align-items:center; gap:8px;
  font-size:9px; letter-spacing:.24em;
  color:rgba(0,0,0,.5); text-transform:uppercase;
  pointer-events:none;
  opacity:0; transition:opacity .5s;
}
.orb-scr-cue.on {
  animation:osc-fade 2.8s ease infinite;
}
@keyframes osc-fade { 0%,100%{opacity:.35} 50%{opacity:.85} }
.osc-line {
  width:1px; height:32px;
  background:linear-gradient(to bottom, rgba(0,0,0,.5), transparent);
  animation:osc-grow 2.8s ease infinite;
}
@keyframes osc-grow {
  0%,100%{transform:scaleY(0.2) translateY(-40%); opacity:.3}
  50%{transform:scaleY(1) translateY(0); opacity:1}
}

/* ══ RESPONSIVE ══ */
@media(max-width:1100px) {
  .svc-bi { grid-template-columns:1fr; }
  .svc-vis { display:none; }
  .cli-grid { grid-template-columns:repeat(3,1fr); }
}
@media(max-width:768px) {
  nav { padding:14px 20px; }
  .nav-links { display:none; }
  .hero-inner { padding:90px 24px 32px; }
  .hero-h1 { font-size:clamp(48px,13vw,88px); }
  .sec-inner, .left-half, .right-half, .full-width { padding:0 24px; max-width:100%; margin:0; }
  .center-half { padding:0 24px; max-width:100%; margin:0; text-align:left; }
  .contact-cta { justify-content:flex-start; }
  .cli-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { flex-direction:column; gap:20px; text-align:center; padding:24px; }
  .hd-coords, .hd-est { display:none; }
  #orb-canvas { opacity:.45; }
}
