/* ============================================================
   9Yards Creations — Design System v2.1
   "Spectrum Sky" + Advanced Animation Layer
   ============================================================ */

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

:root{
  --spec-red:    #FF504B;
  --spec-gold:   #FFD55D;
  --spec-gray:   #C2C2C2;
  --spec-green:  #3BD553;
  --spec-blue:   #39AEFE;

  --c-blue:        #1E8FD5;
  --c-blue-mid:    #39AEFE;
  --c-blue-soft:   #7CCBFF;
  --c-blue-pale:   #D6EFFF;
  --c-blue-faint:  #EEF7FF;
  --c-navy:        #0B2A4A;
  --c-navy-mid:    #133A62;
  --c-aqua:        #22D3EE;
  --c-aqua-soft:   #A5F3FC;
  --c-gold:        #FFD55D;
  --c-white:       #FFFFFF;

  --bg:            #F4FAFF;
  --bg-card:       #FFFFFF;
  --bg-card-alt:   #EBF5FF;
  --bg-deep:       #0B2A4A;

  --text:          #0B2A4A;
  --text-mid:      #2E567A;
  --text-dim:      #6590B2;
  --text-white:    #FFFFFF;

  --border:        rgba(30,143,213,0.14);
  --border-strong: rgba(30,143,213,0.32);

  --grad-sky:      linear-gradient(135deg, #1E8FD5 0%, #39AEFE 100%);
  --grad-hero:     linear-gradient(135deg, #0B2A4A 0%, #133A62 55%, #1E4F80 100%);
  --grad-subtle:   linear-gradient(135deg, #EEF7FF 0%, #D6EFFF 100%);

  --stripe:        linear-gradient(90deg,
                      var(--spec-red) 0%, var(--spec-red) 18%,
                      var(--spec-gold) 18%, var(--spec-gold) 38%,
                      var(--spec-gray) 38%, var(--spec-gray) 56%,
                      var(--spec-green) 56%, var(--spec-green) 76%,
                      var(--spec-blue) 76%, var(--spec-blue) 100%);

  --radius:        16px;
  --ease:          cubic-bezier(.22,1,.36,1);
  --ease-bounce:   cubic-bezier(.34,1.56,.64,1);
  --ease-spring:   cubic-bezier(.175,.885,.32,1.275);
}

/* ─────────────────────────────────────────
   BASE
───────────────────────────────────────── */
*{box-sizing:border-box;}
.ny *{box-sizing:border-box;}
.ny{
  font-family:'Poppins',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
.ny a{text-decoration:none;color:inherit;}
.ny ul{list-style:none;margin:0;padding:0;}
.ny img{max-width:100%;display:block;}
.ny-container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px;}
.ny-section{padding:96px 0;position:relative;}
.ny-section--tight{padding:56px 0;}

/* ─────────────────────────────────────────
   CUSTOM CURSOR
───────────────────────────────────────── */
.ny-cursor{
  position:fixed;
  width:12px;height:12px;
  background:var(--c-blue);
  border-radius:50%;
  pointer-events:none;
  z-index:99999;
  transform:translate(-50%,-50%);
  transition:transform .1s, width .3s var(--ease), height .3s var(--ease), background .3s;
  mix-blend-mode:multiply;
}
.ny-cursor-ring{
  position:fixed;
  width:38px;height:38px;
  border:2px solid var(--c-blue);
  border-radius:50%;
  pointer-events:none;
  z-index:99998;
  transform:translate(-50%,-50%);
  transition:transform .18s var(--ease), width .3s var(--ease), height .3s var(--ease), opacity .3s, border-color .3s;
  opacity:.5;
}
.ny-cursor.is-hovering{
  width:20px;height:20px;
  background:var(--spec-red);
}
.ny-cursor-ring.is-hovering{
  width:52px;height:52px;
  opacity:.25;
  border-color:var(--spec-red);
}
.ny-cursor.is-clicking{
  transform:translate(-50%,-50%) scale(.7);
}
@media(pointer:coarse){
  .ny-cursor,.ny-cursor-ring{display:none;}
}

/* ─────────────────────────────────────────
   EYEBROW
───────────────────────────────────────── */
.ny-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;font-weight:700;
  letter-spacing:.05em;
  padding:6px 16px 6px 10px;
  border-radius:8px;
  background:var(--bg-card);
  border:1.5px solid var(--border-strong);
  color:var(--c-blue);
  margin-bottom:18px;
  text-transform:uppercase;
  animation:ny-eyebrow-in .6s var(--ease-bounce) both;
}
@keyframes ny-eyebrow-in{
  from{opacity:0;transform:translateY(10px) scale(.95);}
  to{opacity:1;transform:translateY(0) scale(1);}
}
.ny-eyebrow .dot{
  width:18px;height:8px;border-radius:4px;
  background:var(--stripe);
  animation:ny-dot-pulse 3s ease infinite;
}
@keyframes ny-dot-pulse{
  0%,100%{opacity:1;}
  50%{opacity:.55;}
}

/* ─────────────────────────────────────────
   HEADINGS / TYPE
───────────────────────────────────────── */
.ny h1,.ny h2,.ny h3,.ny h4{
  font-weight:800;line-height:1.15;
  margin:0 0 16px;
  letter-spacing:-0.02em;
  color:var(--text);
}
.ny h1{font-size:clamp(36px,5vw,58px);}
.ny h2{font-size:clamp(28px,3.4vw,42px);}
.ny h3{font-size:22px;}
.ny p{color:var(--text-mid);line-height:1.75;font-size:16px;margin:0 0 16px;}

.ny-grad-text{
  background:var(--stripe);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  background-size:200% 100%;
  animation:ny-shift 8s ease infinite;
}
@keyframes ny-shift{
  0%,100%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
}

.ny-stripe-rule{
  height:5px;width:72px;border-radius:3px;
  background:var(--stripe);
  margin:0 0 22px;
}

/* ─────────────────────────────────────────
   BUTTONS — magnetic + ripple
───────────────────────────────────────── */
.ny-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;border-radius:10px;
  font-weight:600;font-size:15px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s, color .3s;
  position:relative;
  overflow:hidden;
  user-select:none;
  -webkit-user-select:none;
}

/* Ripple ink */
.ny-btn .ny-ripple{
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.3);
  transform:scale(0);
  animation:ny-ripple .6s linear;
  pointer-events:none;
}
@keyframes ny-ripple{
  to{transform:scale(4);opacity:0;}
}

