/* ============================================================
   EAGLEEYE — STYLE (Mobile-First, Simplified)
   ============================================================ */

:root {
  --bg:        #09111f;
  --bg2:       #0e1928;
  --bg3:       #131f33;
  --border:    #1e2f4a;
  --border2:   #263d5e;
  --amber:     #f59e0b;
  --amber-l:   #fbbf24;
  --amber-glow:rgba(245,158,11,0.11);
  --green:     #10b981;
  --green-d:   rgba(16,185,129,0.12);
  --txt:       #eef2ff;
  --txt2:      #8896b3;
  --txt3:      #5a6a88;
  --txt4:      #3d4e68;
  --r:         10px;
  --r2:        16px;
  --glow:      0 0 48px rgba(245,158,11,0.13);
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background-color: var(--bg);
  background-image:
    radial-gradient(ellipse 90% 60% at 15% 0%,   rgba(245,158,11,0.08) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 85% 100%,  rgba(14,165,233,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 50% 40%,   rgba(59,130,246,0.04) 0%, transparent 70%);
  color: var(--txt);
  font-family: 'Inter', system-ui, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body.loading { overflow: hidden; }
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 999;
  pointer-events: none; opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='280' height='280' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px;
}
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; color: inherit; }
input, textarea { font-family: inherit; }
ul { list-style: none; }

/* ── TYPE ──────────────────────────────────────────────────── */
h1,h2,h3,h4 {
  font-family: 'Space Grotesk', sans-serif;
  line-height: 1.12; font-weight: 700; color: var(--txt);
}
h1 { font-size: clamp(2.4rem, 9vw, 4.4rem); letter-spacing: -0.025em; }
h2 { font-size: clamp(1.7rem, 5.5vw, 2.7rem); letter-spacing: -0.02em; }
h4 { font-size: clamp(0.98rem, 3vw, 1.08rem); }
p  { color: var(--txt2); }

