/* ========== Reset & Tokens ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Brand palette */
  --navy:#1B2D6B;          /* Primary — Deep Navy */
  --navy-dark:#15235A;
  --navy-darker:#0E1B4D;
  --navy-deepest:#08123B;
  --blue:#5879A6;          /* Secondary — Refined Slate Blue */
  --blue-soft:#A8BBD3;      /* Softer wash */
  --green:#4D8B22;         /* Accent — Growth Green */
  --orange:#E8621A;        /* Warm accent — Ember Orange */
  /* Neutrals */
  --white:#FFFFFF;
  --cloud:#F5F7FA;         /* Cloud White */
  --bone:#FAFAF7;          /* Editorial off-white */
  --gray:#9EA8B8;          /* Steel Gray */
  --gray-soft:#D5DBE3;
  --gray-line:#E5E8ED;
  --ink:#1B2D6B;
  --ink-soft:#3A455A;
  --ink-mute:#5B6578;
  /* Effects */
  --shadow-xs:0 1px 2px rgba(27,45,107,.04);
  --shadow-sm:0 2px 8px rgba(27,45,107,.06);
  --shadow-md:0 10px 28px rgba(27,45,107,.09);
  --shadow-lg:0 22px 50px rgba(27,45,107,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
  --radius:8px;
  --radius-md:12px;
  --radius-lg:16px;
  --maxw:1320px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Poppins',system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--white);
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;color:var(--navy);letter-spacing:-.015em;line-height:1.18}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ========== Buttons (glossy / glassmorphism) ========== */
.btn{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 32px;border-radius:var(--radius);
  font-weight:500;font-size:.94rem;letter-spacing:.012em;
  cursor:pointer;white-space:nowrap;
  transition:transform .4s var(--ease),
             background .4s var(--ease),
             border-color .4s var(--ease),
             box-shadow .4s var(--ease),
             color .4s var(--ease);
  overflow:hidden;
  isolation:isolate;
}
/* Subtle gloss highlight that slides across on hover */
.btn::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(110deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.22) 45%,
    rgba(255,255,255,0) 90%);
  transform:translateX(-110%);
  transition:transform .9s var(--ease);
  pointer-events:none;
  z-index:1;
}
.btn:hover::before{transform:translateX(110%)}
.btn > *{position:relative;z-index:2}