.ny-btn--primary{
  background:var(--c-blue);color:#fff;
  box-shadow:0 6px 0 0 var(--c-navy-mid);
}
.ny-btn--primary:hover{
  transform:translateY(-3px);
  box-shadow:0 9px 0 0 var(--c-navy-mid);
}
.ny-btn--primary:active{
  transform:translateY(2px);
  box-shadow:0 2px 0 0 var(--c-navy-mid);
}

.ny-btn--ghost{
  background:transparent;
  border:2px solid var(--border-strong);
  color:var(--c-blue);
}
.ny-btn--ghost:hover{
  border-color:var(--c-blue);
  background:var(--c-blue-pale);
  color:var(--c-navy);
  transform:translateY(-3px);
}

.ny-btn--white{
  background:#fff;color:var(--c-navy);
  box-shadow:0 6px 0 0 rgba(0,0,0,.18);
}
.ny-btn--white:hover{
  transform:translateY(-3px);
  box-shadow:0 9px 0 0 rgba(0,0,0,.22);
}

.ny-btn span.arrow{transition:transform .3s var(--ease);}
.ny-btn:hover span.arrow{transform:translateX(6px);}

/* ─────────────────────────────────────────
   PRELOADER
───────────────────────────────────────── */
.ny-preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg-deep);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:24px;
  transition:opacity .7s var(--ease), visibility .7s;
}
.ny-preloader.is-done{opacity:0;visibility:hidden;}
.ny-preloader-bars{display:flex;gap:8px;height:60px;align-items:flex-end;}
.ny-preloader-bars span{
  width:10px;border-radius:6px;
  display:inline-block;
  animation:ny-bar 1s ease-in-out infinite;
}
.ny-preloader-bars span:nth-child(1){background:var(--spec-red);animation-delay:0s;}
.ny-preloader-bars span:nth-child(2){background:var(--spec-gold);animation-delay:.12s;}
.ny-preloader-bars span:nth-child(3){background:var(--spec-gray);animation-delay:.24s;}
.ny-preloader-bars span:nth-child(4){background:var(--spec-green);animation-delay:.36s;}
.ny-preloader-bars span:nth-child(5){background:var(--spec-blue);animation-delay:.48s;}
@keyframes ny-bar{
  0%,100%{height:18px;}
  50%{height:60px;}
}
.ny-preloader-label{
  font-size:12px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.3);
  animation:ny-label-blink 1.4s ease infinite;
}
@keyframes ny-label-blink{
  0%,100%{opacity:.3;}
  50%{opacity:.9;}
}