.container { width: 100%; max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* ── ORBS ──────────────────────────────────────────────────── */
.orb { position: fixed; border-radius: 50%; pointer-events: none; z-index: 0; filter: blur(70px); }
.orb-1 { width:600px;height:600px;top:-280px;left:-200px;background:radial-gradient(circle,rgba(245,158,11,0.1) 0%,transparent 70%);animation:orbDrift1 28s ease-in-out infinite; }
.orb-2 { width:500px;height:500px;bottom:-150px;right:-180px;background:radial-gradient(circle,rgba(14,165,233,0.08) 0%,transparent 70%);animation:orbDrift2 34s ease-in-out infinite; }
.orb-3 { width:400px;height:400px;top:40%;left:40%;background:radial-gradient(circle,rgba(59,130,246,0.05) 0%,transparent 70%);animation:orbDrift3 22s ease-in-out infinite; }
@keyframes orbDrift1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(70px,55px) scale(1.06)} 66%{transform:translate(-35px,90px) scale(0.96)} }
@keyframes orbDrift2 { 0%,100%{transform:translate(0,0) scale(1)} 40%{transform:translate(-65px,-75px) scale(1.09)} 70%{transform:translate(45px,-35px) scale(0.94)} }
@keyframes orbDrift3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,-50px)} }

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:var(--r);
  font-size:.92rem; font-weight:600; font-family:'Space Grotesk',sans-serif;
  transition:all .22s ease; white-space:nowrap; min-height:48px; position:relative; z-index:1;
}
.btn-primary { background:var(--amber); color:#08100d; }
.btn-primary:hover { background:var(--amber-l); transform:translateY(-2px); box-shadow:0 8px 28px rgba(245,158,11,.38); }
.btn-outline { background:transparent; color:var(--txt); border:1.5px solid var(--border2); }
.btn-outline:hover { border-color:var(--amber); color:var(--amber); }
.btn-glass { background:rgba(255,255,255,.07); color:var(--txt); border:1px solid rgba(255,255,255,.12); backdrop-filter:blur(10px); }
.btn-glass:hover { background:rgba(255,255,255,.12); }
.btn-sm  { padding:9px 18px; font-size:.82rem; min-height:40px; }
.btn-lg  { padding:13px 22px; font-size:.95rem; }

/* ── SECTION HEADER ────────────────────────────────────────── */
.section-header { text-align:center; max-width:600px; margin:0 auto 48px; }
.section-header h2 { margin-bottom:12px; }
.section-header p  { font-size:.97rem; line-height:1.7; }
.section-tag {
  display:inline-block; padding:5px 14px;
  background:var(--amber-glow); border:1px solid rgba(245,158,11,.2); border-radius:100px;
  font-size:.72rem; font-weight:700; font-family:'Space Grotesk',sans-serif;
  color:var(--amber); letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px;
}
.accent-text { color:var(--amber); }

/* ── REVEAL ────────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .65s ease,transform .65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.1s; }
.reveal-d2 { transition-delay:.2s; }

/* ── ENTRANCE ANIMS ────────────────────────────────────────── */
@keyframes slideDown { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideUp   { from{opacity:0;transform:translateY(36px)}  to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn    { from{opacity:0}                             to{opacity:1} }
@keyframes scaleIn   { from{opacity:0;transform:scale(.88)}        to{opacity:1;transform:scale(1)} }
.anim-slide-down { animation:slideDown .65s cubic-bezier(.22,1,.36,1) forwards; }
.anim-slide-up   { animation:slideUp   .7s  cubic-bezier(.22,1,.36,1) forwards; }
.anim-fade-in    { animation:fadeIn    .6s  ease forwards; }
.anim-scale-in   { animation:scaleIn   .5s  cubic-bezier(.34,1.56,.64,1) forwards; }

/* ── LOGO ──────────────────────────────────────────────────── */
.logo-img {
  display:block; height:52px; width:auto; flex-shrink:0;
  transition:filter .3s ease, opacity .3s ease;
}
.logo-img-sm { height:38px; }
.nav-logo:hover .logo-img { filter:drop-shadow(0 0 12px rgba(245,158,11,.55)); }
.nav-logo-text {
  white-space:nowrap;
  transition:opacity .35s ease, max-width .35s ease;
  max-width:160px; overflow:hidden;
}
.nav.scrolled .nav-logo-text { opacity:0; max-width:0; pointer-events:none; }

/* ── LOADER ────────────────────────────────────────────────── */
.page-loader {
  position:fixed; inset:0; background:var(--bg); z-index:9999;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition:opacity .65s ease, visibility .65s ease;
}
.page-loader.out { opacity:0; visibility:hidden; }

.loader-eagle-wrap {
  position:relative;
  opacity:0;
  transform:scale(.8) translateY(14px);
  transition:opacity 1s cubic-bezier(.22,1,.36,1), transform 1s cubic-bezier(.22,1,.36,1);
}
.loader-eagle-wrap.show { opacity:1; transform:scale(1) translateY(0); }

.loader-eagle-img {
  display:block;
  height:clamp(120px,28vw,170px);
  width:auto;
  filter:drop-shadow(0 4px 28px rgba(245,158,11,.28));
  animation:eagleGlow 2.8s ease-in-out infinite;
}
@keyframes eagleGlow {
  0%,100% { filter:drop-shadow(0 4px 28px rgba(245,158,11,.28)); }
  50%     { filter:drop-shadow(0 6px 44px rgba(245,158,11,.52)); }
}

.loader-brand { text-align:center; margin-top:22px; }

.loader-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(2.1rem, 7vw, 2.9rem);
  font-weight:800;
  letter-spacing:-.025em;
  line-height:1;
  min-height:1.15em;
  background:linear-gradient(120deg, #d97706 0%, #f59e0b 25%, #fcd34d 50%, #f59e0b 75%, #d97706 100%);
  background-size:200% auto;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:shimmer 4s linear infinite;
}
@keyframes shimmer { to { background-position:200% center; } }


.loader-sub {
  font-family:'Space Grotesk',sans-serif;
  font-size:.62rem; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--txt4);
  margin-top:14px;
  opacity:0; transform:translateY(6px);
  transition:opacity .38s ease, transform .38s ease;
}
.loader-sub.show { opacity:1; transform:translateY(0); }

/* ── NAV ───────────────────────────────────────────────────── */
.nav { position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:background .35s,padding .35s,box-shadow .35s; }
/* backdrop-filter lives on ::before so .nav never becomes a containing block for position:fixed children */
.nav::before {
  content:'';position:absolute;inset:0;z-index:-1;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  opacity:0;transition:opacity .35s;
}
.nav.scrolled::before { opacity:1; }
.nav.scrolled { background:rgba(9,17,31,.94);padding:10px 0;box-shadow:0 1px 0 var(--border); }
.nav-inner { display:flex;align-items:center;gap:24px;position:relative;z-index:101; }
.nav-logo { display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-size:1.15rem;font-weight:600;color:var(--txt);flex-shrink:0; }
.nav-logo strong { font-weight:800;color:var(--amber); }
.nav-links { display:none; flex:1; gap:4px; list-style:none; }
.nav-link { display:block;padding:8px 14px;border-radius:8px;font-size:.87rem;font-weight:500;color:var(--txt2);transition:color .2s,background .2s; }
.nav-link:hover { color:var(--txt);background:rgba(255,255,255,.05); }
.nav-link.active { color:var(--amber); }
.nav-mobile-ctas { display:none; }
.nav-actions { display:none;align-items:center;gap:14px;margin-left:auto; }
.nav-call { display:flex;align-items:center;gap:6px;font-size:.84rem;font-weight:500;color:var(--txt2);transition:color .2s; }
.nav-call:hover { color:var(--amber); }
.nav-toggle { display:flex;flex-direction:column;gap:5px;padding:8px;border-radius:8px;background:rgba(255,255,255,.06);margin-left:auto;min-width:40px;min-height:40px;align-items:center;justify-content:center; }
.nav-toggle span { display:block;width:20px;height:2px;background:var(--txt);border-radius:2px;transition:all .3s ease; }
.nav-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity:0;transform:scaleX(0); }
.nav-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.nav-links.open {
  display:flex!important;flex-direction:column;position:fixed;inset:0;
  background:rgba(9,17,31,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:200;
  align-items:center;justify-content:center;gap:0;padding:80px 24px 48px;
  animation:navIn .32s ease forwards;
}
@keyframes navIn  { from{opacity:0} to{opacity:1} }
@keyframes navItemIn {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes navOut { to { opacity:0; transform:scale(.98); } }

/* Stagger each direct child into view */
.nav-links.open > li,
.nav-links.open > .nav-mobile-ctas {
  opacity:0;
  animation:navItemIn .55s cubic-bezier(.22,1,.36,1) both;
}
.nav-links.open > *:nth-child(2) { animation-delay:.06s; }
.nav-links.open > *:nth-child(3) { animation-delay:.13s; }
.nav-links.open > *:nth-child(4) { animation-delay:.20s; }
.nav-links.open > *:nth-child(5) { animation-delay:.27s; }
.nav-links.open > *:nth-child(6) { animation-delay:.34s; }
.nav-links.open > *:nth-child(7) { animation-delay:.41s; }

/* Closing */
.nav-links.closing {
  display:flex!important;
  pointer-events:none;
  animation:navOut .26s ease forwards;
}

/* Link styles inside open menu */
.nav-links.open .nav-link {
  position:relative;
  font-size:1.28rem;font-family:'Space Grotesk',sans-serif;
  padding:15px 40px;width:100%;text-align:center;
  color:var(--txt2);
  transition:color .22s;
  background:transparent;
}
.nav-links.open .nav-link::after {
  content:'';
  position:absolute;
  bottom:9px; left:50%; transform:translateX(-50%);
  height:1.5px; width:0;
  background:var(--amber);
  border-radius:2px;
  transition:width .28s cubic-bezier(.22,1,.36,1);
}
.nav-links.open .nav-link:hover { color:var(--txt); background:transparent; }
.nav-links.open .nav-link:hover::after { width:32%; }
.nav-links.open .nav-link.active { color:var(--amber); }
.nav-links.open .nav-link.active::after { width:20%; }

/* CTA separator */
.nav-links.open .nav-mobile-ctas {
  display:flex;flex-direction:column;gap:12px;width:100%;
  margin-top:12px;padding-top:28px;
  border-top:1px solid rgba(255,255,255,.07);
}
.nav-links.open .nav-mobile-ctas .btn { width:100%;font-size:1rem;padding:16px; }

/* ── HERO ──────────────────────────────────────────────────── */
.hero { position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:100px 0 80px; }
.hero-canvas { position:absolute;inset:0;width:100%;height:100%; }
.hero-glow { position:absolute;top:-10%;left:50%;transform:translateX(-50%);width:120%;height:60%;background:radial-gradient(ellipse at center top,rgba(245,158,11,.09) 0%,transparent 65%);pointer-events:none; }
.hero-content { position:relative;z-index:1;padding:0 20px;max-width:720px; }
.hero-badge { display:inline-flex;align-items:center;gap:9px;padding:7px 15px;background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.18);border-radius:100px;font-size:.8rem;font-weight:500;color:var(--amber);margin-bottom:26px;opacity:0; }
.pulse-dot { width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulseDot 2.2s ease-in-out infinite;flex-shrink:0; }
@keyframes pulseDot { 0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.5)} 50%{box-shadow:0 0 0 5px rgba(16,185,129,0)} }
.hero-title { display:flex;flex-direction:column;margin-bottom:20px; }
.hero-line-1,.hero-line-2 { display:block;opacity:0; }
.hero-line-2 { color:var(--amber); }
.hero-sub { font-size:clamp(1rem,3.5vw,1.12rem);color:var(--txt2);margin-bottom:32px;opacity:0; }
.hero-btns { display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px; }
.hero-btn-1,.hero-btn-2 { opacity:0; }
.hero-trust { display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:.82rem;color:var(--txt3);opacity:0; }

