/* =========================================================
   WAELOP — Operation & Maintenance
   Global Stylesheet
   ========================================================= */

:root{
  /* Colour System */
  --navy-900:#0A192F;
  --navy-800:#0F2240;
  --navy-700:#13294B;
  --navy-600:#1B3358;
  --slate-300:#CBD5E1;
  --slate-200:#E2E8F0;
  --slate-100:#F1F5F9;
  --gold:#D4AF37;
  --gold-soft:#E8C766;
  --white:#FFFFFF;
  --black:#000000;

  /* Type */
  --font-display:'Montserrat',system-ui,-apple-system,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;

  /* Layout */
  --container:1240px;
  --radius:14px;
  --radius-sm:8px;

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-soft:cubic-bezier(.6,.05,.28,.91);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--white);
  color:var(--navy-900);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.1;
  color:var(--navy-900);
  margin:0 0 .5em;
}
h1{font-size:clamp(2.6rem,5.6vw,5rem)}
h2{font-size:clamp(2rem,3.6vw,3.4rem)}
h3{font-size:clamp(1.3rem,1.8vw,1.7rem)}
p{margin:0 0 1em;font-size:1.02rem;color:#3A4A5F}
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--font-display);
  font-weight:600;font-size:.78rem;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1.2rem;
}
.eyebrow::before{
  content:"";display:inline-block;width:32px;height:1px;background:var(--gold);
}

/* ---------- LAYOUT HELPERS ---------- */
.container{
  max-width:var(--container);
  margin-inline:auto;
  padding:0 clamp(1.2rem,3vw,2rem);
}
section{padding:clamp(4rem,8vw,7rem) 0;position:relative}
.section-dark{background:var(--navy-900);color:var(--slate-200)}
.section-dark h1,.section-dark h2,.section-dark h3{color:var(--white)}
.section-dark p{color:var(--slate-300)}
.section-light{background:var(--slate-100)}

.grid{display:grid;gap:2rem}
.two-col{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:center;gap:4rem}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:.95rem 1.7rem;
  font-family:var(--font-display);
  font-weight:600;font-size:.92rem;
  letter-spacing:.04em;
  border-radius:999px;
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease),box-shadow .35s var(--ease);
  position:relative;overflow:hidden;
  cursor:pointer;
}
.btn-primary{
  background:var(--gold);color:var(--navy-900);
  box-shadow:0 10px 30px -10px rgba(212,175,55,.55);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 40px -10px rgba(212,175,55,.7)}
.btn-ghost{
  background:transparent;color:var(--white);
  border:1px solid rgba(255,255,255,.25);
}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--gold);color:var(--gold)}
.btn-dark{
  background:var(--navy-900);color:var(--white);
}
.btn-dark:hover{background:var(--navy-700)}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}