/* ─────────────────────────────────────────
   HEADER / NAV
───────────────────────────────────────── */
.ny-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;
  transition:padding .35s var(--ease), background .35s var(--ease), box-shadow .35s;
  border-bottom:3px solid transparent;
}
.ny-header.is-scrolled{
  padding:12px 0;
  background:rgba(255,255,255,.97);
  border-bottom-color:var(--border);
  box-shadow:0 2px 24px rgba(30,143,213,.1);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.ny-nav{display:flex;align-items:center;justify-content:space-between;}
.ny-logo{display:flex;align-items:center;gap:10px;}
.ny-logo img{height:46px;width:auto;}
.ny-nav-links{display:flex;align-items:center;gap:4px;}
.ny-nav-links a{
  position:relative;padding:10px 16px;
  border-radius:8px;font-weight:500;font-size:15px;
  color:var(--text-mid);
  transition:color .25s, background .25s;
  overflow:hidden;
}
.ny-nav-links a::after{
  content:'';
  position:absolute;bottom:6px;left:16px;right:16px;
  height:2px;border-radius:2px;
  background:var(--stripe);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.ny-nav-links a:hover::after,
.ny-nav-links a.is-active::after{transform:scaleX(1);}
.ny-nav-links a:hover,
.ny-nav-links a.is-active{
  color:var(--c-blue);background:var(--c-blue-pale);
}
.ny-nav-cta{margin-left:8px;}

.ny-burger{
  display:none;
  width:42px;height:42px;border-radius:10px;
  border:2px solid var(--border-strong);
  background:var(--bg-card);
  position:relative;cursor:pointer;
}
.ny-burger span{
  position:absolute;left:11px;right:11px;height:2px;
  background:var(--c-navy);
  transition:transform .35s var(--ease), opacity .3s;
}
.ny-burger span:nth-child(1){top:15px;}
.ny-burger span:nth-child(2){top:20px;}
.ny-burger span:nth-child(3){top:25px;}
.ny-burger.is-open span:nth-child(1){transform:translateY(5px) rotate(45deg);}
.ny-burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0);}
.ny-burger.is-open span:nth-child(3){transform:translateY(-5px) rotate(-45deg);}

.ny-mobile-panel{
  position:fixed;top:0;right:0;height:100vh;width:78%;max-width:320px;
  background:#fff;
  border-left:3px solid var(--c-blue);
  z-index:1001;
  padding:100px 30px 30px;
  transform:translateX(100%);
  transition:transform .4s var(--ease);
  box-shadow:-10px 0 40px rgba(30,143,213,.12);
}
.ny-mobile-panel.is-open{transform:translateX(0);}
.ny-mobile-panel a{
  display:block;padding:14px 0;font-size:18px;font-weight:600;
  border-bottom:1px solid var(--border);color:var(--text);
  transform:translateX(20px);opacity:0;
  transition:transform .35s var(--ease), opacity .35s;
}
.ny-mobile-panel.is-open a{transform:translateX(0);opacity:1;}
.ny-mobile-panel.is-open a:nth-child(1){transition-delay:.05s;}
.ny-mobile-panel.is-open a:nth-child(2){transition-delay:.10s;}
.ny-mobile-panel.is-open a:nth-child(3){transition-delay:.15s;}
.ny-mobile-panel.is-open a:nth-child(4){transition-delay:.20s;}
.ny-mobile-panel.is-open a:nth-child(5){transition-delay:.25s;}

.ny-scrim{
  position:fixed;inset:0;background:rgba(11,42,74,.45);
  z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.ny-scrim.is-open{opacity:1;visibility:visible;}

@media(max-width:991px){
  .ny-nav-links{display:none;}
  .ny-burger{display:block;}
}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.ny-hero{
  min-height:92vh;
  display:flex;align-items:center;
  padding-top:140px;padding-bottom:80px;
  position:relative;
  background:var(--grad-hero);
  overflow:hidden;
}
.ny-hero::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:6px;
  background:var(--stripe);z-index:2;
  animation:ny-stripe-shimmer 4s linear infinite;
  background-size:200% 100%;
}
@keyframes ny-stripe-shimmer{
  0%{background-position:0% 0%;}
  100%{background-position:200% 0%;}
}
.ny-hero::after{
  content:'';
  position:absolute;bottom:-15%;right:-8%;
  width:480px;height:480px;
  border-radius:50%;
  border:60px solid rgba(124,203,255,.06);
  animation:ny-ring-pulse 6s ease-in-out infinite;
}
@keyframes ny-ring-pulse{
  0%,100%{transform:scale(1);opacity:.6;}
  50%{transform:scale(1.08);opacity:1;}
}

.ny-hero-dots{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(124,203,255,.14) 1px, transparent 1px);
  background-size:36px 36px;
  pointer-events:none;z-index:0;
  animation:ny-dots-drift 20s linear infinite;
}
@keyframes ny-dots-drift{
  from{background-position:0 0;}
  to{background-position:36px 36px;}
}

