/* ── Service ticker ── */
.ticker-wrap {
  background: var(--navy-mid);
  border-bottom: 1px solid rgba(255,255,255,.06);
  overflow: hidden;
  padding: 11px 0;
  position: relative;
  width: 100%;
}
.ticker-wrap::before,
.ticker-wrap::after {
  content: '';
  position: absolute; top: 0; bottom: 0; width: 80px; z-index: 1; pointer-events: none;
}
.ticker-wrap::before { left: 0; background: linear-gradient(90deg, var(--navy-mid), transparent); }
.ticker-wrap::after  { right: 0; background: linear-gradient(270deg, var(--navy-mid), transparent); }
.ticker-track {
  display: inline-flex;
  align-items: center;
  gap: 0;
  animation: ticker 38s linear infinite;
  white-space: nowrap;
}
.ticker-track:hover { animation-play-state: paused; }
.ticker-item {
  font-size: .67rem;
  font-weight: 600;
  color: rgba(255,255,255,.38);
  text-transform: uppercase;
  letter-spacing: .13em;
  font-family: var(--font-display);
  padding: 0 20px;
  transition: color var(--t-fast);
}
.ticker-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: rgba(249,115,22,.45);
  flex-shrink: 0;
}

/* ── Hero ── */
.hero {
  background: var(--navy); padding: 96px 20px 80px;
  text-align: center; position: relative; overflow: hidden;
  animation: viewEnter 500ms var(--ease-out) both;
}
/* Dot-grid texture — fades from edges, transparent at centre */
.hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.08) 1.2px, transparent 1.2px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse 85% 90% at 50% 50%, transparent 30%, black 80%);
  -webkit-mask-image: radial-gradient(ellipse 85% 90% at 50% 50%, transparent 30%, black 80%);
}
/* Warm accent glow — top-right */
.hero::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(ellipse 55% 50% at 78% 18%, rgba(249,115,22,.1) 0%, transparent 65%),
              radial-gradient(ellipse 40% 35% at 18% 80%, rgba(14,30,54,.9) 0%, transparent 60%);
}
.hero-geo {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden;
  will-change: transform; /* parallax target */
}
.hero-geo svg { display: block; width: 100%; height: 100%; }
.hero-pip { display: none; }
.hero-pip2 { display: none; }

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(249,115,22,.1); border: 1px solid rgba(249,115,22,.3);
  color: var(--accent); font-size: .66rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  padding: 5px 14px 5px 10px; border-radius: 9999px; margin-bottom: 24px;
  font-family: var(--font-display); position: relative; z-index: 1;
  animation: viewEnter 600ms var(--ease-out) 100ms both;
}
.hero-eyebrow-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
  display: inline-block; position: relative; flex-shrink: 0;
}
.hero-eyebrow-dot::after {
  content: ''; position: absolute; inset: -3px; border-radius: 50%;
  border: 1.5px solid var(--accent); opacity: 0;
  animation: pulse-ring 2.2s ease-out infinite;
}