/* ── SERVICES ──────────────────────────────────────────────── */
.services { padding:80px 0;position:relative;z-index:1; }
.services-grid { display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:32px; }
.svc-card {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:36px 28px 30px;
  text-align:center;
  position:relative;
  overflow:hidden;
  transition:border-color .35s, transform .4s cubic-bezier(.22,1,.36,1), box-shadow .35s;
}
/* Ambient radial glow from top on hover */
.svc-card::before {
  content:'';
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:100%; height:100%;
  background:radial-gradient(ellipse 80% 55% at 50% 0%, rgba(245,158,11,.09) 0%, transparent 68%);
  opacity:0; pointer-events:none;
  transition:opacity .45s ease;
}
.svc-card:hover::before { opacity:1; }
/* Bottom accent line draws in */
.svc-card::after {
  content:'';
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--amber),transparent);
  border-radius:2px;
  transition:width .5s cubic-bezier(.22,1,.36,1);
}
.svc-card:hover::after { width:68%; }
.svc-card:hover {
  border-color:rgba(245,158,11,.35);
  transform:translateY(-7px);
  box-shadow:0 18px 48px rgba(245,158,11,.11), 0 4px 20px rgba(0,0,0,.28);
}
.svc-icon {
  width:64px; height:64px; border-radius:18px;
  background:var(--amber-glow); border:1px solid rgba(245,158,11,.2);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber);
  margin:0 auto 22px;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), background .3s, box-shadow .3s;
}
.svc-icon svg { width:28px; height:28px; }
.svc-card:hover .svc-icon {
  transform:scale(1.12) rotate(-7deg);
  background:rgba(245,158,11,.22);
  box-shadow:0 0 26px rgba(245,158,11,.32);
}
.svc-card h4 { margin-bottom:10px; font-size:1.06rem; }
.svc-card p  { font-size:.88rem; line-height:1.65; }
.why-grid { display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px 24px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2); }
.why-item { display:flex;align-items:center;gap:9px;font-size:.85rem;font-weight:500;color:var(--txt2); }

