/* ============================================================
   KEY WILLS & TRUSTS — components
   ============================================================ */

/* ============ HEADER ============ */
.site-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:60;
  background:rgba(12,35,64,.78);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .3s, box-shadow .3s, border-color .3s;
}
.site-header.scrolled{
  background:rgba(10,29,53,.96);
  box-shadow:0 10px 30px rgba(5,16,30,.35);
}
.header-inner{
  height:var(--header-h);
  display:flex;
  align-items:center;
  gap:18px;
}
.brand{ display:flex; align-items:center; flex:none; }
.brand img{ height:40px; width:auto; }
.brand .logo-wordmark{
  font-family:var(--f-display);
  font-weight:700;
  color:#fff;
  font-size:1.18rem;
  letter-spacing:-.01em;
  line-height:1.05;
}
.brand .logo-wordmark span{ color:var(--orange); }

.nav{ display:none; margin-left:auto; }
.nav ul{ display:flex; align-items:center; gap:4px; }
.nav a{
  display:block;
  color:rgba(255,255,255,.84);
  font-weight:500;
  font-size:.95rem;
  padding:10px 14px;
  border-radius:var(--r-pill);
  transition:color .2s, background .2s;
}
.nav a:hover{ color:#fff; background:rgba(255,255,255,.08); }

.header-actions{ display:none; align-items:center; gap:14px; margin-left:8px; }
.tel-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  font-weight:600;
  font-size:.95rem;
  white-space:nowrap;
}
.tel-link svg{ width:17px; height:17px; color:var(--orange); }
.tel-link:hover{ color:var(--orange); }

@media (min-width:1024px){
  .nav{ display:block; }
  .header-actions{ display:flex; }
}

/* mobile menu toggle */
.menu-toggle{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:46px; height:46px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
}
.menu-toggle span{
  position:relative;
  width:20px; height:2px; border-radius:2px;
  background:#fff;
  transition:transform .3s var(--ease), background .2s;
}
.menu-toggle span::before,
.menu-toggle span::after{
  content:""; position:absolute; left:0;
  width:20px; height:2px; border-radius:2px; background:#fff;
  transition:transform .3s var(--ease), top .3s var(--ease);
}
.menu-toggle span::before{ top:-6px; }
.menu-toggle span::after{ top:6px; }
body.menu-open .menu-toggle span{ background:transparent; }
body.menu-open .menu-toggle span::before{ top:0; transform:rotate(45deg); }
body.menu-open .menu-toggle span::after{ top:0; transform:rotate(-45deg); }
@media (min-width:1024px){ .menu-toggle{ display:none; } }

