/* =========================================================================
   PIPELINE PARTNERS. Shared styles.
   Colour and type are locked to the brand. Orange appears only on CTAs and
   genuine key highlights. No em or en dashes anywhere in this file.
   ========================================================================= */

:root{
  /* Ink base and raised surfaces */
  --ink:        #0A0B0E;
  --surface:    #13151C;
  --surface-2:  #1B1E27;
  --hair:       rgba(244,242,237,.10);
  --hair-soft:  rgba(244,242,237,.06);

  /* Warm light section */
  --off:        #F4F2ED;
  --off-2:      #ECE9E0;

  /* Text */
  --on-dark:        #F4F2ED;
  --on-dark-muted:  rgba(244,242,237,.60);
  --on-dark-faint:  rgba(244,242,237,.42);
  --on-light:       #0A0B0E;
  --on-light-muted: rgba(10,11,14,.62);

  /* The one reserved accent */
  --orange:    #FF4D14;
  --orange-lt: #FF7A45;
  --orange-dp: #E23A06;
  --orange-glow: rgba(255,77,20,.55);

  --font-display: "Clash Display", "Satoshi", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --font-body:    "Satoshi", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;

  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 16px;
  --radius-lg: 22px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--on-dark);
  font-family:var(--font-body);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.6;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:var(--orange); color:#fff; }

/* Subtle film grain across the whole page for depth. Pure CSS, no asset. */
body::before{
  content:"";
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ position:relative; padding-block:clamp(72px,10vw,140px); z-index:2; }
.section--tight{ padding-block:clamp(56px,7vw,96px); }
.light{ background:var(--off); color:var(--on-light); }
.light .muted{ color:var(--on-light-muted); }
.muted{ color:var(--on-dark-muted); }

.kicker{
  font-family:var(--font-body);
  font-size:.78rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--on-dark-faint);
  display:inline-block; margin:0 0 1.1rem;
}
.light .kicker{ color:rgba(10,11,14,.5); }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.02; letter-spacing:-.02em; margin:0; }
h2{ font-size:clamp(2rem,5.2vw,3.6rem); }
h3{ font-size:clamp(1.35rem,2.6vw,1.9rem); letter-spacing:-.015em; }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--on-dark-muted); max-width:54ch; }
.light .lead{ color:var(--on-light-muted); }

/* ---------- Buttons. The only orange surface. ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-weight:700; letter-spacing:.01em;
  padding:1.05em 1.6em; border-radius:999px;
  border:1px solid transparent; line-height:1; position:relative;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s var(--ease);
  will-change:transform;
}
.btn .arrow{ transition:transform .35s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

.btn-primary{
  background:var(--orange); color:#fff;
  box-shadow:0 0 0 0 var(--orange-glow), 0 12px 30px -12px rgba(255,77,20,.7);
}
.btn-primary:hover{
  background:var(--orange-lt);
  transform:translateY(-3px);
  box-shadow:0 0 36px -2px var(--orange-glow), 0 18px 40px -14px rgba(255,77,20,.8);
}
.btn-primary:active{ transform:translateY(-1px); }

.btn-ghost{
  background:transparent; color:var(--on-dark);
  border-color:var(--hair);
}
.btn-ghost:hover{ border-color:rgba(244,242,237,.35); transform:translateY(-2px); }
.light .btn-ghost{ color:var(--on-light); border-color:rgba(10,11,14,.18); }
.light .btn-ghost:hover{ border-color:rgba(10,11,14,.4); }

:focus-visible{ outline:3px solid var(--orange-lt); outline-offset:3px; border-radius:6px; }

/* ===================== HEADER ===================== */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,11,14,.72);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--hair);
}
.brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:600; font-size:1.12rem; letter-spacing:-.01em; white-space:nowrap; flex:none; }
.brand svg{ width:26px; height:26px; flex:none; }
.nav-links{ display:flex; align-items:center; gap:2rem; flex:none; }
.nav-links a{ font-size:.95rem; color:var(--on-dark-muted); transition:color .2s; white-space:nowrap; }
.nav-links a:hover{ color:var(--on-dark); }
.nav .btn{ padding:.8em 1.25em; }
.nav-cta{ flex:none; }