.ny-hero .ny-container{position:relative;z-index:1;}
.ny-hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
@media(max-width:991px){.ny-hero-grid{grid-template-columns:1fr;}}
.ny-hero h1{margin-bottom:22px;color:#fff;}
.ny-hero p.lead{font-size:18px;max-width:520px;color:rgba(255,255,255,.75);}
.ny-hero-cta{display:flex;gap:16px;margin-top:28px;flex-wrap:wrap;}

/* Hero art tilt-card */
.ny-hero-art{
  position:relative;border-radius:20px;overflow:hidden;
  border:3px solid var(--c-blue-soft);
  box-shadow:0 24px 60px rgba(0,0,0,.3);
  transform-style:preserve-3d;
  transition:transform .08s linear, box-shadow .3s;
  cursor:none;
}
.ny-hero-art:hover{
  box-shadow:0 32px 80px rgba(0,0,0,.4);
}
.ny-hero-art img{width:100%;height:100%;object-fit:cover;}
.ny-hero-art::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(11,42,74,.9));
}

.ny-floating-card{
  position:absolute;bottom:16px;left:16px;right:16px;
  background:var(--c-navy);
  border:1px solid rgba(124,203,255,.3);
  border-radius:12px;padding:16px 18px;
  display:flex;align-items:center;gap:14px;
  z-index:2;
  animation:ny-float-card 4s ease-in-out infinite;
}
@keyframes ny-float-card{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-5px);}
}
.ny-floating-card .dotwrap{
  width:44px;height:44px;border-radius:10px;
  background:var(--c-blue);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;flex-shrink:0;font-size:13px;
}
.ny-floating-card h5{margin:0;font-size:15px;color:#fff;}
.ny-floating-card p{margin:0;font-size:13px;color:rgba(255,255,255,.65);}

.ny-trust-row{
  display:flex;gap:36px;margin-top:56px;flex-wrap:wrap;
  padding-top:32px;border-top:1px solid rgba(255,255,255,.12);
}
.ny-trust-row .stat h3{font-size:30px;margin:0;color:#fff;}
.ny-trust-row .stat p{
  margin:0;font-size:13px;text-transform:uppercase;
  letter-spacing:.05em;color:rgba(255,255,255,.55);
}
.ny-trust-row .stat{position:relative;}
.ny-trust-row .stat::after{
  content:'';position:absolute;
  left:0;bottom:-8px;
  width:32px;height:3px;border-radius:3px;
  background:var(--stripe);
  opacity:0;
  transition:opacity .5s var(--ease) .4s, width .5s var(--ease) .4s;
}
.ny-trust-row .stat.is-visible::after{opacity:1;width:48px;}

/* ─────────────────────────────────────────
   DIVIDERS
───────────────────────────────────────── */
.ny-divider{
  height:6px;width:100%;
  background:var(--stripe);
  background-size:200% 100%;
  animation:ny-stripe-shimmer 6s linear infinite;
}

/* ─────────────────────────────────────────
   SECTION BACKGROUNDS
───────────────────────────────────────── */
.ny-section--white{background:#fff;}
.ny-section--light{background:var(--bg);}
.ny-section--pale{background:var(--bg-card-alt);}
.ny-section--deep{background:var(--grad-hero);color:#fff;}
.ny-section--deep h2,.ny-section--deep h3,.ny-section--deep h4{color:#fff;}
.ny-section--deep p{color:rgba(255,255,255,.7);}
.ny-section--deep .ny-eyebrow{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.22);
  color:var(--c-blue-soft);
}

/* ─────────────────────────────────────────
   CARDS — why choose us
───────────────────────────────────────── */
.ny-card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
@media(max-width:600px){.ny-card-grid{grid-template-columns:1fr;}}
.ny-card{
  background:var(--bg-card);
  border:1.5px solid var(--border);
  border-left:4px solid transparent;
  border-radius:var(--radius);
  padding:28px;
  transition:transform .35s var(--ease), border-color .35s, box-shadow .35s;
  position:relative;overflow:hidden;
}
/* Shimmer on hover */
.ny-card::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.55) 50%, transparent 70%);
  transform:translateX(-100%);
  transition:transform .6s var(--ease);
  pointer-events:none;
}
.ny-card:hover::before{transform:translateX(100%);}
.ny-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 48px -16px rgba(11,42,74,.2);
}
.ny-card .icon{
  width:50px;height:50px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;font-size:22px;color:#fff;
  transition:transform .4s var(--ease-bounce);
}
.ny-card:hover .icon{transform:rotate(-8deg) scale(1.12);}
.ny-card h4{margin:0 0 8px;font-size:18px;color:var(--text);}
.ny-card p{margin:0;font-size:14px;}