/* ---------- NAVBAR ---------- */
.nav{
  position:fixed;top:1rem;left:50%;transform:translateX(-50%);
  z-index:100;
  width:calc(100% - 2rem);max-width:1320px;
  background:rgba(10,25,47,.65);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.07);
  border-radius:999px;
  padding:.65rem 1.2rem .65rem 1.6rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:all .5s var(--ease);
}
.nav.scrolled{
  background:rgba(10,25,47,.9);
  box-shadow:0 20px 60px -25px rgba(0,0,0,.5);
}
.nav__brand{
  display:flex;align-items:center;gap:.6rem;
  color:var(--white);font-family:var(--font-display);
  font-weight:800;font-size:1.15rem;letter-spacing:.04em;
}
.nav__brand .mark{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  display:grid;place-items:center;color:var(--navy-900);
  font-weight:900;font-size:.95rem;
}
.nav__brand small{
  display:block;font-size:.55rem;font-weight:500;letter-spacing:.25em;color:var(--gold);
  margin-top:-2px;
}
.nav__links{
  display:flex;align-items:center;gap:.4rem;list-style:none;margin:0;padding:0;
}
.nav__links a{
  color:var(--slate-200);
  padding:.55rem .95rem;border-radius:999px;
  font-size:.88rem;font-weight:500;
  transition:all .3s var(--ease);
}
.nav__links a:hover,.nav__links a.active{color:var(--white);background:rgba(255,255,255,.06)}
.nav__cta{
  background:var(--gold);color:var(--navy-900);
  padding:.65rem 1.2rem;border-radius:999px;
  font-family:var(--font-display);font-weight:700;font-size:.85rem;
  letter-spacing:.04em;
  position:relative;
  transition:all .35s var(--ease);
}
.nav__cta::after{
  content:"";position:absolute;inset:-3px;border-radius:999px;
  border:1px solid rgba(212,175,55,.5);
  animation:pulse 2.4s var(--ease) infinite;
}
.nav__cta:hover{transform:translateY(-2px)}
.nav__toggle{display:none;color:var(--white);width:36px;height:36px;border-radius:50%}
.nav__toggle span{
  display:block;width:18px;height:1.5px;background:currentColor;margin:4px auto;
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(212,175,55,.5)}
  50%{box-shadow:0 0 0 8px rgba(212,175,55,0)}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  background:var(--navy-900);
  color:var(--white);
  display:flex;align-items:center;
  overflow:hidden;
  padding-top:7rem;
}
.hero__bg{
  position:absolute;inset:0;z-index:0;
}
.hero__bg::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,25,47,.7) 0%,rgba(10,25,47,.85) 50%,var(--navy-900) 100%);
  z-index:1;
}
.hero__bg img,.hero__bg video{
  width:100%;height:100%;object-fit:cover;opacity:.55;
}
.hero__grid-overlay{
  position:absolute;inset:0;z-index:1;opacity:.15;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;width:100%}
.hero__copy h1{color:var(--white)}
.hero__copy h1 .gold{color:var(--gold)}
.hero__copy .lead{font-size:1.15rem;color:var(--slate-300);max-width:560px;margin-bottom:2rem}
.hero__cta-row{display:flex;flex-wrap:wrap;gap:1rem}
.hero__type{
  font-family:var(--font-display);font-weight:700;
  color:var(--gold);font-size:1.4rem;min-height:1.7em;display:block;margin-bottom:1.2rem;
}
.hero__type::after{
  content:"|";display:inline-block;margin-left:2px;color:var(--gold);
  animation:blink 1s steps(2) infinite;
}
@keyframes blink{50%{opacity:0}}