.hero h1 {
  font-size: clamp(2.4rem,5.2vw,4rem); font-weight: 700;
  letter-spacing: -.045em; color: #fff; line-height: 1.06;
  margin-bottom: 20px; font-family: var(--font-display);
  position: relative; z-index: 1;
}
.hero h1 span {
  background: linear-gradient(135deg,var(--accent) 20%,#fdba74 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  /* Subtle text glow on the gradient */
  filter: drop-shadow(0 0 18px rgba(249,115,22,.28));
}
.hero p {
  font-size: clamp(.88rem,1.8vw,1rem); color: rgba(255,255,255,.55);
  max-width: 440px; margin: 0 auto 32px; line-height: 1.75;
  position: relative; z-index: 1;
}

/* ── Search bar ── */
.search-wrap {
  max-width: 620px; margin: 0 auto; background: #fff;
  border-radius: 9px;
  box-shadow: 0 8px 40px rgba(0,0,0,.45),0 0 0 1px rgba(249,115,22,.15);
  padding: 6px 6px 6px 20px; display: flex; align-items: center;
  gap: 10px; position: relative; z-index: 1;
  transition: box-shadow var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.search-wrap:focus-within {
  box-shadow: 0 8px 40px rgba(0,0,0,.45), 0 0 0 2px var(--accent);
  transform: translateY(-1px);
}
.search-wrap input {
  flex: 1; border: none; outline: none; font-size: .97rem;
  font-family: var(--font); color: var(--text); min-width: 0;
}
.search-wrap input::placeholder { color: var(--faint); }

/* ── Quick-filter chips ── */
.chips {
  max-width: 620px; margin: 14px auto 0;
  display: flex; gap: 5px; flex-wrap: wrap;
  justify-content: center; position: relative; z-index: 1;
}
.chip {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.6); padding: 4px 12px;
  border-radius: 9999px; font-size: .74rem; font-weight: 500;
  cursor: pointer; font-family: var(--font);
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.chip:hover, .chip.active {
  background: rgba(249,115,22,.18);
  border-color: rgba(249,115,22,.4); color: var(--accent);
}
.chip:hover { transform: translateY(-1px); }
.chip.active { transform: none; }

/* ── Stat band ── */
.stat-band {
  background: var(--navy-mid);
  border-top: 1px solid rgba(249,115,22,.15);
  border-bottom: 1px solid rgba(255,255,255,.06);
  position: relative; overflow-x: hidden; width: 100%;
}
.stat-band::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(249,115,22,.5) 30%, rgba(249,115,22,.5) 70%, transparent);
}
.stat-inner { display: flex; justify-content: center; flex-wrap: wrap; }
.stat-item {
  padding: 26px 40px; text-align: center; position: relative;
  border-right: 1px solid rgba(255,255,255,.07);
}
.stat-item:last-child { border-right: none; }
.stat-num {
  font-size: 2.1rem; font-weight: 700; color: var(--accent);
  letter-spacing: -.05em; line-height: 1; font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  animation: countUp .6s ease both;
}
.stat-lbl {
  font-size: .7rem; color: rgba(255,255,255,.42); margin-top: 5px;
  text-transform: uppercase; letter-spacing: .1em; font-family: var(--font-display);
}

/* ── Section framework ── */
.section { padding: 80px 20px; }
.section-alt { background: var(--bg-alt); }
.sec-label {
  font-size: .66rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 10px;
  font-family: var(--font-display);
  display: inline-flex; align-items: center; gap: 8px;
}
.sec-label::before {
  content: ''; display: block; width: 18px; height: 2px;
  background: var(--accent); border-radius: 2px;
}
.sec-title {
  font-size: clamp(1.6rem,3vw,2.3rem); font-weight: 700;
  letter-spacing: -.045em; margin-bottom: 12px; color: var(--navy);
}
.sec-sub { font-size: .91rem; color: var(--muted); max-width: 440px; line-height: 1.75; }