.ny-card:nth-child(1){border-left-color:var(--spec-red);}
.ny-card:nth-child(1) .icon{background:var(--spec-red);}
.ny-card:nth-child(2){border-left-color:var(--spec-gold);}
.ny-card:nth-child(2) .icon{background:var(--spec-gold);color:var(--c-navy);}
.ny-card:nth-child(3){border-left-color:var(--c-blue);}
.ny-card:nth-child(3) .icon{background:var(--c-blue);}
.ny-card:nth-child(4){border-left-color:var(--spec-green);}
.ny-card:nth-child(4) .icon{background:var(--spec-green);}

/* ─────────────────────────────────────────
   SERVICE CARDS
───────────────────────────────────────── */
.ny-services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:991px){.ny-services-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.ny-services-grid{grid-template-columns:1fr;}}
.ny-service-card{
  background:var(--bg-card);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:30px 26px;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s;
}
.ny-service-card::before{
  content:'';position:absolute;left:0;top:0;right:0;height:4px;
  background:var(--c-blue);
  transition:height .35s var(--ease);
}
.ny-service-card:hover::before{height:6px;}
.ny-service-card:nth-child(5n+1)::before{background:var(--spec-red);}
.ny-service-card:nth-child(5n+2)::before{background:var(--spec-gold);}
.ny-service-card:nth-child(5n+3)::before{background:var(--spec-gray);}
.ny-service-card:nth-child(5n+4)::before{background:var(--spec-green);}
.ny-service-card:nth-child(5n+5)::before{background:var(--spec-blue);}
.ny-service-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 48px -16px rgba(11,42,74,.18);
  border-color:var(--c-blue-mid);
}
.ny-service-card .icon-wrap{
  width:54px;height:54px;border-radius:12px;
  background:var(--bg-card-alt);
  border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
  transition:background .3s, border-color .3s, transform .4s var(--ease-bounce);
}
.ny-service-card:hover .icon-wrap{
  background:var(--c-blue-pale);
  border-color:var(--c-blue-mid);
  transform:scale(1.1) rotate(-5deg);
}
.ny-service-card .icon-wrap img{height:26px;width:26px;}
.ny-service-card h4{font-size:17px;margin-bottom:10px;color:var(--text);}
.ny-service-card p{font-size:14px;margin-bottom:0;}
.ny-service-card .go{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:16px;font-size:13px;font-weight:600;color:var(--c-blue);
  transition:gap .3s var(--ease);
}
.ny-service-card:hover .go{gap:12px;}

/* ─────────────────────────────────────────
   ABOUT / SPLIT
───────────────────────────────────────── */
.ny-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
@media(max-width:900px){.ny-split{grid-template-columns:1fr;}}
.ny-split-media{
  border-radius:20px;overflow:hidden;
  border:3px solid var(--c-blue-pale);
  position:relative;
  box-shadow:0 16px 50px -20px rgba(30,143,213,.18);
  transition:box-shadow .4s var(--ease), transform .4s var(--ease);
}
.ny-split-media:hover{
  box-shadow:0 28px 70px -20px rgba(30,143,213,.28);
  transform:translateY(-4px);
}
.ny-split-media img{width:100%;transition:transform .6s var(--ease);}
.ny-split-media:hover img{transform:scale(1.03);}

/* ─────────────────────────────────────────
   QUOTE STRIP
───────────────────────────────────────── */
.ny-quote-strip{
  background:var(--bg-deep);
  border:none;border-radius:20px;
  padding:56px;text-align:center;
  position:relative;overflow:hidden;
}
.ny-quote-strip::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:5px;
  background:var(--stripe);
  background-size:200% 100%;
  animation:ny-stripe-shimmer 5s linear infinite;
}
.ny-quote-strip p{
  font-size:22px;color:#fff;font-weight:500;
  max-width:700px;margin:0 auto;
  position:relative;z-index:1;
}