/* ── PATTERNS ──────────────────────────────────────────────── */
.patterns { padding:80px 0;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;z-index:1; }
.patterns-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.pattern-card { background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:border-color .3s,box-shadow .3s; }
.pattern-card:hover { border-color:rgba(245,158,11,.25);box-shadow:var(--glow); }
.pattern-canvas { display:block;width:100%;height:auto; }
.pattern-info { padding:14px 16px; }
.pattern-info h4 { font-size:.95rem;margin-bottom:4px; }
.pattern-info span { font-size:.78rem;color:var(--txt3); }

/* ── PROCESS ───────────────────────────────────────────────── */
.process { padding:80px 0;position:relative;z-index:1; }

.process-track {
  position:relative;
  max-width:460px;
  margin:0 auto;
}

/* Vertical connector line (mobile) */
.process-vline {
  position:absolute;
  left:22px;
  top:46px;
  bottom:46px;
  width:2px;
  background:var(--border);
  border-radius:2px;
  overflow:hidden;
}
.process-vfill {
  width:100%;
  height:0;
  background:linear-gradient(180deg, var(--amber) 0%, rgba(245,158,11,.2) 100%);
  border-radius:2px;
  transition:height .9s cubic-bezier(.22,1,.36,1);
}

.process-step {
  display:flex;
  align-items:flex-start;
  gap:20px;
  padding-bottom:40px;
  opacity:0;
  transform:translateX(22px);
  transition:opacity .5s ease, transform .5s ease;
}
.process-step:last-child { padding-bottom:0; }
.process-step.ps-active { opacity:1; transform:translateX(0); }