/* Glass-blue — for dark or image backgrounds (hero CTA) */
.btn-light{
  background:linear-gradient(135deg, rgba(76,130,210,.42) 0%, rgba(43,91,168,.48) 55%, rgba(27,45,107,.42) 100%);
  color:#fff;
  border:1px solid rgba(180,210,255,.4);
  backdrop-filter:blur(14px) saturate(180%);
  -webkit-backdrop-filter:blur(14px) saturate(180%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -1px 0 rgba(0,0,0,.08),
    0 10px 28px rgba(43,91,168,.32),
    0 0 22px rgba(76,130,210,.22);
}
.btn-light:hover{
  background:linear-gradient(135deg, rgba(95,150,225,.55) 0%, rgba(60,108,188,.62) 55%, rgba(43,91,168,.55) 100%);
  border-color:rgba(200,225,255,.6);
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    0 16px 38px rgba(43,91,168,.5),
    0 0 36px rgba(95,150,225,.45);
}

/* Glossy navy — for light backgrounds */
.btn-primary{
  background:linear-gradient(180deg, var(--blue) 0%, var(--navy) 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 8px 22px rgba(14,27,77,.28);
}
.btn-primary:hover{
  background:linear-gradient(180deg, var(--navy) 0%, var(--navy-dark) 100%);
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.3),
    0 14px 30px rgba(14,27,77,.36);
}

/* ========== Top Utility Bar ========== */
.topbar{
  position:sticky;top:0;z-index:101;
  background:var(--navy-deepest);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.topbar-row{
  display:flex;align-items:center;justify-content:space-between;
  min-height:40px;
  padding:8px 0;
  gap:18px;
}
.topbar-tag{
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#fff;
  font-weight:500;
}
.topbar-right{display:flex;align-items:center;gap:20px}
.topbar-link{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.95rem;
  letter-spacing:.01em;
  color:#fff;
  transition:opacity .25s var(--ease);
}
.topbar-link i{font-size:1.05rem;color:#fff;transition:opacity .25s var(--ease)}
.topbar-link:hover{opacity:.8}
.topbar-link:hover i{opacity:.8}
.topbar-sep{
  width:1px;height:16px;background:rgba(255,255,255,.28);
}
@media (max-width:780px){
  .topbar-tag{display:none}
  .topbar-row{justify-content:center;gap:14px}
}
@media (max-width:520px){
  .topbar-link.email{display:none}
  .topbar-sep{display:none}
}

/* ========== Header (glass white — AIA-style) ========== */
.header{
  position:sticky;top:40px;z-index:100;
  background:rgba(255,255,255,.50);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 4px 24px rgba(0,0,0,.05);
  transition:background .4s ease, box-shadow .4s ease, border-color .4s ease;
}
.header.scrolled{
  background:rgba(255,255,255,.65);
  box-shadow:0 10px 36px rgba(0,0,0,.10);
  border-bottom-color:rgba(0,0,0,.10);
}
.header-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;gap:24px;
}
.brand{display:inline-flex;align-items:center;flex-shrink:0}
.brand img{
  height:92px;width:auto;
  transition:height .4s ease, transform .4s ease;
}
.brand:hover img{transform:scale(1.03)}
.header.scrolled .brand img{height:76px}

.nav{display:flex;align-items:center;gap:6px;flex:1;justify-content:flex-end}
.nav a{
  position:relative;padding:8px 16px;
  font-size:.95rem;font-weight:500;color:var(--navy);
  letter-spacing:.01em;
  transition:color .35s ease, transform .35s ease;
}
.nav a:hover,.nav a.active{color:var(--blue);transform:translateY(-2px)}
.nav a::after{
  content:"";position:absolute;left:16px;right:16px;bottom:-2px;height:1.5px;
  background:var(--blue);
  transform:scaleX(0);transform-origin:right;
  transition:transform .4s cubic-bezier(.7,0,.3,1);
}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:left}

.menu-toggle{
  display:none;width:44px;height:44px;border-radius:8px;
  background:var(--navy);color:#fff;
  align-items:center;justify-content:center;font-size:1.3rem;
  transition:background .25s var(--ease);
}
.menu-toggle:hover{background:var(--navy-dark)}

@media (max-width:1080px){
  .nav{display:none}
  .menu-toggle{display:inline-flex}
}
@media (max-width:560px){
  .brand img{height:68px}
  .header.scrolled .brand img{height:58px}
}

/* ========== Mobile Modal (glassmorphic, fade + scale) ========== */
.drawer{
  position:fixed;inset:0;z-index:200;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(22px) saturate(170%);
  -webkit-backdrop-filter:blur(22px) saturate(170%);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity .45s var(--ease), backdrop-filter .45s var(--ease);
}
.drawer.open{opacity:1;pointer-events:auto}

.drawer-panel{
  position:relative;
  width:min(560px,92vw);
  max-height:88vh;
  background:transparent;
  border:0;
  box-shadow:none;
  padding:64px 36px 52px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;
  text-align:center;
  overflow-y:auto;
  transform:scale(.95);
  opacity:0;
  transition:transform .55s var(--ease), opacity .5s var(--ease);
}
.drawer.open .drawer-panel{transform:scale(1);opacity:1}

.drawer-close{
  position:absolute;top:16px;right:16px;
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;font-size:1.4rem;
  color:var(--navy);
  background:rgba(255,255,255,.45);
  border:1px solid rgba(27,45,107,.08);
  transition:background .3s var(--ease), transform .35s var(--ease);
}
.drawer-close:hover{background:rgba(255,255,255,.85);transform:rotate(90deg)}

.drawer > .drawer-panel > a{
  width:100%;
  padding:14px 8px;
  font-size:1.18rem;
  font-weight:500;
  letter-spacing:.005em;
  color:var(--navy);
  border:0;
  text-align:center;
  transition:color .3s var(--ease), transform .3s var(--ease);
}
.drawer > .drawer-panel > a:hover{color:var(--blue);transform:translateY(-2px)}

.drawer-contact{
  margin-top:30px;padding-top:26px;
  border-top:1px solid rgba(27,45,107,.10);
  width:100%;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.drawer-contact a{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:4px 0;border:0;font-size:.98rem;
  color:var(--ink-soft);
  text-align:center;
}
.drawer-contact a i{color:var(--navy);font-size:1.15rem}
.drawer-contact a:hover{color:var(--navy)}

/* ========== Hero ========== */
.hero{
  position:relative;
  background:var(--navy-darker);
  padding:140px 0 148px;
  min-height:620px;
  overflow:hidden;
  isolation:isolate;
  color:#fff;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:url('assets/img/hero-building.jpg') center center / cover no-repeat;
  transform:scale(1.05);
  /* Editorial B&W treatment */
  filter:grayscale(100%) contrast(1.05) brightness(.95);
  animation:heroZoom 20s ease-out forwards;
}
@keyframes heroZoom{to{transform:scale(1)}}
/* Darker, blur-free overlay for strong text contrast */
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 50% 55%, rgba(0,0,0,.30) 0%, rgba(0,0,0,.52) 100%),
    linear-gradient(180deg, rgba(8,18,59,.32) 0%, rgba(8,18,59,.42) 100%);
}
/* Thin top accent (kept) */
.hero-ribbon{
  position:absolute;top:0;left:0;right:0;height:3px;z-index:3;
  background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 38%,var(--green) 72%,var(--orange) 100%);
  opacity:.85;
}
.hero-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  max-width:880px;margin:0 auto;
}
.hero-eyebrow{
  font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.82);font-weight:500;
  margin-bottom:24px;
  animation:fadeUp 1.1s var(--ease) .1s both;
}
.hero-title{
  font-size:clamp(2.2rem,4.6vw,3.7rem);
  font-weight:600;color:#fff;
  letter-spacing:-.022em;line-height:1.12;
  max-width:780px;margin-bottom:24px;
  animation:fadeUp 1.1s var(--ease) .25s both;
}
.hero-subtitle{
  font-size:clamp(1rem,1.45vw,1.18rem);
  color:rgba(255,255,255,.92);font-weight:300;
  max-width:620px;line-height:1.7;
  animation:fadeUp 1.1s var(--ease) .4s both;
}