/* ─────────────────────────────────────────
   CTA BAND
───────────────────────────────────────── */
.ny-cta-band{
  border-radius:20px;padding:56px;
  background:var(--c-blue);
  display:flex;align-items:center;
  justify-content:space-between;
  gap:30px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.ny-cta-band::before{
  content:'';
  position:absolute;
  width:300px;height:300px;border-radius:50%;
  background:rgba(255,255,255,.05);
  top:-100px;right:-60px;
  animation:ny-ring-pulse 5s ease-in-out infinite;
}
.ny-cta-band::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:6px;
  background:var(--stripe);
  background-size:200% 100%;
  animation:ny-stripe-shimmer 5s linear infinite;
}
.ny-cta-band h3{color:#fff;margin-bottom:8px;position:relative;z-index:1;}
.ny-cta-band p{color:rgba(255,255,255,.82);margin:0;position:relative;z-index:1;}
.ny-cta-band .ny-btn--white{position:relative;z-index:1;}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
.ny-footer{
  background:var(--c-navy);
  border-top:5px solid transparent;
  border-image:var(--stripe) 1;
  padding-top:70px;
}
.ny-footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;
  padding-bottom:50px;
}
@media(max-width:900px){.ny-footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.ny-footer-grid{grid-template-columns:1fr;}}
.ny-footer h5{
  color:#fff;font-size:15px;margin-bottom:18px;
  letter-spacing:.03em;text-transform:uppercase;
}
.ny-footer-links li{margin-bottom:10px;}
.ny-footer-links a{
  color:rgba(255,255,255,.55);font-size:14px;
  transition:color .25s, padding-left .3s var(--ease);
  display:inline-flex;align-items:center;gap:6px;
}
.ny-footer-links a:hover{color:var(--c-blue-soft);padding-left:6px;}
.ny-footer-contact li{
  display:flex;gap:10px;margin-bottom:14px;
  font-size:14px;color:rgba(255,255,255,.55);
}
.ny-footer-contact i{color:var(--c-blue-soft);margin-top:2px;}
.ny-social{display:flex;gap:10px;margin-top:16px;}
.ny-social a{
  width:38px;height:38px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);
  transition:transform .3s var(--ease-bounce), background .25s, color .25s, box-shadow .3s;
}
.ny-social a:hover{
  transform:translateY(-5px) scale(1.1);
  background:var(--c-blue);color:#fff;
  border-color:transparent;
  box-shadow:0 8px 20px -4px rgba(30,143,213,.4);
}
.ny-footer-map iframe{
  width:100%;height:160px;border-radius:12px;
  border:1px solid rgba(255,255,255,.1);
  filter:grayscale(.3) invert(.92) contrast(.85);
}
.ny-footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:22px 0;text-align:center;
  font-size:13px;color:rgba(255,255,255,.45);
}

/* ─────────────────────────────────────────
   SCROLL REVEAL — FULL SUITE
───────────────────────────────────────── */

/* Base: fade up */
.reveal{
  opacity:0;
  transform:translateY(36px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d,0s);
  will-change:opacity,transform;
}
.reveal.is-visible{opacity:1;transform:translateY(0);}