.hero__visual{position:relative;aspect-ratio:1/1.05}
.hero__visual .blob{
  position:absolute;inset:0;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(212,175,55,.12),transparent 60%),
             linear-gradient(20deg,rgba(255,255,255,.04),transparent 70%);
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.hero__visual .blob::before{
  content:"";position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=900&q=80') center/cover;
  opacity:.55;
}
.hero__visual .stat{
  position:absolute;background:rgba(10,25,47,.7);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:1.1rem 1.3rem;
  z-index:2;
}
.hero__visual .stat .num{
  font-family:var(--font-display);font-weight:800;font-size:1.8rem;color:var(--gold);display:block;
}
.hero__visual .stat .lbl{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate-300)}
.hero__visual .stat--a{top:8%;right:-2%}
.hero__visual .stat--b{bottom:6%;left:-2%}
.hero__visual .badge{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:130px;height:130px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--gold),#9a7b1a);
  display:grid;place-items:center;text-align:center;
  font-family:var(--font-display);font-weight:800;font-size:.78rem;letter-spacing:.18em;
  color:var(--navy-900);
  box-shadow:0 30px 60px -20px rgba(212,175,55,.55);
}
.hero__scroll{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:3;
  color:var(--slate-300);font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
}
.hero__scroll::after{
  content:"";width:1px;height:34px;background:var(--slate-300);
  animation:scrollLine 2s var(--ease) infinite;transform-origin:top;
}
@keyframes scrollLine{0%{transform:scaleY(0)}50%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- SECTION HEADER ---------- */
.sec-head{max-width:760px;margin-bottom:3.5rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head p{font-size:1.08rem}

/* ---------- VALUES STRIP ---------- */
.values-strip{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;
  border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);
}
.value-cell{
  padding:2.2rem 1.6rem;border-right:1px solid rgba(255,255,255,.08);
  transition:background .4s var(--ease);
}
.value-cell:last-child{border-right:none}
.value-cell:hover{background:rgba(212,175,55,.05)}
.value-cell .num{
  color:var(--gold);font-family:var(--font-display);font-size:.8rem;letter-spacing:.3em;
  font-weight:700;margin-bottom:.8rem;display:block;
}
.value-cell h3{color:var(--white);font-size:1.25rem;margin-bottom:.4rem}
.value-cell p{font-size:.92rem;margin:0;color:var(--slate-300)}

/* ---------- SERVICE CARDS ---------- */
.services-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.4rem;
}
.service-card{
  position:relative;
  background:var(--white);
  border:1px solid var(--slate-200);
  border-radius:var(--radius);
  padding:2.2rem 1.8rem;
  overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease);
  isolation:isolate;
}
.service-card::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(160deg,var(--navy-900),var(--navy-700));
  opacity:0;transition:opacity .5s var(--ease);
}
.service-card::after{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background-image:
    linear-gradient(rgba(212,175,55,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.08) 1px,transparent 1px);
  background-size:30px 30px;
  transition:opacity .6s var(--ease);
}
.service-card:hover{
  transform:translateY(-6px);
  border-color:var(--navy-900);
  box-shadow:0 30px 60px -25px rgba(10,25,47,.45);
}
.service-card:hover::before,.service-card:hover::after{opacity:1}
.service-card:hover h3,.service-card:hover p,.service-card:hover .num{color:var(--white)!important}
.service-card:hover .icon{background:var(--gold);color:var(--navy-900);border-color:var(--gold)}
.service-card:hover .more{color:var(--gold)}
.service-card .num{
  font-family:var(--font-display);font-weight:700;color:var(--slate-300);
  font-size:.82rem;letter-spacing:.3em;margin-bottom:1.3rem;display:block;
  transition:color .5s var(--ease);
}
.service-card .icon{
  width:54px;height:54px;border-radius:14px;
  border:1px solid var(--slate-200);
  display:grid;place-items:center;color:var(--navy-900);
  margin-bottom:1.4rem;
  transition:all .5s var(--ease);
}
.service-card h3{transition:color .5s var(--ease);margin-bottom:.7rem}
.service-card p{transition:color .5s var(--ease);font-size:.95rem}
.service-card .more{
  display:inline-flex;align-items:center;gap:.5rem;margin-top:.8rem;
  font-family:var(--font-display);font-weight:600;font-size:.82rem;
  color:var(--navy-900);letter-spacing:.06em;
  transition:color .5s var(--ease);
}

/* ---------- SPLIT FEATURE BLOCKS ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split__media{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(10,25,47,.4);
}
.split__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.split:hover .split__media img{transform:scale(1.05)}
.split__media .frame{
  position:absolute;inset:1rem;border:1px solid rgba(255,255,255,.25);border-radius:10px;pointer-events:none;
}
.split__media .tag{
  position:absolute;bottom:1.4rem;left:1.4rem;
  background:rgba(10,25,47,.85);
  backdrop-filter:blur(10px);
  color:var(--white);padding:.7rem 1.1rem;border-radius:8px;
  font-family:var(--font-display);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid rgba(212,175,55,.4);
}

/* ---------- STATS ---------- */
.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;
  padding:3rem;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:var(--white);position:relative;overflow:hidden;
}
.stats::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;opacity:.6;
}
.stat-item{position:relative;z-index:1}
.stat-item .n{font-family:var(--font-display);font-size:3rem;font-weight:800;color:var(--gold);line-height:1}
.stat-item .l{font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--slate-300);margin-top:.5rem}

/* ---------- CTA BANNER ---------- */
.cta-banner{
  background:linear-gradient(120deg,var(--navy-900) 0%,var(--navy-700) 100%);
  padding:clamp(3rem,6vw,5rem);
  border-radius:var(--radius);
  position:relative;overflow:hidden;
  color:var(--white);
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center;
}
.cta-banner::before{
  content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;
  background:radial-gradient(closest-side,rgba(212,175,55,.25),transparent 70%);
  filter:blur(50px);
}
.cta-banner h2{color:var(--white);margin-bottom:.4em}
.cta-banner p{color:var(--slate-300);margin-bottom:0}
.cta-banner .actions{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;position:relative;z-index:1}