/* ── How it works grid ── */
.how-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 16px; margin-top: 40px;
}
.how-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r); padding: 28px 24px 24px;
  transition: box-shadow var(--t-base) var(--ease-out),
              transform var(--t-base) var(--ease-out),
              border-color var(--t-base);
  position: relative; overflow: hidden;
  /* animation handled by .anim-ready + IntersectionObserver */
}
/* Left-edge accent bar — slides in on hover */
.how-card::before {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--accent), var(--accent-d));
  transform: scaleY(0); transform-origin: top;
  transition: transform var(--t-base) var(--ease-out);
}
/* Top gradient line */
.how-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0; transition: opacity var(--t-base);
}
.how-card:hover { box-shadow: 0 8px 32px rgba(11,21,37,.12),0 2px 8px rgba(11,21,37,.07); transform: translateY(-5px); border-color: var(--border-d); }
.how-card:hover::before { transform: scaleY(1); }
.how-card:hover::after { opacity: 1; }
/* Large background watermark step number */
.how-card-bg {
  position: absolute; bottom: -12px; right: 6px;
  font-size: 6rem; font-weight: 700; line-height: 1;
  color: rgba(11,21,37,.038); font-family: var(--font-display);
  letter-spacing: -.12em; pointer-events: none; user-select: none; z-index: 0;
  transition: color var(--t-base);
}
.how-card:hover .how-card-bg { color: rgba(249,115,22,.06); }
/* Push all card content above the bg number */
.how-card > *:not(.how-card-bg) { position: relative; z-index: 1; }
.how-num {
  font-size: .67rem; font-weight: 700; color: var(--accent);
  letter-spacing: .14em; text-transform: uppercase; margin-bottom: 14px;
  font-family: var(--font-display);
  display: flex; align-items: center; gap: 7px;
}
.how-num::before {
  content: ''; display: block; width: 20px; height: 1.5px;
  background: var(--accent); border-radius: 2px;
  animation: accentGrow 600ms var(--ease-out) both;
}
/* SVG icon container */
.how-icon {
  width: 44px; height: 44px; border-radius: var(--rsm);
  background: var(--accent-l); border: 1px solid rgba(249,115,22,.2);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px; color: var(--accent);
  transition: background var(--t-base), transform var(--t-base) var(--ease-spring), box-shadow var(--t-base);
}
.how-card:hover .how-icon {
  background: var(--accent); color: #fff;
  transform: scale(1.08) rotate(-3deg);
  box-shadow: 0 4px 14px rgba(249,115,22,.35);
}
.how-title {
  font-size: 1rem; font-weight: 700; margin-bottom: 6px;
  color: var(--navy); font-family: var(--font-display); letter-spacing: -.025em;
}
.how-desc { font-size: .84rem; color: var(--muted); line-height: 1.7; }

/* ── Home About section ── */
/* home-featured: inline style had grid-template-columns removed, set here instead */
#home-featured { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.home-about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; max-width: 1100px; margin: 0 auto; }
.home-about-principles { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; margin-top: 24px; }
.principle-item { padding: 16px; background: var(--bg-alt); border-radius: var(--rsm); border: 1px solid var(--border); }
.principle-icon { font-size: 1.2rem; margin-bottom: 7px; }
.principle-title { font-size: .85rem; font-weight: 700; margin-bottom: 3px; color: var(--navy); }
.principle-desc { font-size: .77rem; color: var(--muted); line-height: 1.55; }
.about-img-block { position: relative; }
.about-img-main { width: 100%; border-radius: var(--r); background: var(--navy); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; font-size: 4rem; }
.about-img-badge { position: absolute; bottom: -16px; right: -16px; background: #fff; border: 1px solid var(--border); border-radius: var(--r); padding: 14px 18px; box-shadow: var(--shadow-md); }
.aib-val { font-size: 1.4rem; font-weight: 700; color: var(--accent); font-family: var(--font-display); letter-spacing: -.03em; }
.aib-lbl { font-size: .72rem; color: var(--muted); margin-top: 2px; }

/* ── Pricing card grid (home) ── */
.p-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 16px; margin-top: 40px;
}
.p-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r); padding: 26px; position: relative;
  min-width: 0; /* prevent grid blowout — card content cannot expand grid tracks */
  transition: box-shadow var(--t-base) var(--ease-out),
              transform var(--t-base) var(--ease-out),
              border-color var(--t-base);
  /* animation handled by .anim-ready + IntersectionObserver */
}
.p-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 0;
  background: linear-gradient(90deg, var(--accent), var(--accent-d));
  border-radius: var(--r) var(--r) 0 0;
  transition: height var(--t-base) var(--ease-out);
}
.p-card:hover { box-shadow: 0 10px 36px rgba(11,21,37,.13),0 2px 8px rgba(11,21,37,.07); transform: translateY(-4px); border-color: var(--border-d); }
.p-card:hover::before { height: 3px; }
.p-card.pop { border: 1px solid var(--border); }
.p-card.pop::before { height: 3px; }
.p-badge {
  display: block; width: fit-content; margin: 0 auto 14px;
  background: var(--accent); color: #fff; font-size: .67rem; font-weight: 700;
  padding: 3px 12px; border-radius: 9999px; letter-spacing: .06em;
  text-transform: uppercase; white-space: nowrap; font-family: var(--font-display);
}
.p-tier {
  font-size: .68rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .1em; color: var(--muted); margin-bottom: 5px;
  font-family: var(--font-display);
}
.p-price {
  font-size: 2.2rem; font-weight: 700; letter-spacing: -.05em;
  line-height: 1; color: var(--navy); font-family: var(--font-display);
}
.p-price span { font-size: .88rem; font-weight: 500; color: var(--muted); }
.p-desc { font-size: .81rem; color: var(--muted); margin: 8px 0 16px; line-height: 1.6; }
.p-feats { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 20px; }
.p-feats li { display: flex; align-items: center; gap: 8px; font-size: .82rem; color: var(--body); }
.feat-y { color: var(--green); display: flex; align-items: center; flex-shrink: 0; }
.feat-n { color: var(--faint); display: flex; align-items: center; flex-shrink: 0; }