/* Slide left */
.reveal--left{
  opacity:0;transform:translateX(-50px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--left.is-visible{opacity:1;transform:translateX(0);}

/* Slide right */
.reveal--right{
  opacity:0;transform:translateX(50px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--right.is-visible{opacity:1;transform:translateX(0);}

/* Scale pop */
.reveal--scale{
  opacity:0;transform:scale(.88);
  transition:opacity .6s var(--ease), transform .6s var(--ease-spring);
  transition-delay:var(--d,0s);
}
.reveal--scale.is-visible{opacity:1;transform:scale(1);}

/* Pure fade */
.reveal--fade{
  opacity:0;transform:none;
  transition:opacity .8s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--fade.is-visible{opacity:1;}

/* Flip up */
.reveal--flip{
  opacity:0;
  transform:perspective(600px) rotateX(14deg) translateY(28px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--flip.is-visible{opacity:1;transform:perspective(600px) rotateX(0) translateY(0);}

/* Rotate in */
.reveal--rotate{
  opacity:0;transform:rotate(-6deg) translateY(24px) scale(.95);
  transition:opacity .6s var(--ease), transform .7s var(--ease-spring);
  transition-delay:var(--d,0s);
}
.reveal--rotate.is-visible{opacity:1;transform:rotate(0) translateY(0) scale(1);}

/* Blur in */
.reveal--blur{
  opacity:0;filter:blur(12px);transform:translateY(16px);
  transition:opacity .7s var(--ease), filter .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--blur.is-visible{opacity:1;filter:blur(0);transform:translateY(0);}

/* Clip from bottom (curtain) */
.reveal--clip{
  opacity:0;
  clip-path:inset(100% 0 0 0);
  transition:opacity .01s .7s, clip-path .7s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal--clip.is-visible{opacity:1;clip-path:inset(0% 0 0 0);}

/* ─────────────────────────────────────────
   STAGGER HELPER
   Add data-stagger-group to a parent;
   children get auto delays via JS
───────────────────────────────────────── */
[data-stagger-group] > *{--d:0s;}

/* ─────────────────────────────────────────
   TILT CARDS (3D mouse-over)
   Add .ny-tilt to any card
───────────────────────────────────────── */
.ny-tilt{
  transform-style:preserve-3d;
  transition:transform .08s linear;
}
.ny-tilt-inner{transform:translateZ(16px);}

/* ─────────────────────────────────────────
   MAGNETIC BUTTON WRAPPER
   Add .ny-magnet around a .ny-btn
───────────────────────────────────────── */
.ny-magnet{display:inline-block;}

/* ─────────────────────────────────────────
   PARALLAX LAYER
   JS reads data-parallax="0.3" (speed multiplier)
───────────────────────────────────────── */
[data-parallax]{will-change:transform;}

/* ─────────────────────────────────────────
   COUNTER / TICKER
───────────────────────────────────────── */
.ny-counter{
  display:inline-block;
  font-variant-numeric:tabular-nums;
}

/* ─────────────────────────────────────────
   SCROLL PROGRESS BAR
───────────────────────────────────────── */
.ny-scroll-progress{
  position:fixed;top:0;left:0;
  height:3px;z-index:9998;
  background:var(--stripe);
  background-size:200% 100%;
  animation:ny-stripe-shimmer 4s linear infinite;
  width:0%;
  transition:width .1s linear;
  transform-origin:left;
}

/* ─────────────────────────────────────────
   TYPING CURSOR
───────────────────────────────────────── */
.ny-type-cursor{
  display:inline-block;width:3px;height:1em;
  background:var(--c-blue);
  margin-left:2px;
  animation:ny-type-blink .75s step-end infinite;
  vertical-align:text-bottom;
  border-radius:2px;
}
@keyframes ny-type-blink{
  0%,100%{opacity:1;}
  50%{opacity:0;}
}

/* ─────────────────────────────────────────
   SPOTLIGHT GLOW (follows mouse in hero)
───────────────────────────────────────── */
.ny-spotlight{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(circle 400px at var(--mx,50%) var(--my,50%),
    rgba(57,174,254,.12) 0%, transparent 70%);
  transition:background .15s;
}

/* ─────────────────────────────────────────
   MARQUEE / TICKER
───────────────────────────────────────── */
.ny-marquee-wrap{overflow:hidden;position:relative;}
.ny-marquee-track{
  display:flex;gap:40px;
  animation:ny-marquee 28s linear infinite;
  width:max-content;
}
.ny-marquee-track:hover{animation-play-state:paused;}
@keyframes ny-marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
.ny-marquee-item{
  white-space:nowrap;
  display:flex;align-items:center;gap:12px;
  font-weight:600;font-size:14px;
  color:var(--text-dim);
  padding:10px 20px;
  border-radius:8px;
  border:1.5px solid var(--border);
  background:var(--bg-card);
}

/* ─────────────────────────────────────────
   TOOLTIP
───────────────────────────────────────── */
[data-tip]{position:relative;}
[data-tip]::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px);
  background:var(--c-navy);color:#fff;
  font-size:12px;font-weight:500;
  padding:6px 12px;border-radius:8px;white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
  z-index:10;
}
[data-tip]:hover::after{
  opacity:1;transform:translateX(-50%) translateY(0);
}

/* ─────────────────────────────────────────
   WAVE DIVIDER
───────────────────────────────────────── */
.ny-wave{display:block;width:100%;overflow:hidden;line-height:0;}
.ny-wave svg{display:block;width:100%;height:70px;}
.ny-wave--down svg{transform:rotate(180deg);}

/* ─────────────────────────────────────────
   BADGE / TAGS
───────────────────────────────────────── */
.ny-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:8px;
  background:rgba(30,143,213,.08);
  border:1.5px solid rgba(30,143,213,.22);
  font-size:13px;font-weight:600;color:var(--c-blue);
}

/* ─────────────────────────────────────────
   ANIMATED UNDERLINE LINKS
───────────────────────────────────────── */
.ny-link-anim{
  position:relative;display:inline-block;
  color:var(--c-blue);font-weight:600;
}
.ny-link-anim::after{
  content:'';position:absolute;left:0;bottom:-2px;
  width:0;height:2px;background:var(--c-blue);
  border-radius:2px;transition:width .35s var(--ease);
}
.ny-link-anim:hover::after{width:100%;}

/* ─────────────────────────────────────────
   BACK TO TOP
───────────────────────────────────────── */
.ny-top-btn{
  position:fixed;bottom:26px;right:26px;z-index:900;
  width:50px;height:50px;border-radius:12px;
  background:var(--c-blue);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:18px;
  opacity:0;transform:translateY(24px) scale(.9);visibility:hidden;
  transition:opacity .3s, transform .4s var(--ease-bounce), visibility .3s, box-shadow .3s;
  cursor:pointer;border:none;
  box-shadow:0 6px 0 0 var(--c-navy-mid);
}
.ny-top-btn.is-visible{
  opacity:1;transform:translateY(0) scale(1);visibility:visible;
}
.ny-top-btn:hover{
  transform:translateY(-4px) scale(1.05);
  box-shadow:0 10px 0 0 var(--c-navy-mid);
}

/* ─────────────────────────────────────────
   PARTICLE CANVAS
───────────────────────────────────────── */
#ny-particles{
  position:absolute;inset:0;
  pointer-events:none;z-index:0;opacity:.5;
}

/* ─────────────────────────────────────────
   PAGE TRANSITION OVERLAY
───────────────────────────────────────── */
.ny-page-overlay{
  position:fixed;inset:0;z-index:9990;
  background:var(--stripe);
  background-size:100% 100%;
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
  pointer-events:none;
}
.ny-page-overlay.is-leaving{transform:scaleX(1);}
.ny-page-overlay.is-entering{
  transform-origin:right;
  transform:scaleX(0);
}

/* ─────────────────────────────────────────
   TALKING MASCOT / MOUTH ANIMATION
   ------------------------------------------------
   HTML to pair with this block:

   <div class="ny-mascot is-talking">
     <div class="ny-mascot-face">
       <div class="ny-mascot-eye left"></div>
       <div class="ny-mascot-eye right"></div>
       <div class="ny-mascot-mouth"></div>
     </div>
   </div>

   - Toggle the "is-talking" class with JS to start/stop
     the mouth-flap loop (e.g. while a chatbot reply types out,
     or on a timed loop for a hero mascot). Remove it to return
     to the idle smiling face.
   - Eyes blink on their own loop regardless of talking state.
───────────────────────────────────────── */

.ny-mascot{
  width:140px;height:140px;
  display:flex;align-items:center;justify-content:center;
}
.ny-mascot-face{
  position:relative;
  width:120px;height:120px;border-radius:50%;
  background:var(--grad-sky);
  box-shadow:0 14px 32px -10px rgba(30,143,213,.4), inset 0 -8px 18px rgba(11,42,74,.18);
  display:flex;align-items:center;justify-content:center;
}

/* Eyes — blink loop */
.ny-mascot-eye{
  position:absolute;top:42px;
  width:14px;height:14px;border-radius:50%;
  background:var(--c-navy);
  animation:ny-blink 4.5s ease-in-out infinite;
}
.ny-mascot-eye.left{left:34px;}
.ny-mascot-eye.right{right:34px;}
@keyframes ny-blink{
  0%,92%,100%{transform:scaleY(1);}
  95%{transform:scaleY(.1);}
}

/* Mouth */
.ny-mascot-mouth{
  position:absolute;bottom:30px;left:50%;
  width:36px;height:14px;
  transform:translateX(-50%);
  background:var(--c-navy);
  border-radius:0 0 18px 18px;
  transform-origin:center top;
  transition:height .15s ease, border-radius .15s ease, transform .15s ease;
}

/* Idle (not talking): soft closed smile, slow breathing */
.ny-mascot:not(.is-talking) .ny-mascot-mouth{
  height:6px;border-radius:0 0 14px 14px;
  animation:ny-mouth-idle 3.6s ease-in-out infinite;
}
@keyframes ny-mouth-idle{
  0%,100%{height:6px;}
  50%{height:9px;}
}

/* Talking: cycles through open/closed/wide "viseme-ish" shapes
   to fake lip-sync — purely decorative, no audio analysis needed */
.ny-mascot.is-talking .ny-mascot-mouth{
  animation:ny-mouth-talk .42s steps(1) infinite;
}
@keyframes ny-mouth-talk{
  0%   { height:6px;  width:30px; border-radius:0 0 14px 14px; }   /* closed */
  20%  { height:18px; width:24px; border-radius:0 0 24px 24px; }   /* open round */
  40%  { height:10px; width:36px; border-radius:6px;          }    /* wide flat */
  60%  { height:22px; width:20px; border-radius:50%;          }    /* open wide */
  80%  { height:8px;  width:32px; border-radius:0 0 16px 16px;}    /* half close */
  100% { height:6px;  width:30px; border-radius:0 0 14px 14px; }   /* closed */
}

/* Whole-face nod while talking, adds life */
.ny-mascot.is-talking .ny-mascot-face{
  animation:ny-face-nod 1.4s ease-in-out infinite;
}
@keyframes ny-face-nod{
  0%,100%{transform:translateY(0) rotate(0);}
  50%{transform:translateY(-2px) rotate(1deg);}
}

/* ─────────────────────────────────────────
   REDUCED MOTION
───────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .reveal,.reveal--left,.reveal--right,
  .reveal--scale,.reveal--fade,.reveal--flip,
  .reveal--rotate,.reveal--blur,.reveal--clip{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    clip-path:none !important;
  }
  .ny-cursor,.ny-cursor-ring,.ny-scroll-progress{display:none;}
  .ny-mascot-mouth,.ny-mascot-eye,.ny-mascot-face{
    animation:none !important;
  }
}