/* ============================================================
   HOME page specific styles
   ============================================================ */

/* ---------- Hero ---------- */
.hero{
  padding:200px 0 120px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.hero-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}
.hero-loc{font-size:11px;letter-spacing:0.12em;text-transform:uppercase}

.hero-headline{margin-bottom:72px;max-width:18ch;letter-spacing:-0.04em;position:relative;z-index:2}

/* ---------- Hero abstract gradient art ---------- */
.hero-visual{
  position:absolute;
  top:0;right:0;bottom:0;
  width:55%;
  max-width:880px;
  pointer-events:none;
  z-index:1;
  overflow:hidden;
  /* Soft fade-in from left so it never crowds the headline */
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 35%, #000 100%);
          mask-image:linear-gradient(to right, transparent 0%, #000 35%, #000 100%);
  isolation:isolate;
}
.blob{
  position:absolute;
  border-radius:50%;
  mix-blend-mode:multiply;
  filter:blur(48px);
  will-change:transform;
}
.blob-1{
  width:62%;aspect-ratio:1;
  background:radial-gradient(circle at 50% 50%, rgba(241,90,36,0.55), rgba(241,90,36,0) 65%);
  top:-8%;right:8%;
  animation:drift1 22s ease-in-out infinite;
}
.blob-2{
  width:54%;aspect-ratio:1;
  background:radial-gradient(circle at 50% 50%, rgba(255,180,120,0.65), rgba(255,180,120,0) 65%);
  bottom:-6%;right:0%;
  animation:drift2 27s ease-in-out infinite;
}
.blob-3{
  width:48%;aspect-ratio:1;
  background:radial-gradient(circle at 50% 50%, rgba(255,122,61,0.40), rgba(255,122,61,0) 65%);
  top:32%;right:38%;
  animation:drift3 31s ease-in-out infinite;
}
.blob-4{
  width:42%;aspect-ratio:1;
  background:radial-gradient(circle at 50% 50%, rgba(255,235,210,0.65), rgba(255,235,210,0) 65%);
  top:55%;right:18%;
  animation:drift4 35s ease-in-out infinite;
  mix-blend-mode:screen;
}
.blob-shimmer{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 50% 30% at 70% 30%, rgba(255,255,255,0.35), transparent 70%);
  mix-blend-mode:overlay;
  animation:shimmerDrift 24s ease-in-out infinite alternate;
  pointer-events:none;
}

@keyframes drift1{
  0%,100%{transform:translate(0,0) scale(1)}
  33%   {transform:translate(-60px,40px) scale(1.12)}
  66%   {transform:translate(40px,-30px) scale(0.94)}
}
@keyframes drift2{
  0%,100%{transform:translate(0,0) scale(1)}
  40%   {transform:translate(50px,-60px) scale(0.88)}
  70%   {transform:translate(-40px,20px) scale(1.14)}
}
@keyframes drift3{
  0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}
  50%   {transform:translate(-70px,-40px) scale(1.22) rotate(18deg)}
}
@keyframes drift4{
  0%,100%{transform:translate(0,0) scale(1)}
  45%   {transform:translate(60px,-50px) scale(1.1)}
  80%   {transform:translate(-30px,30px) scale(0.92)}
}
@keyframes shimmerDrift{
  0%  {transform:translate(0,0)}
  100%{transform:translate(-30px,40px)}
}

/* Responsive */
@media (max-width:1280px){.hero-visual{width:50%}}
@media (max-width:1080px){.hero-visual{width:45%;opacity:0.7}}
@media (max-width:760px){.hero-visual{display:none}}
@media (prefers-reduced-motion: reduce){
  .blob,.blob-shimmer{animation:none !important}
}

.hero-foot{
  display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:end;
  padding-top:40px;border-top:1px solid var(--border);
}
.hero-ctas{display:flex;gap:12px;justify-self:end;flex-wrap:wrap}

.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  margin-top:96px;padding-top:32px;border-top:1px solid var(--border);
}
.hero-stat .num{font-size:44px;line-height:1;margin-bottom:8px;color:var(--fg)}
.hero-stat .mono{font-size:11px;letter-spacing:0.12em;text-transform:uppercase}

.hero-deco{position:absolute;inset:0;pointer-events:none;z-index:0}
.deco-circle{
  position:absolute;right:-160px;top:-80px;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(241,90,36,0.32), transparent 65%);
  filter:blur(8px);mix-blend-mode:multiply;
}
.deco-orb{
  position:absolute;left:-180px;bottom:-120px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 60% 60%, rgba(255,200,140,0.5), transparent 65%);
  filter:blur(20px);mix-blend-mode:multiply;
}
.deco-grid{display:none}