/* ── Scroll reveal system ── */
.anim-ready {
  opacity: 0; transform: translateY(22px);
  transition: opacity var(--t-slow) var(--ease-out),
              transform var(--t-slow) var(--ease-out);
}
.anim-ready.anim-in { opacity: 1; transform: none; }

/* Directional variants */
[data-anim="left"].anim-ready  { transform: translateX(-36px); opacity: 0; }
[data-anim="right"].anim-ready { transform: translateX(36px);  opacity: 0; }
[data-anim="scale"].anim-ready { transform: scale(.92);         opacity: 0; }
[data-anim="none"].anim-ready  { transform: none; opacity: 0; }
[data-anim="left"].anim-in,
[data-anim="right"].anim-in,
[data-anim="scale"].anim-in,
[data-anim="none"].anim-in     { transform: none; opacity: 1; }

/* Stagger delays via data-delay */
[data-delay="1"] { transition-delay: .08s !important; }
[data-delay="2"] { transition-delay: .16s !important; }
[data-delay="3"] { transition-delay: .24s !important; }
[data-delay="4"] { transition-delay: .32s !important; }
[data-delay="5"] { transition-delay: .40s !important; }

/* Legacy named delays */
.anim-delay-1 { transition-delay: .07s; }
.anim-delay-2 { transition-delay: .14s; }
.anim-delay-3 { transition-delay: .21s; }

/* Mobile: replace side-entry translateX with a gentle translateY so
   overflow-x clipping on sections never prevents the IO from firing */
@media (max-width: 960px) {
  [data-anim="left"].anim-ready,
  [data-anim="right"].anim-ready { transform: translateY(18px); }
}

/* ── Responsive layout ── */
@media (max-width: 960px) {
  .how-grid, .p-grid { grid-template-columns: 1fr; }
  #home-featured { grid-template-columns: 1fr; }
  .stat-item { flex: 1 1 calc(50% - 1px); border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }
  /* Stack the about grid on mobile */
  .home-about-grid { grid-template-columns: 1fr; gap: 28px; }
  /* Contain any remaining overflow at the section level */
  .section { overflow-x: hidden; }
}
@media (max-width: 600px) {
  .hero { padding: 48px 16px 44px; }
  .hero h1 { font-size: 1.9rem; line-height: 1.08; letter-spacing: -.04em; }
  .search-wrap { padding: 5px 5px 5px 14px; gap: 7px; }
  .search-wrap input { font-size: .88rem; }
  .chips { gap: 5px; }
  .chip { font-size: .71rem; padding: 4px 10px; }
  .stat-item { flex: 1 1 calc(50% - 1px); border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }
  .section { padding: 44px 16px; }
  .sec-title { font-size: 1.35rem; }
  .how-grid { gap: 12px; }
  .how-card { padding: 20px 16px; }
  .p-grid { grid-template-columns: 1fr; gap: 12px; }
  .p-card.pop { order: -1; }
  .home-about-principles { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
}
@media (max-width: 400px) {
  .stat-item { flex: 1 1 100%; }
  .home-about-principles { grid-template-columns: 1fr !important; }
}