.ps-node {
  position:relative;
  width:46px;
  height:46px;
  flex-shrink:0;
  border-radius:50%;
  background:var(--bg2);
  border:2px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1;
  transition:border-color .4s, background .4s, box-shadow .4s;
}
.ps-node span {
  font-family:'Space Grotesk',sans-serif;
  font-size:.7rem;
  font-weight:800;
  letter-spacing:.06em;
  color:var(--txt3);
  transition:color .4s;
  user-select:none;
}
.ps-ring {
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:1.5px solid transparent;
  pointer-events:none;
}

.process-step.ps-active .ps-node {
  border-color:var(--amber);
  background:rgba(245,158,11,.07);
  box-shadow:0 0 22px rgba(245,158,11,.22), 0 0 8px rgba(245,158,11,.1);
}
.process-step.ps-active .ps-node span { color:var(--amber); }
.process-step.ps-active .ps-ring {
  border-color:rgba(245,158,11,.22);
  animation:psRingPulse 2.8s ease-in-out infinite;
}
@keyframes psRingPulse {
  0%,100% { transform:scale(1); opacity:.7; }
  50%      { transform:scale(1.22); opacity:.15; }
}

.ps-body { padding-top:10px; flex:1; min-width:0; }
.ps-body h4 { margin-bottom:6px; }
.ps-body p  { font-size:.88rem; line-height:1.65; }

/* ── FAQ ───────────────────────────────────────────────────── */
.faq { padding:80px 0;background:var(--bg2);border-top:1px solid var(--border);position:relative;z-index:1; }
.faq .container { max-width:680px; }
.faq-list { display:flex;flex-direction:column;gap:10px; }
.faq-item { background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s; }
.faq-item.open { border-color:rgba(245,158,11,.3); }
.faq-q { width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px;font-size:.92rem;font-weight:600;font-family:'Space Grotesk',sans-serif;color:var(--txt);text-align:left;min-height:64px; }
.faq-q svg { flex-shrink:0;color:var(--txt3);transition:transform .3s; }
.faq-item.open .faq-q { color:var(--amber); }
.faq-item.open .faq-q svg { transform:rotate(180deg);color:var(--amber); }
.faq-a { max-height:0;overflow:hidden;transition:max-height .38s ease,padding .38s ease;font-size:.88rem;color:var(--txt2);line-height:1.7;padding:0 20px; }
.faq-item.open .faq-a { max-height:150px;padding:0 20px 20px; }