/* ---------- Hero photo collage (animated) ---------- */
.hero-photo .wrap{position:relative;z-index:2}
.hero-photo .wrap > *{position:relative}

.hero-collage{
  position:absolute;top:0;bottom:0;right:0;left:62%;z-index:0;overflow:hidden;
}
.collage-tile{
  position:absolute;border-radius:24px;overflow:hidden;
  box-shadow:0 24px 80px -20px rgba(60,30,10,0.35), 0 1px 0 rgba(255,255,255,0.6);
  border:1px solid rgba(255,255,255,0.5);
  opacity:0;transform:translateY(40px) scale(0.96);
  transition:opacity 1.4s var(--ease), transform 1.4s var(--ease);
}
.collage-tile img{width:100%;height:100%;object-fit:cover;display:block;transform-origin:center}
.hero-photo.in .collage-tile{opacity:1;transform:none}

/* Tile positions — asymmetric, magazine-like */
.collage-1{
  width:58%;max-width:280px;aspect-ratio:5/4;
  right:2%;top:14%;
  transition-delay:.1s;
}
.collage-2{
  width:46%;max-width:220px;aspect-ratio:4/3;
  right:0%;bottom:6%;
  transition-delay:.35s;transform:translateY(40px) scale(0.96) rotate(-2deg);
}
.hero-photo.in .collage-2{transform:rotate(-3deg)}
.collage-3{
  width:40%;max-width:190px;aspect-ratio:3/4;
  left:2%;top:18%;
  transition-delay:.55s;transform:translateY(40px) scale(0.96) rotate(2deg);
}
.hero-photo.in .collage-3{transform:rotate(3deg)}

/* Ken Burns drift on imgs */
.collage-1 img{animation:kb1 22s ease-in-out infinite alternate}
.collage-2 img{animation:kb2 26s ease-in-out infinite alternate}
.collage-3 img{animation:kb3 24s ease-in-out infinite alternate}
@keyframes kb1{
  0%{transform:scale(1.05) translate(0,0)}
  100%{transform:scale(1.18) translate(-3%,-2%)}
}
@keyframes kb2{
  0%{transform:scale(1.08) translate(2%,0)}
  100%{transform:scale(1.2) translate(-2%,-3%)}
}
@keyframes kb3{
  0%{transform:scale(1.1) translate(0,1%)}
  100%{transform:scale(1.22) translate(2%,-2%)}
}

/* Cream wash over collage so headline stays readable on left */
.collage-wash{
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(105deg, rgba(251,248,242,0.96) 0%, rgba(251,248,242,0.86) 28%, rgba(251,248,242,0.5) 50%, rgba(251,248,242,0.2) 70%, rgba(251,248,242,0) 95%),
    linear-gradient(180deg, rgba(251,248,242,0) 60%, rgba(251,248,242,0.85) 100%);
}
.collage-grain{
  position:absolute;inset:0;opacity:0.08;mix-blend-mode:multiply;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

@media (max-width:1100px){
  .collage-3{display:none}
  .collage-1{right:-8vw;top:80px;width:46vw}
  .collage-2{right:6vw;top:380px;width:32vw}
}
@media (max-width:780px){
  .collage-tile{display:none}
  .collage-wash{display:none}
}

/* ---------- Trust / Marquee ---------- */
.trust{padding:60px 0}
.trust-head{margin-bottom:40px}

/* ---------- Section head ---------- */
.section-head{margin-bottom:72px;max-width:800px}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{margin-bottom:20px}
.section-head.split{display:flex;justify-content:space-between;align-items:end;max-width:none;gap:40px}

/* ---------- Services grid ---------- */
.svc-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:16px;
}
.svc-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:20px;
  padding:32px;min-height:320px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;cursor:pointer;
  transition:border-color .35s var(--ease), transform .35s var(--ease);
}
.svc-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  background:radial-gradient(320px circle at var(--mx,50%) var(--my,50%), rgba(20,16,10,0.08), transparent 50%);
  opacity:0;transition:opacity .3s;
}
.svc-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}
.svc-card:hover::before{opacity:1}
.svc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.svc-title{font-family:var(--font-serif);font-weight:400;font-size:42px;line-height:0.98;letter-spacing:-0.025em}
.svc-desc{margin-top:16px;font-size:15px;color:var(--fg-muted);max-width:32ch}
.svc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.svc-foot .mono{font-size:11px;letter-spacing:0.1em;text-transform:uppercase}
.svc-arrow{font-size:22px;transition:transform .3s var(--ease);color:var(--fg-muted)}
.svc-card:hover .svc-arrow{transform:translate(4px,-4px);color:var(--accent)}