/* mobile drawer */
.mobile-nav{
  position:fixed;
  inset:var(--header-h) 0 auto 0;
  z-index:55;
  background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.1);
  padding:14px 22px 26px;
  transform:translateY(-12px);
  opacity:0;
  visibility:hidden;
  transition:transform .3s var(--ease), opacity .3s, visibility .3s;
  box-shadow:0 26px 50px rgba(5,16,30,.45);
}
body.menu-open .mobile-nav{ transform:none; opacity:1; visibility:visible; }
.mobile-nav a{
  display:block;
  color:rgba(255,255,255,.9);
  font-weight:500;
  font-size:1.05rem;
  padding:14px 8px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mobile-nav a:hover{ color:var(--orange); }
.mobile-nav .mobile-cta{ display:grid; gap:12px; margin-top:18px; }
.mobile-nav .mobile-cta .btn{ width:100%; }
@media (min-width:1024px){ .mobile-nav{ display:none; } }

/* ============ HERO ============ */
.hero{
  position:relative;
  background:
    radial-gradient(900px 540px at 78% 18%, rgba(242,153,74,.20), transparent 60%),
    radial-gradient(720px 520px at 10% 90%, rgba(28,67,116,.55), transparent 60%),
    linear-gradient(165deg, #0B2038 0%, var(--navy) 48%, #0A1B30 100%);
  color:#fff;
  padding:calc(var(--header-h) + 56px) 0 130px;
  overflow:hidden;
}
.hero::before{
  /* faint keyhole grid texture */
  content:"";
  position:absolute; inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1.4px);
  background-size:30px 30px;
  mask-image:radial-gradient(120% 100% at 70% 30%, #000, transparent 75%);
  pointer-events:none;
}
.hero-grid{
  position:relative;
  display:grid;
  gap:46px;
  grid-template-columns:1fr;
  align-items:center;
}
@media (min-width:980px){
  .hero-grid{ grid-template-columns:1.08fr .92fr; gap:54px; }
  .hero{ padding-bottom:150px; }
}

.hero h1{
  font-size:clamp(2.35rem, 1.3rem + 4.6vw, 4.05rem);
  margin:18px 0 0;
  letter-spacing:-.018em;
}
.hero h1 .hl{ color:var(--orange); }
.hero .sub{
  margin-top:22px;
  font-size:clamp(1.05rem, .98rem + .5vw, 1.28rem);
  color:rgba(235,242,250,.86);
  max-width:36ch;
  line-height:1.55;
}
.hero-cta{
  margin-top:32px;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}
.hero .trust-line{
  margin-top:26px;
  display:flex;
  align-items:center;
  gap:11px;
  font-size:.95rem;
  color:rgba(235,242,250,.78);
}
.hero .trust-line svg{ width:20px; height:20px; color:var(--gold); flex:none; }

/* load stagger */
.hero [data-load]{ opacity:0; transform:translateY(22px); }
.hero.loaded [data-load]{ animation:fadeUp .9s var(--ease) forwards; }
.hero.loaded [data-load="1"]{ animation-delay:.05s; }
.hero.loaded [data-load="2"]{ animation-delay:.16s; }
.hero.loaded [data-load="3"]{ animation-delay:.28s; }
.hero.loaded [data-load="4"]{ animation-delay:.40s; }
.hero.loaded [data-load="5"]{ animation-delay:.52s; }
@keyframes fadeUp{ to{ opacity:1; transform:none; } }

/* ---- hero key/safe visual ---- */
.hero-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:340px;
}
.hero-visual .glow{
  position:absolute;
  width:78%; aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle, rgba(242,153,74,.34), transparent 64%);
  filter:blur(8px);
}
.safe{
  position:relative;
  width:min(420px, 86vw);
  filter:drop-shadow(0 30px 50px rgba(5,16,30,.5));
}
.safe svg{ width:100%; height:auto; display:block; overflow:visible; }

/* key turns in the lock on load */
.safe .key-group{
  transform:rotate(-94deg);
  transform-origin:200px 196px;
  transform-box:view-box;
  transition:transform 1.15s var(--ease);
}
.safe.unlocked .key-group{ transform:rotate(0deg); }
.safe .lock-glow{ opacity:0; transition:opacity .7s ease .35s; }
.safe.unlocked .lock-glow{ opacity:1; }
.safe .dial-ring{
  transform-origin:200px 196px;
  transform-box:view-box;
  transition:transform 1.2s var(--ease);
}
.safe.unlocked .dial-ring{ transform:rotate(118deg); }

@media (prefers-reduced-motion:reduce){
  .safe .key-group,
  .safe .dial-ring{ transform:none !important; transition:none; }
  .safe .lock-glow{ opacity:1; }
}

@media (prefers-reduced-motion:reduce){
  .hero.loaded [data-load]{ animation:none; opacity:1; transform:none; }
}

/* wave divider */
.wave{ position:relative; line-height:0; }
.wave svg{ display:block; width:100%; height:auto; }
.hero-wave{ position:absolute; left:0; right:0; bottom:-1px; z-index:2; }