/* ── CONTACT ───────────────────────────────────────────────── */
.contact { padding:80px 0;position:relative;z-index:1; }
.contact-ctas { display:flex;flex-direction:column;gap:14px;max-width:520px;margin:0 auto 28px; }
.contact-btn { display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:var(--r2);border:1.5px solid transparent;transition:all .22s ease;min-height:68px; }
.contact-btn.primary { background:var(--amber);color:#080d08; }
.contact-btn.primary:hover { background:var(--amber-l);transform:translateY(-2px);box-shadow:0 12px 36px rgba(245,158,11,.35); }
.contact-btn.secondary { background:var(--bg2);border-color:var(--border2);color:var(--txt); }
.contact-btn.secondary:hover { border-color:var(--amber);transform:translateY(-2px); }
.cbtn-icon { width:42px;height:42px;border-radius:10px;background:rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.contact-btn.secondary .cbtn-icon { background:var(--amber-glow);color:var(--amber); }
.cbtn-text { flex:1; }
.cbtn-text strong { display:block;font-size:1rem;font-family:'Space Grotesk',sans-serif;margin-bottom:2px; }
.cbtn-text span   { font-size:.82rem;opacity:.7; }
.contact-meta { display:flex;flex-direction:column;align-items:center;gap:10px;max-width:520px;margin:0 auto;text-align:center; }
.contact-meta span {
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:20px 28px;
  background:rgba(245,158,11,.06);
  border:1px solid rgba(245,158,11,.14);
  border-radius:16px;
  font-size:.92rem;color:var(--txt2);
}
.contact-meta span svg { width:22px;height:22px; }

/* ── FOOTER ────────────────────────────────────────────────── */
.footer { background:var(--bg);border-top:1px solid var(--border);padding:48px 0 32px;position:relative;z-index:1; }
.footer-inner { display:flex;align-items:center;justify-content:center;margin-bottom:28px; }
.footer-brand {
  display:flex;flex-direction:column;align-items:center;gap:11px;
  text-decoration:none;
}
.footer-brand .logo-img-sm { transition:filter .3s ease; }
.footer-brand:hover .logo-img-sm { filter:drop-shadow(0 0 12px rgba(245,158,11,.5)); }
.footer-brand-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.08rem;font-weight:600;
  color:var(--txt);letter-spacing:.01em;
}
.footer-brand-name strong { font-weight:800;color:var(--amber); }
.footer-certs { display:flex;gap:8px;flex-wrap:wrap; }
.cert { padding:4px 10px;background:var(--green-d);border:1px solid rgba(16,185,129,.18);border-radius:100px;font-size:.68rem;font-weight:700;color:var(--green);letter-spacing:.05em; }
.footer-links-row { display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--border);padding-top:20px;margin-bottom:24px; }
.footer-links-row a { font-size:.84rem;color:var(--txt3);padding:6px 14px;border-radius:6px;transition:color .2s;min-height:40px;display:flex;align-items:center; }
.footer-links-row a:hover { color:var(--amber); }
.footer-bottom { border-top:1px solid var(--border);padding-top:20px;display:flex;flex-direction:column;gap:4px;font-size:.76rem;color:var(--txt4);text-align:center;align-items:center; }