@media (max-width:760px){
  .hero{padding:96px 0 104px;min-height:480px}
  .hero-eyebrow{font-size:.7rem;letter-spacing:.2em;margin-bottom:18px}
}

/* ========== Our Approach Section ========== */
.ethos{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:48px 0 60px;
}
.ethos-head{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:780px;
  margin:0 auto 28px;
  gap:0;
}
.ethos-eyebrow{
  font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gray);font-weight:500;
  margin:0;
}
.ethos-divider{
  display:block;width:48px;height:1px;
  background:linear-gradient(90deg,
    rgba(27,45,107,0) 0%,
    rgba(27,45,107,.35) 50%,
    rgba(27,45,107,0) 100%);
}

@media (max-width:760px){
  .ethos{padding:40px 0 48px}
  .ethos-head{margin-bottom:22px}
}

/* ========== Icon Carousel ========== */
.carousel{position:relative}
.carousel-viewport{overflow:hidden}
.carousel-track{display:flex;will-change:transform}
.slide{
  flex:0 0 auto;
  padding:0 12px;
  display:flex;align-items:stretch;
}

.icon-card{
  width:100%;
  background:#fff;
  border:1px solid rgba(27,45,107,.06);
  border-radius:var(--radius-md);
  padding:30px 26px 28px;
  min-height:200px;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  transition:transform .5s var(--ease),
             box-shadow .5s var(--ease),
             border-color .5s var(--ease);
}
.icon-card:hover{
  transform:translateY(-5px);
  border-color:transparent;
  box-shadow:0 18px 40px rgba(27,45,107,.14);
}
.ic-icon{
  width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(180deg, rgba(43,91,168,.08) 0%, rgba(27,45,107,.04) 100%);
  border:1px solid rgba(27,45,107,.12);
  color:var(--navy);
  font-size:1.25rem;
  margin-bottom:20px;
  transition:background .4s var(--ease),
             border-color .4s var(--ease),
             color .4s var(--ease);
}
.icon-card:hover .ic-icon{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.icon-card h4{
  font-size:1rem;font-weight:600;color:var(--navy);
  letter-spacing:-.005em;
  margin-bottom:8px;
}
.icon-card p{
  font-size:.88rem;color:var(--ink-mute);
  font-weight:400;line-height:1.6;
}

.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:46px;height:46px;border-radius:50%;
  background:#fff;color:var(--navy);
  display:grid;place-items:center;
  font-size:1.05rem;
  border:1px solid var(--gray-line);
  box-shadow:var(--shadow-sm);
  transition:all .3s var(--ease);
  z-index:5;
}
.carousel-arrow:hover{
  background:var(--navy);color:#fff;border-color:var(--navy);
  transform:translateY(-50%) scale(1.06);
  box-shadow:var(--shadow-md);
}
.carousel-arrow.prev{left:-22px}
.carousel-arrow.next{right:-22px}

@media (max-width:1080px){
  .carousel-arrow.prev{left:-4px}
  .carousel-arrow.next{right:-4px}
}
@media (max-width:760px){
  .carousel-arrow{width:40px;height:40px;font-size:.95rem}
  .icon-card{min-height:180px;padding:26px 22px 24px}
}

/* ========== Services — outcome-focused grid ========== */
.services-section{
  background:var(--navy);
  padding:104px 0 112px;
  color:#fff;
  position:relative;
  isolation:isolate;
}
.services-section::before{
  content:"";
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(43,91,168,.18) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(8,18,59,.45) 0%, transparent 55%);
  pointer-events:none;
}
.services-head{
  text-align:center;
  max-width:680px;margin:0 auto 64px;
}
.services-eyebrow{
  font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.6);font-weight:500;
  margin-bottom:16px;
}
.services-head h2{
  color:#fff;
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  font-weight:500;letter-spacing:-.018em;line-height:1.2;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.service-card{
  position:relative;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .55s var(--ease),
             border-color .55s var(--ease),
             background .55s var(--ease);
}
.service-card:hover{
  transform:translateY(-5px);
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.2);
}
.service-img{
  position:relative;
  aspect-ratio:16 / 10;
  overflow:hidden;
}
.service-img img{
  width:100%;height:100%;object-fit:cover;
  /* Default: editorial B&W */
  filter:grayscale(100%) contrast(1.04) brightness(.92);
  transform:scale(1);
  transition:filter .45s ease, transform .55s ease;
}
.service-card:hover .service-img img{
  /* Hover: full colour + subtle zoom-in */
  filter:grayscale(0%) contrast(1.02) brightness(1);
  transform:scale(1.07);
}
.service-img::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,27,77,0) 55%,rgba(14,27,77,.5) 100%);
  pointer-events:none;
  transition:opacity .45s ease;
}
.service-card:hover .service-img::after{opacity:.35}
.service-body{
  padding:32px 30px 36px;
  flex:1;
  display:flex;flex-direction:column;align-items:flex-start;
}
.service-icon{
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.22);
  color:#fff;font-size:1.2rem;
  margin-bottom:18px;
  transition:border-color .4s var(--ease),background .4s var(--ease);
}
.service-card:hover .service-icon{
  border-color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.06);
}
.service-body h3{
  color:#fff;font-size:1.28rem;font-weight:500;
  letter-spacing:-.005em;margin-bottom:10px;
}
.service-body p{
  color:rgba(255,255,255,.74);
  font-size:.94rem;font-weight:300;line-height:1.7;
}