.svc-card.svc-cta{
  background:linear-gradient(135deg, #FFF6EC 0%, #FFFFFF 60%);
  border-color:var(--border-strong);
}
.svc-card.svc-cta .svc-title{font-size:32px}
.svc-card.svc-cta .btn{align-self:flex-start;margin-top:24px}

/* ---------- Process ---------- */
.process-track{
  position:relative;
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
  padding:40px 0;
}
.process-line{
  position:absolute;top:84px;left:40px;right:40px;height:1px;
  background:var(--border);
}
.process-line-fill{
  height:100%;width:calc(var(--progress, 0) * 100%);
  background:var(--accent);transition:width .3s;
}
.process-step{
  display:flex;flex-direction:column;gap:24px;padding:0 8px;position:relative;
}
.process-step::before{
  content:"";position:absolute;top:78px;left:8px;width:13px;height:13px;border-radius:50%;
  background:var(--bg);border:1px solid var(--border);transition:background .3s, border-color .3s, transform .3s;
}
.process-step.active::before{background:var(--accent);border-color:var(--accent);transform:scale(1.2)}
.process-num{
  font-family:var(--font-serif);font-size:80px;line-height:1;color:var(--fg-dim);
  letter-spacing:-0.03em;transition:color .4s;
}
.process-step.active .process-num{color:var(--fg)}
.process-body{padding-top:40px}
.process-body h3{font-family:var(--font-serif);font-size:28px;font-weight:400;margin-bottom:10px;letter-spacing:-0.02em}
.process-body p{font-size:14px;margin-bottom:16px;max-width:24ch}
.process-body .mono{font-size:11px;letter-spacing:0.12em;text-transform:uppercase}

/* ---------- Case studies ---------- */
.case-list{display:flex;flex-direction:column;gap:32px}
.case-card{
  display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center;
  padding:40px;border:1px solid var(--border);border-radius:24px;
  background:var(--bg-card);
  transition:border-color .35s var(--ease), transform .35s var(--ease);
}
.case-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}
.case-card-reverse{grid-template-columns:1fr 1.1fr}
.case-card-reverse .case-visual{order:2}
.case-visual{position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;background:var(--bg-elevated)}
.ph-case{width:100%;height:100%}
.case-photo{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease), filter .4s var(--ease)}
.case-card:hover .case-photo{transform:scale(1.04)}
.case-visual::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg, transparent 55%, rgba(20,16,10,0.18) 100%)}
.case-tag{
  position:absolute;top:16px;left:16px;
  background:rgba(255,255,255,0.85);backdrop-filter:blur(8px);
  padding:6px 12px;border:1px solid var(--border);border-radius:999px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg);
}
.case-meta h3{font-family:var(--font-serif);font-weight:400;font-size:38px;line-height:1.02;letter-spacing:-0.02em;margin-bottom:16px}
.case-meta > p{margin-bottom:32px;font-size:16px}
.case-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-top:28px;border-top:1px solid var(--border)}
.case-stats > div{display:flex;flex-direction:column;gap:6px}
.case-stats .num{font-size:36px;line-height:1;color:var(--accent)}
.case-stats .mono{font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase}