/* hamburger (shown only on narrow screens) */
.nav-toggle{ display:none; position:relative; width:44px; height:44px; background:none; border:0; flex:none; cursor:pointer; }
.nav-toggle span{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:22px; height:2px; background:var(--on-dark); border-radius:2px; transition:background .2s; }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:var(--on-dark); border-radius:2px; transition:transform .3s var(--ease); }
.nav-toggle span::before{ top:-7px; }
.nav-toggle span::after{ top:7px; }
.nav-toggle.open span{ background:transparent; }
.nav-toggle.open span::before{ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span::after{ transform:translateY(-7px) rotate(-45deg); }

/* mobile dropdown panel, anchored under the fixed bar */
.mobile-menu{ display:none; }

@media (max-width:960px){
  .nav-links{ display:none; }
  .nav-cta{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .mobile-menu{
    display:flex; flex-direction:column;
    position:absolute; top:100%; left:0; right:0;
    padding:.4rem var(--gutter) 1.4rem;
    background:rgba(10,11,14,.97); backdrop-filter:blur(16px) saturate(140%);
    border-bottom:1px solid var(--hair);
    transform:translateY(-10px); opacity:0; pointer-events:none;
    transition:opacity .3s var(--ease), transform .3s var(--ease);
  }
  .mobile-menu.open{ transform:none; opacity:1; pointer-events:auto; }
  .mobile-menu a{ padding:.95rem .25rem; color:var(--on-dark); font-size:1.05rem; border-bottom:1px solid var(--hair); }
  .mobile-menu a.btn{ margin-top:1rem; border-bottom:0; justify-content:center; }
}

/* ===================== HERO ===================== */
.hero{
  position:relative; min-height:100svh;
  display:grid; align-items:center;
  padding-top:120px; padding-bottom:60px;
  overflow:hidden;
}
/* one controlled glow, anchored behind the phone, not scattered */
.hero::after{
  content:""; position:absolute; z-index:0;
  right:-6%; top:38%; width:46vw; height:46vw; max-width:760px; max-height:760px;
  background:radial-gradient(circle at center, rgba(255,77,20,.20), rgba(255,77,20,.05) 38%, transparent 64%);
  filter:blur(8px); pointer-events:none;
}
.hero-grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,64px);
  align-items:center;
}
.hero-copy{ max-width:42ch; }
.hero h1{
  font-size:clamp(2.6rem,6.4vw,5rem);
  letter-spacing:-.03em; line-height:.98;
}
.hero h1 .flow{ color:var(--orange); }
.hero .lead{ margin-top:1.5rem; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; align-items:center; }
.trust{
  margin-top:2.4rem; padding-top:1.5rem;
  border-top:1px solid var(--hair);
  font-size:.95rem; color:var(--on-dark-muted);
  display:flex; flex-wrap:wrap; gap:.5rem 1.6rem;
}
.trust b{ color:var(--on-dark); font-weight:700; }

/* The signature pipeline visual */
.flowstage{ position:relative; width:100%; aspect-ratio:6/5; }
.flowstage svg{ width:100%; height:100%; overflow:visible; }
.lead-dot{
  fill:var(--orange);
  filter:drop-shadow(0 0 6px var(--orange-glow));
}
@media (max-width:880px){
  .hero{ min-height:auto; }
  .hero-grid{ grid-template-columns:1fr; gap:8px; }
  .hero-copy{ max-width:none; order:1; }
  .flowstage{ order:2; max-width:520px; margin:8px auto 0; }
  .hero::after{ top:auto; bottom:-10%; right:-20%; }
}

/* ===================== VERTICAL PILLARS ===================== */
.pillars-head{ display:flex; justify-content:space-between; align-items:end; gap:2rem; flex-wrap:wrap; margin-bottom:clamp(28px,4vw,48px); }
.pillars-head h2{ max-width:16ch; }
.pillars-head p{ max-width:34ch; margin:0; }