@media (max-width:980px){
  .services-section{padding:80px 0 88px}
  .services-grid{grid-template-columns:1fr;gap:18px;max-width:520px;margin:0 auto}
  .service-img{aspect-ratio:16 / 9}
  .service-body{padding:26px 24px 28px}
}

/* ========== Footer ========== */
.footer{
  background:var(--navy-deepest);
  padding:52px 0 30px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-inner{
  display:flex;flex-direction:column;align-items:center;gap:30px;
}
.footer-reg{text-align:center}
.footer-reg-label{
  font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:500;
  margin-bottom:14px;
}
.footer-reg-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:8px 28px;
}
.footer-reg-list a{
  font-size:.86rem;
  color:rgba(255,255,255,.78);
  letter-spacing:.01em;
  transition:color .25s var(--ease);
}
.footer-reg-list a:hover{color:#fff}
.footer-copy{
  font-size:.84rem;
  font-weight:400;
  color:rgba(255,255,255,.55);
  letter-spacing:.02em;
  margin:0;
  text-align:center;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px;
  width:100%;
  max-width:560px;
}

@media (max-width:560px){
  .footer{padding:40px 0 26px}
  .footer-inner{gap:24px}
  .footer-reg-list{gap:6px 18px;font-size:.82rem}
  .footer-copy{font-size:.8rem;line-height:1.5}
}

/* ========== Nav disabled / Coming-soon badge ========== */
.nav .nav-disabled{
  cursor:default;
  color:var(--ink-mute);
  display:inline-flex;align-items:center;gap:9px;
}
.nav .nav-disabled:hover{color:var(--ink-mute);transform:none}
.nav .nav-disabled:hover::after{transform:scaleX(0)}
.badge-soon{
  display:inline-block;
  font-size:.6rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  padding:3px 8px 2px;
  border-radius:999px;
  color:var(--navy);
  background:rgba(27,45,107,.08);
  border:1px solid rgba(27,45,107,.16);
  line-height:1;
}
.drawer-panel .nav-disabled{
  pointer-events:none;
  color:var(--ink-mute);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.drawer-panel .nav-disabled:hover{color:var(--ink-mute);transform:none}

/* ========== Page Hero / Breadcrumb (sub-page banner with image) ========== */
.page-hero{
  position:relative;
  padding:88px 0 76px;
  text-align:center;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.page-hero-bg{
  position:absolute;inset:0;z-index:0;
  background:url('assets/img/breadcrumb-bg.jpg') center center / cover no-repeat;
  transform:scale(1.04);
  /* Editorial B&W treatment — matches the rest of the site */
  filter:grayscale(100%) contrast(1.04) brightness(.95);
  animation:heroZoom 20s ease-out forwards;
}
.page-hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(0,0,0,.32) 0%, rgba(0,0,0,.55) 100%),
    linear-gradient(180deg, rgba(8,18,59,.42) 0%, rgba(8,18,59,.52) 100%);
}
.page-hero-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
}
.breadcrumb{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.78);font-weight:500;
  margin-bottom:24px;
}
.breadcrumb a{
  color:rgba(255,255,255,.7);
  transition:color .25s var(--ease);
}
.breadcrumb a:hover{color:#fff}
.breadcrumb-sep{
  color:rgba(255,255,255,.42);
  font-weight:300;
  font-size:.85rem;
  letter-spacing:0;
}
.breadcrumb [aria-current="page"]{color:#fff}
.page-hero h1{
  font-size:clamp(1.35rem,2.6vw,1.95rem);
  font-weight:600;
  letter-spacing:-.018em;line-height:1.2;
  color:#fff;
  max-width:980px;
  margin:0 auto 22px;
}
/* Keep title on a single line from tablet upwards */
@media (min-width:768px){
  .page-hero h1{white-space:nowrap}
}
.page-hero-divider{
  display:block;width:48px;height:1px;
  background:linear-gradient(90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.55) 50%,
    rgba(255,255,255,0) 100%);
}

@media (max-width:760px){
  .page-hero{padding:84px 0 72px}
  .breadcrumb{font-size:.66rem;letter-spacing:.2em;margin-bottom:18px}
}

/* ========== Reusable section head ========== */
.section-head{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:780px;margin:0 auto 56px;
  gap:14px;
}
.section-head .ethos-eyebrow{color:var(--gray);margin:0}
.section-head h2{
  font-size:clamp(1.6rem,2.8vw,2.3rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.2;
  color:var(--navy);
  margin:0;
}

@media (max-width:760px){
  .section-head{margin-bottom:40px;gap:12px}
}

/* ========== About — Our Story (two-column: image | text) ========== */
.about-story{
  background:#fff;
  padding:104px 0 100px;
}
.about-story-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
}
.about-story-img{
  position:relative;
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:0 20px 50px rgba(27,45,107,.14);
  background:#EEF2F8;
  align-self:start;
}
.about-story-img img{
  width:100%;
  height:auto;
  display:block;
}
.about-story-text .ethos-eyebrow{color:var(--gray);margin:0}
.about-story-text h2{
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.22;
  margin:14px 0 24px;
  color:var(--navy);
}
.about-story-text p{
  font-size:1rem;
  line-height:1.78;
  color:var(--ink-soft);
  font-weight:300;
  margin-bottom:18px;
}
.story-services-list{
  list-style:none;padding:0;
  margin:24px 0 0;
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px 28px;
}
.story-services-list li{
  font-size:.96rem;
  color:var(--ink-soft);
  display:flex;align-items:center;gap:12px;
  font-weight:400;
}
.story-services-list li::before{
  content:"";
  width:5px;height:5px;border-radius:50%;
  background:var(--navy);
  flex-shrink:0;
}

@media (max-width:920px){
  .about-story-grid{grid-template-columns:1fr;gap:36px;max-width:680px}
  /* Center the natural-ratio image in the single-column mobile layout */
  .about-story-img{
    max-width:560px;
    margin:0 auto;
  }
}
@media (max-width:760px){
  .about-story{padding:72px 0 80px}
  .story-services-list{grid-template-columns:1fr;gap:8px}
}

/* ========== About — Team grid ========== */
.team-section{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:96px 0 104px;
}
.team-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  max-width:1200px;
  margin:0 auto;
}
.team-card{
  background:#fff;
  border:1px solid rgba(27,45,107,.06);
  border-radius:var(--radius-md);
  overflow:hidden;
  text-align:center;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.team-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 44px rgba(27,45,107,.16);
}
/* Real photo treatment — taller frame, top-aligned to keep foreheads visible */
.team-photo{
  aspect-ratio:3/4;
  background:#EEF2F8;
  overflow:hidden;
  position:relative;
}
.team-photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  filter:grayscale(100%) contrast(1.02) brightness(.97);
  transform:scale(1);
  transition:filter .55s ease, transform .65s ease;
}
.team-card:hover .team-photo img{
  filter:grayscale(0%) contrast(1) brightness(1);
  transform:scale(1.04);
}
.team-photo::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 78%, rgba(14,27,77,.10) 100%);
  pointer-events:none;
}
.team-body{padding:22px 20px 26px}
.team-name{
  font-size:1.05rem;font-weight:600;
  color:var(--navy);
  letter-spacing:-.005em;
  margin-bottom:6px;
}
.team-creds{
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gray);
  font-weight:500;
  margin-bottom:8px;
  min-height:.85rem;
}
.team-role{
  font-size:.9rem;
  color:var(--ink-soft);
  line-height:1.5;
  font-weight:400;
}