/* ---------- Pricing preview ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.price-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:20px;
  padding:32px;display:flex;flex-direction:column;gap:24px;
  transition:border-color .35s var(--ease), transform .35s var(--ease);
  position:relative;
}
.price-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}
.price-card-featured{background:linear-gradient(180deg, rgba(241,90,36,0.10), transparent 40%), var(--bg-card);border-color:rgba(241,90,36,0.35)}
.price-badge{
  position:absolute;top:-12px;left:32px;
  background:var(--accent);color:var(--accent-ink);
  padding:4px 12px;border-radius:999px;font-family:var(--font-mono);
  font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;font-weight:500;
}
.price-head .tag{margin-bottom:20px}
.price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.price-amt{font-family:var(--font-serif);font-size:48px;line-height:1;letter-spacing:-0.02em}
.price-unit{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);letter-spacing:0.05em}
.price-feats{list-style:none;display:flex;flex-direction:column;gap:10px;padding-top:20px;border-top:1px solid var(--border);flex:1}
.price-feats li{font-size:14px;color:var(--fg-muted);padding-left:22px;position:relative;line-height:1.5}
.price-feats li::before{content:"";position:absolute;left:0;top:8px;width:12px;height:1px;background:var(--accent)}
.price-card .btn{align-self:flex-start}

/* ---------- Testimonial ---------- */
.testimonial-section{background:var(--bg);padding:120px 0}
.testimonial{max-width:1000px;margin:0 auto;text-align:center}
.testimonial p{
  font-family:var(--font-serif);font-size:clamp(28px,4vw,48px);
  line-height:1.2;letter-spacing:-0.02em;color:var(--fg);margin-bottom:40px;
}
.testimonial-foot{display:flex;align-items:center;justify-content:center;gap:16px}
.testimonial-ph{width:56px;height:56px;border-radius:50%;font-size:9px}
.testimonial-name{font-size:15px;margin-bottom:2px}

/* ---------- Final CTA ---------- */
.final-cta{padding:140px 0 180px}

@media (max-width: 900px){
  .hero{padding:140px 0 60px}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:8px}
  .hero-foot{grid-template-columns:1fr;gap:32px}
  .hero-ctas{justify-self:start}
  .hero-stats{grid-template-columns:1fr 1fr;gap:16px}
  .hero-stat .num{font-size:40px}
  .svc-grid{grid-template-columns:1fr}
  .process-track{grid-template-columns:1fr;gap:8px}
  .process-line{display:none}
  .process-step::before{display:none}
  .process-num{font-size:48px}
  .process-body{padding-top:0}
  .case-card, .case-card-reverse{grid-template-columns:1fr;gap:24px;padding:24px}
  .case-card-reverse .case-visual{order:0}
  .case-stats{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr}
  .section-head.split{flex-direction:column;align-items:flex-start}
}


/* Hero background video layer */
.hero .bg-video{z-index:0;opacity:1;position:absolute;inset:0;overflow:hidden}
.hero .bg-video canvas{display:block;width:100%;height:100%}
.hero-deco{z-index:1}
.hero .wrap{position:relative;z-index:2}

/* Grain overlay above canvas, below content */
.hero-grain{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  opacity:0.07;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.hero-logomark{display:none}

.img-strip{display:none}
.img-strip.tall{grid-template-columns:1fr 1fr 1fr}
.img-strip.tall .img-tile{aspect-ratio:3/4}
.img-strip.tall .img-tile:first-child{grid-row:auto}

.testimonial-ph-img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}

/* Footer brand wordmark - invert white area by screen-blend */
.footer-brand{margin:0 0 48px;max-width:240px}
.footer-brand img{width:auto;height:64px;display:block;mix-blend-mode:multiply;opacity:0.92;object-fit:contain}

@media (max-width:900px){
  .hero-logomark{width:300px;height:300px;right:-80px;top:40px;opacity:0.05}
  .img-strip, .img-strip.tall{grid-template-columns:1fr;margin-top:48px}
  .img-strip .img-tile:first-child{aspect-ratio:16/9;grid-row:auto}
}


/* Scroll cue at hero bottom */
.hero-scroll{
  position:absolute;right:40px;bottom:-30px;
  display:flex;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--fg-muted);transition:color .25s;
}
.hero-scroll:hover{color:var(--accent)}
.hero-scroll-line{
  display:inline-block;width:64px;height:1px;background:var(--fg-muted);position:relative;overflow:hidden;
}
.hero-scroll-line::after{
  content:"";position:absolute;left:-30%;top:0;width:30%;height:1px;background:var(--accent);
  animation:scrollHint 2.2s var(--ease) infinite;
}
@keyframes scrollHint{
  0%{left:-30%}100%{left:100%}
}
@media (max-width:900px){.hero-scroll{right:24px;bottom:-22px}.hero-scroll-line{width:40px}}

/* ============================================================
   HERO ORBIT — animated SEO ecosystem SVG
   Absolute-positioned on the right of the hero so headline keeps
   its original natural size and width.
   ============================================================ */

.hero .wrap{position:relative}

.hero-orbit{
  position:absolute;
  top:0;
  right:0;
  /* Only as wide as needed — stays in the right 40% */
  width:clamp(280px, 38vw, 520px);
  /* Match height of the headline block only — stops before hero-foot */
  height:clamp(240px, 34vw, 460px);
  aspect-ratio:unset;
  z-index:1;
  pointer-events:none;
  opacity:1;
  /* Clip anything that would bleed outside this box */
  overflow:hidden;
}
.hero-orbit svg{width:100%;height:100%;display:block;overflow:visible}