/* asymmetric grid: one tall feature card plus two stacked. Not three equal boxes. */
.pillars{ display:grid; grid-template-columns:1.25fr 1fr; grid-auto-rows:1fr; gap:18px; }
.pillar{
  position:relative; display:flex; flex-direction:column; justify-content:space-between;
  background:var(--surface); border:1px solid var(--hair); border-radius:var(--radius-lg);
  padding:clamp(22px,2.6vw,34px); min-height:200px; overflow:hidden;
  transition:transform .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease);
}
.pillar:first-child{ grid-row:span 2; }
.pillar:hover{ transform:translateY(-4px); border-color:rgba(244,242,237,.22); background:var(--surface-2); }
/* the accent rule that grows on hover. echoes the flow motif, not a chip. */
.pillar::before{
  content:""; position:absolute; left:clamp(22px,2.6vw,34px); top:0; height:3px; width:34px;
  background:linear-gradient(90deg,var(--orange),var(--orange-lt)); border-radius:2px;
  transition:width .5s var(--ease); transform-origin:left;
}
.pillar:hover::before{ width:64px; }
.pillar .p-index{ font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--on-dark-faint); }
.pillar h3{ margin:.7rem 0 .5rem; }
.pillar .p-one{ color:var(--on-dark-muted); margin:0 0 1.1rem; }
.pillar .p-eg{ font-size:.92rem; color:var(--on-dark-faint); margin:0; }
.pillar .p-link{
  margin-top:1.6rem; display:inline-flex; align-items:center; gap:.5em;
  font-weight:700; color:var(--on-dark); font-size:.95rem;
}
.pillar .p-link .arrow{ transition:transform .35s var(--ease); }
.pillar:hover .p-link{ color:var(--orange-lt); }
.pillar:hover .p-link .arrow{ transform:translateX(4px); }
.pillar:first-child h3{ font-size:clamp(1.7rem,3vw,2.4rem); }
.expand-note{ margin-top:1.4rem; color:var(--on-dark-muted); font-size:.98rem; }
.expand-note b{ color:var(--on-dark); }
@media (max-width:760px){
  .pillars{ grid-template-columns:1fr; }
  .pillar:first-child{ grid-row:auto; }
}

/* ===================== HOW IT WORKS ===================== */
.steps{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,4vw,56px); margin-top:clamp(36px,5vw,64px); }
/* the flowing connector line through the steps */
.flowline{ position:absolute; left:0; right:0; top:14px; height:2px; pointer-events:none; }
.flowline svg{ width:100%; height:40px; overflow:visible; position:absolute; top:-19px; }
.step{ position:relative; }
.step .s-label{ display:flex; align-items:center; gap:.7rem; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--on-dark-faint); margin-bottom:1.1rem; }
.step .s-node{ width:13px; height:13px; border-radius:50%; background:var(--surface-2); border:2px solid rgba(244,242,237,.25); flex:none; position:relative; z-index:2; }
.step.is-on .s-node{ border-color:var(--orange); box-shadow:0 0 0 5px rgba(255,77,20,.14); }
.step h3{ margin:0 0 .6rem; }
.step p{ color:var(--on-dark-muted); margin:0; max-width:34ch; }
@media (max-width:760px){
  .steps{ grid-template-columns:1fr; gap:32px; }
  .flowline{ display:none; }
}

/* ===================== GUARANTEE ===================== */
.guarantee{ position:relative; overflow:hidden; }
.guar-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,5vw,72px); align-items:center; }
.guar-big{
  font-family:var(--font-display); font-weight:600; letter-spacing:-.03em; line-height:.92;
  font-size:clamp(3rem,9vw,7rem); margin:0;
}
.guar-big .stop{ display:block; }
.guar-rule{ height:4px; width:120px; background:linear-gradient(90deg,var(--orange),var(--orange-lt)); border-radius:3px; margin:1.6rem 0 0; }
.guar-points{ list-style:none; margin:0; padding:0; display:grid; gap:1.1rem; }
.guar-points li{ padding-left:1.7rem; position:relative; color:var(--on-light-muted); }
.guar-points li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; border-radius:50%; background:var(--orange); }
.guar-points b{ color:var(--on-light); font-weight:700; }
@media (max-width:760px){ .guar-grid{ grid-template-columns:1fr; gap:32px; } }

/* ===================== PROOF ===================== */
.proof-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(24px,4vw,48px); align-items:stretch; }
.proof-statement{ }
.proof-statement .big{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.6rem,3.4vw,2.6rem); line-height:1.1; letter-spacing:-.02em; }
.proof-statement .big .flow{ color:var(--orange); }
.proof-slot{
  border:1.5px dashed rgba(244,242,237,.22); border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,34px); background:rgba(255,255,255,.015);
  display:flex; flex-direction:column; justify-content:center;
}
.proof-slot .tag{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--orange-lt); font-weight:700; }
.proof-slot h3{ margin:.8rem 0 .5rem; font-size:1.3rem; }
.proof-slot p{ color:var(--on-dark-muted); margin:0 0 1rem; font-size:.96rem; }
.proof-slot ul{ margin:0; padding-left:1.1rem; color:var(--on-dark-faint); font-size:.92rem; display:grid; gap:.4rem; }
@media (max-width:760px){ .proof-grid{ grid-template-columns:1fr; } }