@media (max-width:1080px){
  .team-grid{grid-template-columns:repeat(2,1fr);gap:20px;max-width:680px}
}
@media (max-width:560px){
  .team-section{padding:72px 0 80px}
  .team-grid{grid-template-columns:1fr;max-width:360px;gap:18px}
}

/* ========== About — Services brief ========== */
.services-brief{
  background:#fff;
  padding:80px 0;
  border-top:1px solid var(--gray-line);
  text-align:center;
}
.services-brief-inner{
  max-width:680px;
  margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.services-brief-inner .ethos-eyebrow{color:var(--gray);margin:0}
.services-brief-inner h2{
  font-size:clamp(1.5rem,2.4vw,2rem);
  font-weight:500;
  letter-spacing:-.015em;
  margin:0;
}
.services-brief-list{
  font-size:1rem;
  color:var(--ink-soft);
  letter-spacing:.04em;
  margin-top:6px;
}
.services-brief-link{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:18px;
  font-size:.9rem;font-weight:500;
  letter-spacing:.04em;
  color:var(--navy);
  padding:6px 4px;
  transition:color .25s var(--ease), gap .3s var(--ease);
}
.services-brief-link i{font-size:1rem;transition:transform .3s var(--ease)}
.services-brief-link:hover{color:var(--blue);gap:12px}
.services-brief-link:hover i{transform:translateX(2px)}

@media (max-width:560px){
  .services-brief{padding:60px 0}
  .services-brief-list{font-size:.92rem;letter-spacing:.02em}
}

/* ========== Services Page — Intro ========== */
.services-intro{
  background:#fff;
  padding:96px 0 72px;
  text-align:center;
}
.services-intro-inner{
  max-width:760px;
  margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.services-intro-inner .ethos-eyebrow{color:var(--gray);margin:0}
.services-intro-inner h2{
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.22;
  margin:0;
}
.services-intro-lede{
  font-size:1.04rem;
  line-height:1.78;
  color:var(--ink-soft);
  font-weight:300;
  max-width:640px;
  margin-top:6px;
}
@media (max-width:760px){
  .services-intro{padding:72px 0 56px}
}

/* Sub-services list inside service cards (Services page only) */
.service-list{
  list-style:none;padding:0;
  margin:18px 0 0;
  display:flex;flex-direction:column;gap:8px;
}
.service-list li{
  font-size:.88rem;
  color:rgba(255,255,255,.72);
  font-weight:300;
  display:flex;align-items:center;gap:10px;
  letter-spacing:.005em;
}
.service-list li::before{
  content:"";
  width:5px;height:1px;
  background:rgba(255,255,255,.5);
  flex-shrink:0;
}

/* ========== Services Page — Detail grid (light blue bg, 4 cards) ========== */
.services-detail{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:88px 0 100px;
}
.services-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:30px;
  max-width:1100px;
  margin:0 auto;
}
.svc-card{
  background:#fff;
  border:1px solid rgba(27,45,107,.06);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.svc-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 44px rgba(27,45,107,.16);
}
.svc-img{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
}
.svc-img img{
  width:100%;height:100%;
  object-fit:cover;
  filter:grayscale(100%) contrast(1.04) brightness(.92);
  transform:scale(1);
  transition:filter .5s ease, transform .6s ease;
}
.svc-card:hover .svc-img img{
  filter:grayscale(0%) contrast(1) brightness(1);
  transform:scale(1.06);
}
.svc-body{
  padding:28px 28px 30px;
  flex:1;
  display:flex;flex-direction:column;align-items:flex-start;
  gap:10px;
}
.svc-icon{
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(88,121,166,.10);
  border:1px solid rgba(88,121,166,.22);
  color:var(--navy);
  font-size:1.2rem;
  margin-bottom:6px;
}
.svc-body h3{
  font-size:1.22rem;font-weight:500;
  color:var(--navy);
  letter-spacing:-.005em;
  margin:0;
}
.svc-body p{
  font-size:.94rem;
  line-height:1.65;
  color:var(--ink-soft);
  font-weight:300;
  flex:1;
}
.svc-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;
  font-size:.78rem;font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--navy);
  padding:11px 22px;
  border:1px solid rgba(27,45,107,.22);
  border-radius:var(--radius);
  background:#fff;
  transition:color .3s var(--ease),
             background .3s var(--ease),
             border-color .3s var(--ease),
             transform .3s var(--ease),
             box-shadow .3s var(--ease);
}
.svc-cta i{font-size:1rem;transition:transform .3s var(--ease)}
.svc-cta:hover{
  color:#fff;
  background:var(--navy);
  border-color:var(--navy);
  transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(14,27,77,.22);
}
.svc-cta:hover i{transform:translateX(3px)}