/* ---------- TIMELINE ---------- */
.timeline{position:relative;padding:1rem 0 1rem 2.5rem}
.timeline::before{
  content:"";position:absolute;left:.7rem;top:1rem;bottom:1rem;width:2px;
  background:linear-gradient(180deg,var(--gold) 0%,transparent 100%);
}
.t-item{position:relative;padding:0 0 2.5rem 1.4rem}
.t-item::before{
  content:"";position:absolute;left:-2.1rem;top:.3rem;width:14px;height:14px;border-radius:50%;
  background:var(--navy-900);border:3px solid var(--gold);
}
.t-item h3{color:var(--white);font-size:1.2rem;margin-bottom:.3rem}
.t-item .year{font-family:var(--font-display);color:var(--gold);font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;display:block;margin-bottom:.4rem}

/* ---------- WHY-CHOOSE LIST ---------- */
.why-list{display:grid;gap:1rem}
.why-item{
  display:flex;gap:1.2rem;align-items:flex-start;
  padding:1.4rem 1.6rem;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  transition:all .35s var(--ease);
}
.why-item:hover{background:rgba(212,175,55,.06);border-color:rgba(212,175,55,.3);transform:translateX(6px)}
.why-item .tick{
  flex-shrink:0;width:38px;height:38px;border-radius:50%;
  background:var(--gold);color:var(--navy-900);
  display:grid;place-items:center;
}
.why-item h4{font-family:var(--font-display);font-size:1.05rem;margin:0 0 .3rem;color:var(--white)}
.why-item p{margin:0;font-size:.92rem;color:var(--slate-300)}

/* ---------- INDUSTRY PILL CLOUD ---------- */
.industry-cloud{display:flex;flex-wrap:wrap;gap:.75rem}
.industry-pill{
  padding:.7rem 1.2rem;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  color:var(--slate-200);font-size:.88rem;font-weight:500;
  transition:all .35s var(--ease);
}
.industry-pill:hover{background:var(--gold);color:var(--navy-900);border-color:var(--gold);transform:translateY(-3px)}

/* ---------- PROJECTS ---------- */
.filter-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem}
.filter-chip{
  padding:.6rem 1.2rem;border-radius:999px;
  background:transparent;border:1px solid var(--slate-300);color:var(--navy-900);
  font-family:var(--font-display);font-weight:600;font-size:.85rem;
  transition:all .3s var(--ease);
}
.filter-chip:hover{border-color:var(--navy-900)}
.filter-chip.active{background:var(--navy-900);color:var(--white);border-color:var(--navy-900)}

.projects-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;
}
.project-card{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  cursor:pointer;
}
.project-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.project-card:hover img{transform:scale(1.08)}
.project-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(10,25,47,.95) 0%,rgba(10,25,47,.2) 50%,transparent 100%);
  padding:1.6rem;display:flex;flex-direction:column;justify-content:flex-end;
  color:var(--white);
}
.project-card .cat{
  font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem;
  font-family:var(--font-display);font-weight:700;
}
.project-card h3{color:var(--white);font-size:1.25rem;margin:0 0 .3rem}
.project-card .loc{font-size:.85rem;color:var(--slate-300)}
.project-card .arrow-btn{
  position:absolute;top:1.2rem;right:1.2rem;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.1);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);
  display:grid;place-items:center;color:var(--white);
  transition:all .3s var(--ease);
}
.project-card:hover .arrow-btn{background:var(--gold);border-color:var(--gold);color:var(--navy-900)}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.contact-info{display:grid;gap:1.2rem}
.info-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-sm);padding:1.4rem;
  display:flex;gap:1rem;align-items:flex-start;
  transition:all .35s var(--ease);
}
.info-card:hover{border-color:rgba(212,175,55,.4);background:rgba(212,175,55,.04)}
.info-card .ico{
  flex-shrink:0;width:44px;height:44px;border-radius:10px;
  background:rgba(212,175,55,.12);color:var(--gold);
  display:grid;place-items:center;
}
.info-card h4{color:var(--white);margin:0 0 .3rem;font-size:1rem}
.info-card p{margin:0;color:var(--slate-300);font-size:.92rem}
.info-card a{color:var(--slate-300)}
.info-card a:hover{color:var(--gold)}