/* ============ TRUST STRIP ============ */
.trust-strip{
  background:var(--paper);
  padding:8px 0 64px;
}
.chips{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
@media (min-width:680px){ .chips{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px){ .chips{ grid-template-columns:repeat(6,1fr); gap:16px; } }

.chip{
  background:var(--cloud);
  border:1px solid var(--hairline);
  border-radius:var(--r-md);
  padding:20px 16px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  min-height:128px;
  box-shadow:var(--shadow-sm);
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .2s;
}
.chip:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(242,153,74,.4); }
.chip .ic{
  width:42px; height:42px;
  border-radius:11px;
  background:rgba(242,153,74,.14);
  color:var(--orange-deep);
  display:flex; align-items:center; justify-content:center;
  flex:none;
}
.chip .ic svg{ width:22px; height:22px; }
.chip .label{ font-weight:600; font-size:.95rem; color:var(--navy); line-height:1.3; }

.chip.ipw{ align-items:center; justify-content:center; text-align:center; gap:10px; }
.chip.ipw img{ max-height:62px; width:auto; object-fit:contain; }
.chip.ipw .ipw-fallback{
  display:none;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.chip.ipw.failed{ border-color:var(--gold); box-shadow:0 0 0 2px rgba(217,164,65,.25), var(--shadow-sm); }
.chip.ipw.failed img{ display:none; }
.chip.ipw.failed .ipw-fallback{ display:flex; }
.chip.ipw .ipw-fallback strong{
  font-family:var(--f-display);
  color:var(--navy); font-size:1.3rem;
}
.chip.ipw .ipw-fallback span{ font-size:.72rem; color:var(--ink-soft); line-height:1.25; }

/* ============ HOW IT WORKS ============ */
.how{
  background:var(--navy);
  color:#fff;
  padding:88px 0 100px;
  position:relative;
}
.how .eyebrow{ color:var(--orange); }
.how .section-head h2{ color:#fff; }
.how-top{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:24px; }
.how-grid{
  margin-top:48px;
  display:grid;
  gap:18px;
  grid-template-columns:1fr;
}
@media (min-width:640px){ .how-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .how-grid{ grid-template-columns:repeat(5,1fr); gap:16px; } }

.step{
  background:linear-gradient(180deg, rgba(28,67,116,.55), rgba(21,53,92,.35));
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg);
  padding:26px 22px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .2s, background .2s;
}
.step:hover{ transform:translateY(-5px); border-color:rgba(242,153,74,.5); background:linear-gradient(180deg, rgba(28,67,116,.7), rgba(21,53,92,.45)); }
.step .num{
  font-family:var(--f-display);
  font-weight:700;
  font-size:2.1rem;
  color:var(--orange);
  line-height:1;
  display:flex;
  align-items:baseline;
  gap:8px;
}
.step .num::before{
  content:"";
  width:30px; height:30px;
  border-radius:9px;
  background:rgba(242,153,74,.16);
  display:inline-block;
}
.step p{ color:rgba(232,240,249,.84); font-size:.98rem; line-height:1.5; }
.how-cta{ margin-top:40px; display:flex; }

@media (min-width:1024px){
  .step{ position:relative; }
}

/* ============ SERVICES ============ */
.services{
  background:var(--paper);
  padding:90px 0 104px;
}
.services-grid{
  margin-top:48px;
  display:grid;
  gap:20px;
  grid-template-columns:1fr;
}
@media (min-width:640px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .services-grid{ grid-template-columns:repeat(3,1fr); } }

.svc{
  background:var(--cloud);
  border:1px solid var(--hairline);
  border-radius:var(--r-lg);
  padding:30px 28px 28px;
  display:flex;
  flex-direction:column;
  gap:16px;
  box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .2s;
  position:relative;
  overflow:hidden;
}
.svc::after{
  content:"";
  position:absolute; left:0; top:0; height:4px; width:100%;
  background:linear-gradient(90deg, var(--orange), var(--gold));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s var(--ease);
}
.svc:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(242,153,74,.45); }
.svc:hover::after{ transform:scaleX(1); }
.svc .svc-ic{
  width:58px; height:58px;
  border-radius:15px;
  background:linear-gradient(160deg, var(--navy), var(--navy-3));
  display:flex; align-items:center; justify-content:center;
  color:var(--orange);
  flex:none;
  box-shadow:var(--shadow-sm);
}
.svc .svc-ic svg{ width:30px; height:30px; }
.svc h3{ font-size:1.32rem; color:var(--navy); }
.svc p{ color:var(--ink-soft); font-size:1rem; flex:1; }
.svc .link-more{ margin-top:4px; }

/* featured (Trusts) card */
.svc.featured{
  background:linear-gradient(165deg, var(--navy) 0%, var(--navy-3) 100%);
  border-color:transparent;
}
.svc.featured h3{ color:#fff; }
.svc.featured p{ color:rgba(232,240,249,.82); }
.svc.featured .svc-ic{ background:rgba(242,153,74,.16); color:var(--orange); }
.svc.featured .badge{
  position:absolute; top:20px; right:20px;
  font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:#2A1402; background:var(--gold);
  padding:5px 11px; border-radius:var(--r-pill);
}
.svc.featured .link-more{ color:var(--orange); }