@media (max-width:920px){
  .services-detail{padding:64px 0 80px}
  .services-detail-grid{grid-template-columns:1fr;gap:22px;max-width:560px}
}

/* ========== Contact — General (two-column: enquiries + address) ========== */
.contact-general-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  max-width:1000px;
  margin:0 auto;
  align-items:start;
}
.contact-general-block{
  display:flex;flex-direction:column;align-items:flex-start;
  text-align:left;
  gap:6px;
}
.contact-general-block .ethos-eyebrow{color:var(--gray);margin:0 0 8px}
.contact-general-block h3{
  font-size:1.4rem;font-weight:500;
  color:var(--navy);
  letter-spacing:-.018em;
  line-height:1.2;
  margin:0 0 16px;
}
.contact-general-block .contact-action{
  display:inline-flex;align-items:center;gap:10px;
  padding:5px 0;
  font-size:.98rem;color:var(--navy);
  font-weight:500;
  transition:color .25s var(--ease), transform .3s var(--ease);
}
.contact-general-block .contact-action i{color:var(--blue);font-size:1.15rem}
.contact-general-block .contact-action:hover{color:var(--blue);transform:translateX(2px)}
.contact-general-block .contact-address{
  font-size:.98rem;
  color:var(--ink-soft);
  line-height:1.8;
  font-weight:400;
  margin-top:0;
}
.contact-general-block .contact-postal{
  font-size:.9rem;
  color:var(--gray);
  line-height:1.7;
  margin-top:10px;
}

@media (max-width:760px){
  .contact-general-grid{grid-template-columns:1fr;gap:36px}
  .contact-general{padding:64px 0 56px}
}