.form-card{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);
  padding:2.5rem;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{
  font-family:var(--font-display);font-weight:600;font-size:.78rem;
  letter-spacing:.15em;text-transform:uppercase;color:var(--slate-300);
}
.field input,.field select,.field textarea{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-sm);
  padding:.95rem 1rem;color:var(--white);font-family:inherit;font-size:.95rem;
  transition:all .3s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(203,213,225,.45)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);background:rgba(212,175,55,.04);
}
.field textarea{min-height:130px;resize:vertical;font-family:inherit}

.map-wrap{
  border-radius:var(--radius);overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  filter:grayscale(.4) contrast(1.1);
}
.map-wrap iframe{width:100%;height:380px;border:0;display:block}

/* ---------- FOOTER ---------- */
.footer{
  background:#06101F;color:var(--slate-300);
  padding:5rem 0 2rem;
  border-top:1px solid rgba(255,255,255,.05);
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:3rem;margin-bottom:3rem}
.footer h4{color:var(--white);font-size:.95rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer ul a{color:var(--slate-300);font-size:.92rem;transition:color .3s var(--ease)}
.footer ul a:hover{color:var(--gold)}
.footer__brand p{font-size:.92rem;max-width:300px}
.footer__social{display:flex;gap:.6rem;margin-top:1rem}
.footer__social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,.1);
  display:grid;place-items:center;
  transition:all .3s var(--ease);
}
.footer__social a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy-900);transform:translateY(-3px)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.85rem;color:var(--slate-300);
}

/* ---------- PAGE BANNER (sub-pages) ---------- */
.page-banner{
  position:relative;background:var(--navy-900);color:var(--white);
  padding:11rem 0 5rem;overflow:hidden;
}
.page-banner::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(circle at 70% 50%,#000 0%,transparent 70%);
}
.page-banner::after{
  content:"";position:absolute;top:0;right:-10%;width:50%;height:100%;
  background:radial-gradient(circle,rgba(212,175,55,.15),transparent 60%);
  filter:blur(60px);
}
.page-banner__inner{position:relative;z-index:1;max-width:760px}
.page-banner h1{color:var(--white);margin-bottom:1rem}
.page-banner p{color:var(--slate-300);font-size:1.15rem}
.breadcrumbs{
  font-family:var(--font-display);font-size:.78rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;
}
.breadcrumbs a{color:var(--slate-300)}
.breadcrumbs a:hover{color:var(--gold)}

/* ---------- ANIMATION UTILITIES ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.55s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.65s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.75s}

/* ---------- RESPONSIVE ---------- */
@media (max-width:960px){
  .hero__inner{grid-template-columns:1fr;gap:3rem}
  .hero__visual{max-width:480px;margin-inline:auto;width:100%}
  .split{grid-template-columns:1fr;gap:3rem}
  .split.reverse{direction:ltr}
  .cta-banner{grid-template-columns:1fr;text-align:left}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .nav__toggle{display:grid;place-items:center}
  .nav__links{
    position:absolute;top:calc(100% + .8rem);left:0;right:0;
    background:rgba(10,25,47,.96);backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,.08);border-radius:18px;
    flex-direction:column;align-items:stretch;gap:.2rem;padding:1rem;
    transform:translateY(-10px);opacity:0;pointer-events:none;
    transition:all .35s var(--ease);
  }
  .nav__links a{padding:.9rem 1.1rem;border-radius:10px;font-size:.95rem}
  .nav.open .nav__links{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav__cta{display:none}
  .form-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .nav{padding:.55rem .8rem .55rem 1rem}
  .nav__brand small{display:none}
  .stats{padding:2rem 1.5rem}
}

/* ---------- ACCESSIBILITY ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal,.reveal-stagger > *{opacity:1!important;transform:none!important}
}