/* ── FLOATING CTA ──────────────────────────────────────────── */
.floating-cta { position:fixed;bottom:22px;right:18px;z-index:99;display:flex;align-items:center;gap:7px;padding:10px 16px;background:var(--amber);color:#08100d;font-size:.8rem;font-weight:700;font-family:'Space Grotesk',sans-serif;border-radius:100px;box-shadow:0 6px 22px rgba(245,158,11,.38);transform:translateY(80px);opacity:0;transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .4s ease;min-height:40px; }
.floating-cta.show { transform:translateY(0);opacity:1; }
.floating-cta:hover { background:var(--amber-l);transform:translateY(-2px);animation:none; }

/* ── NAV CLOSE ─────────────────────────────────────────────── */
.nav-close { display:none; }
.nav-links.open .nav-close { display:flex;position:absolute;top:18px;right:18px;width:44px;height:44px;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--txt);transition:background .2s; }
.nav-links.open .nav-close:hover { background:rgba(255,255,255,.16); }

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (min-width:600px) {
  .services-grid { grid-template-columns:repeat(3,1fr); }
  .why-grid      { grid-template-columns:repeat(4,1fr); }
  .contact-ctas  { flex-direction:row; }
  .btn-lg        { padding:16px 32px; font-size:1rem; }
}
@media (min-width:900px) {
  section,.services,.patterns,.process,.faq,.contact { padding:100px 0; }
  .nav-toggle  { display:none; }
  .nav-links   { display:flex; }
  .nav-actions { display:flex; }
  .footer-bottom { flex-direction:column;align-items:center; }
  .patterns-grid { grid-template-columns:repeat(4,1fr); }
  /* Process — horizontal layout */
  .process-track {
    max-width:720px;
    display:flex;
    align-items:flex-start;
    position:relative;
  }
  .process-track::before {
    content:'';
    position:absolute;
    left:calc(100%/6 + 23px);
    right:calc(100%/6 + 23px);
    top:22px;
    height:2px;
    background:var(--border);
    z-index:0;
  }
  .process-vline { display:none; }
  .process-step {
    flex:1;
    flex-direction:column;
    align-items:center;
    text-align:center;
    padding:0;
    gap:16px;
    transform:translateY(18px);
  }
  .process-step.ps-active { transform:translateY(0); }
  .ps-body { padding-top:0; }
}
@media (max-width:400px) {
  .hero-btns { flex-direction:column; }
  .hero-btns .btn { width:100%; }
  .why-grid  { grid-template-columns:1fr; }
  .patterns-grid { grid-template-columns:1fr; }
}

/* ── LUXURY TOUCHES ────────────────────────────────────────── */

/* Scroll progress bar */
.scroll-progress {
  position:fixed; top:0; left:0; z-index:10000;
  height:2px; width:0%;
  background:linear-gradient(90deg,#d97706 0%,var(--amber) 55%,#fcd34d 100%);
  pointer-events:none;
  will-change:width;
}

/* Section H2 — animated underline draws on scroll entry */
.section-header h2::after {
  content:'';
  display:block;
  margin:10px auto 0;
  height:3px; width:0;
  background:linear-gradient(90deg,transparent 0%,var(--amber) 25%,var(--amber-l) 50%,var(--amber) 75%,transparent 100%);
  border-radius:3px;
  box-shadow:0 0 10px rgba(245,158,11,.45);
  transition:width .75s cubic-bezier(.22,1,.36,1) .32s;
}
.section-header.visible h2::after { width:72%; }

/* Stagger-reveal children */
.stagger-child {
  opacity:0;
  transform:translateY(16px);
  transition:opacity .5s ease, transform .5s ease;
}
.stagger-child.visible { opacity:1; transform:translateY(0); }

/* Why items slide in from left */
.why-item.stagger-child { transform:translateX(-14px); }
.why-item.stagger-child.visible { transform:translateX(0); }

/* FAQ items keep their border-color transition */
.faq-item.stagger-child { transition:border-color .2s, opacity .5s ease, transform .5s ease; }

/* Floating CTA — breathing pulse after it slides in */
@keyframes ctaPulse {
  0%,100% { box-shadow:0 6px 22px rgba(245,158,11,.38); }
  50%      { box-shadow:0 6px 32px rgba(245,158,11,.6), 0 0 0 8px rgba(245,158,11,.07); }
}
.floating-cta.show { animation:ctaPulse 3.5s ease-in-out infinite 1.8s; }

/* Footer location link */
.footer-location {
  display:inline-flex;align-items:center;gap:6px;
  color:var(--txt4);font-size:.76rem;
  transition:color .22s;
}
.footer-location svg { color:var(--amber);flex-shrink:0; }
.footer-location:hover { color:var(--amber); }