/* ========== Contact — Team + Inquiry form ========== */
.contact-team-form{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:96px 0 56px;
}
.contact-team-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:start;
  max-width:1200px;
  margin:0 auto;
}
.contact-team-side .ethos-eyebrow,
.contact-form-side .ethos-eyebrow{color:var(--gray);margin:0 0 12px}
.contact-team-side h2,
.contact-form-side h2{
  font-size:clamp(1.5rem,2.4vw,2rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.22;
  margin:0 0 28px;
  color:var(--navy);
}
.contact-team-side .contact-list{
  max-width:none;
  margin:0;
}
.contact-team-side .contact-list li{
  grid-template-columns:1fr;
  gap:8px;
  padding:20px 22px;
}
.contact-team-side .contact-name{font-size:1rem;margin-bottom:2px}

@media (max-width:920px){
  .contact-team-form-grid{grid-template-columns:1fr;gap:56px}
  .contact-team-form{padding:72px 0}
}

/* ========== Inquiry Form ========== */
.inquiry-form{
  display:flex;flex-direction:column;gap:18px;
  width:100%;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.form-field{
  display:flex;flex-direction:column;
  gap:7px;
}
.form-label{
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  padding:13px 16px;
  border:1px solid var(--gray-line);
  border-radius:var(--radius);
  background:#fff;
  font-family:inherit;
  font-size:.95rem;
  color:var(--ink);
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.form-field input::placeholder,
.form-field textarea::placeholder{color:var(--gray)}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(88,121,166,.15);
}
.form-field textarea{
  resize:vertical;
  min-height:130px;
  line-height:1.55;
}
.btn-submit{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 30px;
  font-size:.8rem;font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  background:linear-gradient(180deg, var(--blue) 0%, var(--navy) 100%);
  border:0;
  border-radius:var(--radius);
  cursor:pointer;
  margin-top:6px;
  box-shadow:0 8px 22px rgba(14,27,77,.22);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.btn-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(14,27,77,.32);
}
.btn-submit i{font-size:1rem;transition:transform .3s var(--ease)}
.btn-submit:hover i{transform:translateX(3px)}

@media (max-width:560px){
  .form-row{grid-template-columns:1fr;gap:14px}
}

/* ========== Contact — Full-width map ========== */
.location-section--full{
  padding:0;
  background:#fff;
}
.location-map-full{
  width:100%;
  height:480px;
  position:relative;
  overflow:hidden;
}
.location-map-full iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  filter:grayscale(100%) contrast(.96);
}
/* Tighter footer immediately after the full-width map */
.location-section--full + .footer{
  padding-top:32px;
}

@media (max-width:760px){
  .location-map-full{height:380px}
}

/* ========== Thank You page ========== */
.thanks-section{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  min-height:62vh;
  padding:120px 0 130px;
  display:flex;align-items:center;
}
.thanks-inner{
  max-width:640px;
  margin:0 auto;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.thanks-icon{
  width:88px;height:88px;
  border-radius:50%;
  display:grid;place-items:center;
  background:rgba(88,121,166,.10);
  border:1px solid rgba(88,121,166,.22);
  color:var(--navy);
  font-size:2.4rem;
  margin-bottom:32px;
}
.thanks-eyebrow{
  font-size:.74rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gray);
  font-weight:500;
  margin:0 0 14px;
}
.thanks-section h1{
  font-size:clamp(1.7rem,3vw,2.4rem);
  font-weight:500;
  letter-spacing:-.018em;
  line-height:1.2;
  color:var(--navy);
  margin:0 0 22px;
  max-width:560px;
}
.thanks-lede{
  font-size:1.04rem;
  line-height:1.72;
  color:var(--ink-soft);
  font-weight:300;
  max-width:500px;
  margin:0 0 36px;
}
.thanks-link{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);
  padding:14px 28px;
  border:1px solid rgba(27,45,107,.22);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  transition:color .3s var(--ease),
             background .3s var(--ease),
             border-color .3s var(--ease),
             transform .3s var(--ease),
             box-shadow .3s var(--ease);
}
.thanks-link i{font-size:1rem;transition:transform .3s var(--ease)}
.thanks-link:hover{
  color:#fff;
  background:var(--navy);
  border-color:var(--navy);
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(14,27,77,.22);
}
.thanks-link:hover i{transform:translateX(-3px)}

@media (max-width:560px){
  .thanks-section{padding:80px 0 90px}
  .thanks-icon{width:72px;height:72px;font-size:2rem;margin-bottom:24px}
  .thanks-lede{font-size:.98rem}
}

/* ========== Blog page — flexible card grid ========== */
.blog-list{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:88px 0 96px;
}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  max-width:1200px;
  margin:0 auto;
}
.blog-card{
  background:#fff;
  border:1px solid rgba(27,45,107,.06);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.blog-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 44px rgba(27,45,107,.16);
}
.blog-card-img{
  display:block;
  aspect-ratio:16/10;
  overflow:hidden;
  position:relative;
}
.blog-card-img img{
  width:100%;height:100%;
  object-fit:cover;
  filter:grayscale(100%) contrast(1.04) brightness(.92);
  transform:scale(1);
  transition:filter .5s ease, transform .6s ease;
}
.blog-card:hover .blog-card-img img{
  filter:grayscale(0%) contrast(1) brightness(1);
  transform:scale(1.05);
}
.blog-card-body{
  padding:24px 26px 26px;
  flex:1;
  display:flex;flex-direction:column;align-items:flex-start;
  gap:10px;
}
.blog-meta{
  font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--gray);font-weight:500;
  margin:0;
}
.blog-title{
  font-size:1.18rem;
  font-weight:500;
  color:var(--navy);
  letter-spacing:-.008em;
  line-height:1.32;
  margin:0;
}
.blog-title a{color:inherit;transition:color .25s var(--ease)}
.blog-title a:hover{color:var(--blue)}
.blog-excerpt{
  font-size:.92rem;
  color:var(--ink-soft);
  font-weight:300;
  line-height:1.65;
  flex:1;
}
.blog-link{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:6px;
  font-size:.76rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);
  transition:gap .3s var(--ease), color .3s var(--ease);
}
.blog-link i{font-size:.95rem;transition:transform .3s var(--ease)}
.blog-link:hover{color:var(--blue);gap:12px}
.blog-link:hover i{transform:translateX(2px)}