/* ===================== COMPARISON ===================== */
.compare{ border:1px solid var(--hair); border-radius:var(--radius-lg); overflow:hidden; }
.compare-row{ display:grid; grid-template-columns:1.2fr 1fr 1fr; align-items:stretch; }
.compare-row + .compare-row{ border-top:1px solid var(--hair); }
.compare .cell{ padding:clamp(16px,2vw,22px) clamp(16px,2.2vw,26px); }
.compare .cell.factor{ color:var(--on-dark-muted); font-weight:500; }
.compare .cell.us{ background:rgba(255,77,20,.05); color:var(--on-dark); font-weight:600; position:relative; }
.compare .cell.them{ color:var(--on-dark-faint); }
.compare-row.head .cell{ font-family:var(--font-display); letter-spacing:-.01em; }
.compare-row.head .cell.us{ color:var(--orange-lt); }
.compare-row.head .cell.them{ font-weight:600; color:var(--on-dark-muted); }
.compare .cell.us::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--orange); }
.compare-foot{ margin-top:1.2rem; font-size:.92rem; color:var(--on-dark-faint); }
@media (max-width:680px){
  .compare-row{ grid-template-columns:1fr; }
  .compare .cell.factor{ background:var(--surface); font-weight:700; color:var(--on-dark); border-top:1px solid var(--hair); }
  .compare-row:first-child .cell.factor{ border-top:0; }
  .compare .cell.us::before{ display:none; }
  .compare-row.head{ display:none; }
  .compare .cell.us::after{ content:"Pipeline Partners"; display:block; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--orange-lt); margin-bottom:.3rem; }
  .compare .cell.them::after{ content:"Shared lead sellers"; display:block; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--on-dark-faint); margin-bottom:.3rem; order:-1; }
  .compare .cell.them{ display:flex; flex-direction:column; }
}

/* ===================== FORM ===================== */
.enquire-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:start; }
.enquire-copy h2{ margin-bottom:1rem; }
.enquire-copy .lead{ margin-bottom:1.6rem; }
.enquire-copy .mini{ font-size:.92rem; color:var(--on-dark-faint); border-top:1px solid var(--hair); padding-top:1.2rem; margin-top:1.6rem; }
.ghl-shell{ background:var(--surface); border:1px solid var(--hair); border-radius:var(--radius-lg); padding:clamp(18px,2.4vw,26px); }
.ghl-slot{ min-height:420px; border-radius:14px; display:flex; }
.ghl-placeholder{
  flex:1; display:flex; flex-direction:column; justify-content:center; align-items:flex-start;
  border:1.5px dashed rgba(244,242,237,.2); border-radius:14px; padding:clamp(22px,3vw,34px);
  background:rgba(255,255,255,.015);
}
.ghl-placeholder .tag{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--orange-lt); font-weight:700; }
.ghl-placeholder h3{ margin:.7rem 0 .5rem; }
.ghl-placeholder p{ color:var(--on-dark-muted); font-size:.95rem; max-width:46ch; }
.ghl-placeholder code{ font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:.82rem; color:var(--orange-lt); background:rgba(255,77,20,.08); padding:.15em .45em; border-radius:6px; }
.ghl-slot iframe{ width:100%; border:0; border-radius:14px; min-height:560px; }
@media (max-width:820px){ .enquire-grid{ grid-template-columns:1fr; } }

/* ===================== FAQ ===================== */
.faq-grid{ display:grid; grid-template-columns:.7fr 1.3fr; gap:clamp(24px,4vw,56px); align-items:start; }
.faq-list{ border-top:1px solid var(--hair); }
.faq-item{ border-bottom:1px solid var(--hair); }
.faq-q{
  width:100%; text-align:left; background:none; border:0; color:var(--on-dark);
  display:flex; justify-content:space-between; align-items:center; gap:1.5rem;
  padding:1.35rem 0; font-family:var(--font-display); font-weight:500; font-size:clamp(1.05rem,1.8vw,1.3rem); letter-spacing:-.01em;
}
.faq-q .pm{ flex:none; width:22px; height:22px; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:var(--orange); border-radius:2px; transition:transform .35s var(--ease),opacity .35s var(--ease); }
.faq-q .pm::before{ left:0; right:0; top:10px; height:2px; }
.faq-q .pm::after{ top:0; bottom:0; left:10px; width:2px; }
.faq-item.open .pm::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; height:0; transition:height .4s var(--ease); }
.faq-a-inner{ padding:0 0 1.5rem; color:var(--on-dark-muted); max-width:62ch; }
@media (max-width:760px){ .faq-grid{ grid-template-columns:1fr; } }