/* Tone down the peach decoration so it doesn't fight the orbit */
.hero .deco-orb{opacity:0.5}

/* Hide on narrow viewports where the orbit would overlap headline content */
@media (max-width:1280px){
  .hero-orbit{right:12px;top:80px;width:clamp(200px, 18vw, 280px);opacity:0.85}
}
@media (max-width:1024px){
  .hero-orbit{display:none}
}

/* ----------------------------------------------------------
   ANIMATIONS — individual CSS transform properties compose
   with the SVG transform attribute instead of replacing it.
   ---------------------------------------------------------- */

/* Each icon gets its own float pattern for organic motion */
.orbit-item{will-change:translate, rotate}
.orbit-item-1{animation:orbitFloatA 5.5s ease-in-out infinite}
.orbit-item-2{animation:orbitFloatB 6.2s ease-in-out infinite;animation-delay:0.6s}
.orbit-item-3{animation:orbitFloatC 5.0s ease-in-out infinite;animation-delay:1.2s}
.orbit-item-4{animation:orbitFloatD 6.8s ease-in-out infinite;animation-delay:0.3s}
.orbit-item-5{animation:orbitFloatA 5.8s ease-in-out infinite;animation-delay:2.0s}
.orbit-item-6{animation:orbitFloatB 6.4s ease-in-out infinite;animation-delay:1.5s}

@keyframes orbitFloatA{
  0%,100%{translate:0 0;rotate:0deg}
  50%{translate:0 -10px;rotate:1.5deg}
}
@keyframes orbitFloatB{
  0%,100%{translate:0 0;rotate:0deg}
  50%{translate:0 -7px;rotate:-1.8deg}
}
@keyframes orbitFloatC{
  0%,100%{translate:0 0}
  50%{translate:0 -6px}   /* gears: only float, no wobble (they already spin) */
}
@keyframes orbitFloatD{
  0%,100%{translate:0 0;rotate:0deg}
  50%{translate:0 -9px;rotate:2.2deg}
}

/* Central monitor breathes (scale around its own centre) */
.orbit-center{
  transform-box:fill-box;
  transform-origin:center;
  animation:orbitPulse 4.4s ease-in-out infinite;
}
@keyframes orbitPulse{
  0%,100%{scale:1}
  50%{scale:1.035}
}

/* Pulsing halo behind the monitor */
.orbit-halo{
  transform-box:fill-box;
  transform-origin:center;
  animation:orbitHalo 3.6s ease-in-out infinite;
}
@keyframes orbitHalo{
  0%,100%{scale:0.85;opacity:0.10}
  50%{scale:1.15;opacity:0.28}
}

/* Gears spin (opposite directions) */
.orbit-gear-1, .orbit-gear-2{
  transform-box:fill-box;
  transform-origin:center;
}
.orbit-gear-1{animation:orbitSpin 9s linear infinite}
.orbit-gear-2{animation:orbitSpinReverse 7s linear infinite}
@keyframes orbitSpin{to{rotate:360deg}}
@keyframes orbitSpinReverse{to{rotate:-360deg}}

/* Arrows: staggered start times so the dash-flow ripples around the cycle */
.orbit-arrows .flow{
  stroke-dasharray:8 6;
  animation:orbitFlow 2.2s linear infinite;
}
.orbit-arrows .flow:nth-child(1){animation-delay:0s}
.orbit-arrows .flow:nth-child(2){animation-delay:0.18s}
.orbit-arrows .flow:nth-child(3){animation-delay:0.36s}
.orbit-arrows .flow:nth-child(4){animation-delay:0.54s}
.orbit-arrows .flow:nth-child(5){animation-delay:0.72s}
.orbit-arrows .flow:nth-child(6){animation-delay:0.90s}
.orbit-arrows .flow:nth-child(7){animation-delay:1.08s}
@keyframes orbitFlow{
  to{stroke-dashoffset:-28}
}

/* Arrow heads — subtle opacity pulse, also staggered */
.orbit-arrowheads polyline{
  transform-box:fill-box;
  transform-origin:center;
  animation:orbitPulseSoft 3s ease-in-out infinite;
}
.orbit-arrowheads polyline:nth-child(odd){animation-delay:0s}
.orbit-arrowheads polyline:nth-child(even){animation-delay:0.5s}
@keyframes orbitPulseSoft{
  0%,100%{opacity:0.6}
  50%{opacity:1}
}