@media (max-width:1024px){
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media (max-width:640px){
  .blog-list{padding:64px 0 72px}
  .blog-grid{grid-template-columns:1fr;max-width:480px;gap:20px}
}

/* ========== Services Page — CTA strip ========== */
.services-cta{
  background:#fff;
  padding:88px 0 96px;
}
.services-cta-inner{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
}
.services-cta-inner .ethos-eyebrow{color:var(--gray);margin:0}
.services-cta-inner h2{
  font-size:clamp(1.6rem,2.6vw,2.2rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.22;
  margin:0;
}
.services-cta-lede{
  font-size:1.02rem;
  line-height:1.7;
  color:var(--ink-soft);
  font-weight:300;
}
.services-cta-link{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:14px;
  font-size:.95rem;font-weight:500;
  letter-spacing:.04em;
  color:var(--navy);
  padding:14px 28px;
  border:1px solid rgba(27,45,107,.18);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  transition:color .3s var(--ease),
             background .3s var(--ease),
             border-color .3s var(--ease),
             transform .3s var(--ease),
             box-shadow .3s var(--ease);
}
.services-cta-link i{font-size:1.05rem;transition:transform .3s var(--ease)}
.services-cta-link:hover{
  color:#fff;
  background:var(--navy);
  border-color:var(--navy);
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(14,27,77,.22);
}
.services-cta-link:hover i{transform:translateX(3px)}

@media (max-width:560px){
  .services-cta{padding:64px 0 72px}
}

/* ========== Contact — General ========== */
.contact-general{
  background:#fff;
  padding:96px 0 80px;
  text-align:center;
}
.contact-general-inner{
  max-width:720px;
  margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.contact-general-inner .ethos-eyebrow{color:var(--gray);margin:0}
.contact-general-lede{
  font-size:1.06rem;
  line-height:1.7;
  color:var(--ink-soft);
  font-weight:300;
  max-width:520px;
}
.contact-actions{
  margin-top:14px;
  display:inline-flex;align-items:center;gap:24px;
  flex-wrap:wrap;justify-content:center;
}
.contact-action{
  display:inline-flex;align-items:center;gap:10px;
  font-size:1.02rem;font-weight:500;
  color:var(--navy);
  padding:6px 4px;
  transition:color .25s var(--ease), transform .3s var(--ease);
}
.contact-action i{font-size:1.2rem;color:var(--blue)}
.contact-action:hover{color:var(--blue);transform:translateY(-2px)}
.contact-actions-sep{
  width:1px;height:18px;background:rgba(27,45,107,.18);
}

@media (max-width:560px){
  .contact-general{padding:72px 0 60px}
  .contact-actions{flex-direction:column;gap:16px}
  .contact-actions-sep{display:none}
}

/* ========== Contact — Team contact list ========== */
.contact-team{
  background:linear-gradient(180deg, #EEF2F8 0%, #F5F7FA 100%);
  padding:88px 0 96px;
}
.contact-list{
  list-style:none;padding:0;margin:0;
  max-width:920px;margin:0 auto;
  background:#fff;
  border:1px solid rgba(27,45,107,.06);
  border-radius:var(--radius-md);
  box-shadow:0 4px 14px rgba(27,45,107,.07);
  overflow:hidden;
}
.contact-list li{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:24px;
  padding:22px 28px;
  border-bottom:1px solid var(--gray-line);
  align-items:center;
}
.contact-list li:last-child{border-bottom:0}
.contact-name{
  font-weight:600;color:var(--navy);font-size:1.02rem;
  letter-spacing:-.005em;
}
.contact-phone, .contact-email{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ink-soft);
  font-size:.95rem;
  transition:color .25s ease;
}
.contact-phone i, .contact-email i{
  color:var(--blue);font-size:1.05rem;
}
.contact-phone:hover, .contact-email:hover{color:var(--navy)}

@media (max-width:760px){
  .contact-team{padding:64px 0 72px}
  .contact-list li{
    grid-template-columns:1fr;
    gap:8px;
    padding:20px 22px;
  }
  .contact-name{font-size:1.04rem;margin-bottom:2px}
}

/* ========== Contact — Location ========== */
.location-section{
  background:#fff;
  padding:96px 0 104px;
}
.location-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.location-info .ethos-eyebrow{color:var(--gray)}
.location-info h2{
  font-size:clamp(1.6rem,2.6vw,2.2rem);
  font-weight:500;
  letter-spacing:-.018em;line-height:1.22;
  margin:14px 0 24px;
}
.location-address{
  font-size:1.02rem;
  color:var(--ink-soft);
  line-height:1.8;
  font-weight:400;
  margin-bottom:20px;
}
.location-postal{
  font-size:.95rem;
  color:var(--gray);
  line-height:1.7;
}
.location-map{
  aspect-ratio:16/12;
  border-radius:var(--radius-md);
  overflow:hidden;
  background:#EEF2F8;
  border:1px solid rgba(27,45,107,.08);
  box-shadow:0 4px 14px rgba(27,45,107,.08);
  position:relative;
}
.location-map iframe{
  width:100%;height:100%;
  border:0;
  display:block;
  filter:grayscale(35%) contrast(.98);
  transition:filter .5s ease;
}
.location-map:hover iframe{filter:grayscale(0%) contrast(1)}

@media (max-width:920px){
  .location-grid{grid-template-columns:1fr;gap:36px}
  .location-section{padding:72px 0 80px}
}

/* ========== Reveal animations (calm, editorial) ========== */
.reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);
}
.reveal.in{opacity:1;transform:translateY(0)}
[data-delay="100"]{transition-delay:.15s}
[data-delay="200"]{transition-delay:.30s}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}

::selection{background:var(--navy);color:#fff}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
}