/* ===================== FINAL CTA ===================== */
.final{ position:relative; text-align:center; overflow:hidden; }
.final::after{
  content:""; position:absolute; left:50%; top:60%; transform:translate(-50%,-50%);
  width:60vw; height:60vw; max-width:720px; max-height:720px;
  background:radial-gradient(circle, rgba(255,77,20,.16), transparent 62%); filter:blur(6px); pointer-events:none;
}
.final-inner{ position:relative; z-index:2; max-width:20ch; margin-inline:auto; }
.final h2{ font-size:clamp(2.4rem,7vw,5rem); letter-spacing:-.03em; }
.final p{ color:var(--on-dark-muted); margin:1.4rem auto 2.2rem; max-width:42ch; }
.final .scarcity{ display:inline-block; margin-top:2rem; font-size:.92rem; color:var(--on-dark-faint); }
.final .scarcity b{ color:var(--on-dark); }

/* ===================== FOOTER ===================== */
.footer{ background:var(--ink); border-top:1px solid var(--hair); padding-block:clamp(48px,6vw,80px); position:relative; z-index:2; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:clamp(24px,4vw,48px); }
.footer .brand{ margin-bottom:1rem; }
.footer .motto{ color:var(--on-dark-faint); font-size:.95rem; max-width:30ch; }
.footer h4{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--on-dark-faint); margin:0 0 1.1rem; font-weight:700; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.footer a{ color:var(--on-dark-muted); font-size:.96rem; transition:color .2s; }
.footer a:hover{ color:var(--on-dark); }
.footer-base{ margin-top:clamp(40px,5vw,64px); padding-top:1.6rem; border-top:1px solid var(--hair); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color:var(--on-dark-faint); font-size:.86rem; }
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .footer-grid{ grid-template-columns:1fr; } }

/* ===================== SCROLL REVEAL ===================== */
.reveal{ opacity:0; transform:translateY(26px) scale(.985); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }

/* ===================== HERO PHONE RING ===================== */
/* All animations transform or opacity or fill only. Looping cycle is 3.6s,
   matched to the lead arrival pacing so the phone reads as ringing on arrival. */
.ring{ fill:none; stroke:var(--orange); stroke-width:2; opacity:0; transform-box:fill-box; transform-origin:center; }
.ring:nth-child(1){ animation:ringOut 3.6s var(--ease) infinite; }
.ring:nth-child(2){ animation:ringOut 3.6s var(--ease) .28s infinite; }
.ring:nth-child(3){ animation:ringOut 3.6s var(--ease) .56s infinite; }
@keyframes ringOut{
  0%, 64%{ opacity:0; transform:scale(.5); }
  68%{ opacity:.5; }
  92%{ opacity:0; transform:scale(2.6); }
  100%{ opacity:0; transform:scale(2.6); }
}
.phone{ transform-box:fill-box; transform-origin:center; animation:phoneShake 3.6s var(--ease) infinite; }
@keyframes phoneShake{
  0%, 66%, 100%{ transform:rotate(0deg); }
  70%{ transform:rotate(-2.4deg); }
  74%{ transform:rotate(2.4deg); }
  78%{ transform:rotate(-1.6deg); }
  82%{ transform:rotate(1.2deg); }
  86%{ transform:rotate(0deg); }
}
.screen{ animation:screenGlow 3.6s var(--ease) infinite; }
@keyframes screenGlow{
  0%, 64%{ fill:#0A0B0E; }
  72%{ fill:#1c100a; }
  100%{ fill:#0A0B0E; }
}
.call-dot{ transform-box:fill-box; transform-origin:center; animation:callPulse 3.6s var(--ease) infinite; }
@keyframes callPulse{
  0%, 64%{ transform:scale(.55); opacity:.25; }
  72%{ transform:scale(1.15); opacity:1; }
  100%{ transform:scale(.55); opacity:.25; }
}

/* ===================== CONNECTOR (how it works) ===================== */
.flowline-path{ stroke-dasharray:1400; stroke-dashoffset:1400; }
.flowline.drawn .flowline-path{ transition:stroke-dashoffset 1.6s var(--ease); stroke-dashoffset:0; }
.flowline.drawn .flowline-path{ animation:lineShimmer 4.5s ease-in-out 1.6s infinite; }
@keyframes lineShimmer{ 0%,100%{ opacity:.7; } 50%{ opacity:1; } }

/* ===================== REDUCED MOTION ===================== */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .lead-dot{ display:none; }
}