/* Flowing dashed arrows */
.orbit-arrows .flow{
  stroke-dasharray:8 6;
  animation:orbitFlow 2.2s linear infinite;
}
@keyframes orbitFlow{
  to{stroke-dashoffset:-28}
}

/* Arrow heads pulse subtly */
.orbit-arrowheads polyline{
  animation:orbitPulseSoft 3s ease-in-out infinite;
  transform-box:fill-box;transform-origin:center;
}
@keyframes orbitPulseSoft{
  0%,100%{opacity:0.7}
  50%{opacity:1}
}

/* Tablet — orbit becomes a hair smaller */
@media (max-width:1200px){
  .hero .wrap{column-gap:32px}
  .hero-orbit{max-width:400px}
  .hero-headline{font-size:clamp(36px, 5vw, 72px)}
}

/* Tablet/mobile — single column, orbit below headline as accent */
@media (max-width:900px){
  .hero .wrap{display:block}
  .hero-orbit{
    position:relative;
    margin:32px auto 8px;
    width:min(380px, 80vw);
    max-width:none;
    justify-self:auto;
    opacity:0.92;
  }
  .hero-headline{font-size:clamp(40px, 9vw, 64px);max-width:18ch;margin-bottom:32px}
}

/* Very small phones — keep orbit but make it compact */
@media (max-width:480px){
  .hero-orbit{width:280px}
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .orbit-item,.orbit-center,.orbit-gear-1,.orbit-gear-2,.orbit-arrows .flow,.orbit-arrowheads polyline{
    animation:none;
  }
}


/* ---------- Animated Graphic Diagram ---------- */

/* Custom animation for the flat PNG logo */
@keyframes premiumLogoFloat {
  0%, 100% {
    transform: translateY(0) rotate(0deg) scale(1);
    filter: drop-shadow(0 10px 20px rgba(241, 90, 36, 0.15));
  }
  50% {
    transform: translateY(-20px) rotate(3deg) scale(1.03);
    filter: drop-shadow(0 30px 40px rgba(241, 90, 36, 0.35));
  }
}

/* ── Hero SVG graphic animations ────────────────────── */
@keyframes svgFloatY  { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes svgFloatY2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)}  }
@keyframes svgSpinCW  { from{transform:rotate(0deg)} to{transform:rotate(360deg)}  }
@keyframes svgSpinCCW { from{transform:rotate(0deg)} to{transform:rotate(-360deg)} }
@keyframes svgPulse   { 0%,100%{opacity:.35} 50%{opacity:1} }
@keyframes svgDash    { from{stroke-dashoffset:60} to{stroke-dashoffset:0} }

.svg-f1  { animation: svgFloatY  5.5s ease-in-out infinite; }
.svg-f2  { animation: svgFloatY2 6.2s ease-in-out infinite .8s; }
.svg-f3  { animation: svgFloatY  5.0s ease-in-out infinite 1.5s; }
.svg-f4  { animation: svgFloatY2 6.8s ease-in-out infinite .3s; }
.svg-f5  { animation: svgFloatY  5.8s ease-in-out infinite 2s; }
.svg-pu  { animation: svgPulse   1.8s ease-in-out infinite; }
.svg-da  { animation: svgDash    1.8s linear infinite; }
.svg-scw1 { transform-box:fill-box; transform-origin:center; animation: svgSpinCW  9s linear infinite; }
.svg-scw2 { transform-box:fill-box; transform-origin:center; animation: svgSpinCW  6s linear infinite; }
.svg-scc  { transform-box:fill-box; transform-origin:center; animation: svgSpinCCW 8s linear infinite; }


/* ── Hero Image Grid ───────────────────────────────── */
.hero-orbit .hero-img-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
  width: 100%;
  height: 100%;
  /* Fade out the left edge so images blend into the page background */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,0.5) 18%, black 38%);
  mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,0.5) 18%, black 38%);
}

/* Left tall image spans both rows */
.hero-orbit .hig-left {
  grid-column: 1;
  grid-row: 1 / 3;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}

/* Top-right image */
.hero-orbit .hig-top-right {
  grid-column: 2;
  grid-row: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}

/* Bottom-right image */
.hero-orbit .hig-bottom-right {
  grid-column: 2;
  grid-row: 2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}
