:root{
  /* Light-only brand site: opt out of browser/OS "force dark" (Chrome/Android/Samsung),
     which auto-inverted the navy sections, images and white-on-dark form fields → illegible. */
  color-scheme:light;
  /* ===== Harbor Partners brand palette (exact) ===== */
  --navy:#113152;     /* primary brand navy */
  --blue:#1d5c9b;     /* brand blue, primary accent */
  --green:#679a85;    /* secondary accent */
  --rust:#9c3e11;     /* secondary accent */
  --slate:#4f565a;    /* neutral slate */
  --gray:#aeaeae;     /* light gray */
  --gray-d:#404040;   /* dark gray */
  --sky:#beced7;      /* light blue-gray */

  /* Dark surfaces (navy scale) */
  --ink:#113152;      /* main dark sections */
  --ink-2:#0b2138;    /* deepest dark, hero / footer */
  --ink-soft:#1a3e63; /* raised / hover dark panel */
  --ink-700:#21466e;  /* avatar gradient */

  /* Light surfaces */
  --paper:#ffffff;    /* page background */
  --paper-2:#eef3f7;  /* alternating sections (cool tint) */
  --text:#1f2933;     /* primary body text */

  /* Accent roles (var names kept; values now brand blue) */
  --bronze:#1d5c9b;   /* accent, links, buttons, eyebrows, active states */
  --bronze-l:#beced7; /* accent, lighter (palette light blue-gray) for use on dark surfaces */
  --bronze-d:#16487a; /* accent, deeper, small text / emphasis on light */

  --muted:#566069;    /* muted text on light */
  --muted-d:#94a2ac;  /* muted text on dark */
  --line:rgba(17,49,82,.14);     /* hairline on light */
  --line-d:rgba(255,255,255,.13); /* hairline on dark */
  --maxw:clamp(1240px,calc(1240px + (100vw - 1500px) * .62),1920px); /* fluid: 1240 up to ~1500px, grows to fill large/27" screens, caps at 1920 */
  --gut:clamp(22px,5.2vw,84px);
  --ease:cubic-bezier(.16,1,.3,1);
  --serif:"Inter Tight","Inter",-apple-system,BlinkMacSystemFont,sans-serif; /* display/heading sans (all-sans system) */
  --sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--paper);color:var(--text);
  -webkit-font-smoothing:antialiased;font-size:17px;line-height:1.7;
  overflow-x:hidden;font-feature-settings:"ss01";
  -webkit-tap-highlight-color:transparent;text-size-adjust:100%;-webkit-text-size-adjust:100%;
}
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  transform:translateZ(0);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--bronze);color:#fff}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ============ TYPE ============ */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.06;letter-spacing:-.02em}
.display{font-size:clamp(2.7rem,6.6vw,5.7rem);line-height:1.02}
.h-sec{font-size:clamp(2rem,4.3vw,3.5rem)}
.h-sec i,.display i{font-style:normal;color:var(--bronze-d)}
.on-dark .h-sec i,.on-dark .display i{color:var(--bronze-l)}
.lead{font-size:clamp(1.06rem,1.45vw,1.3rem);font-weight:300;line-height:1.62;color:var(--muted);max-width:60ch}
.on-dark .lead{color:#c4d1db}
.eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:.69rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:var(--bronze-d)}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--bronze)}
.on-dark .eyebrow{color:var(--bronze-l)}
/* Dark page banners (.pagehead/.hero/.contact-hero) aren't tagged .on-dark, give their
   eyebrows + accent lines the light accent so they're legible on the navy background. */
.pagehead .eyebrow,.hero .eyebrow,.contact-hero .eyebrow,.pf-hero .eyebrow{color:var(--bronze-l)}
.on-dark .eyebrow::before,.pagehead .eyebrow::before,.hero .eyebrow::before,.contact-hero .eyebrow::before,.pf-hero .eyebrow::before{background:var(--bronze-l)}
/* ...and the body copy on those banners: lead text defaults to --muted (dark grey),
   illegible on navy. Lift it to the light on-dark tone; accent words/links to light accent. */
.pagehead .lead,.hero .lead,.contact-hero .lead{color:#cdd9e2}
.pagehead .display i,.pagehead .h-sec i,.hero .display i,.hero .h-sec i,.contact-hero .display i,.contact-hero .h-sec i{color:var(--bronze-l)}
.pagehead .txtlink,.hero .txtlink,.contact-hero .txtlink{color:var(--bronze-l)}
.tnum{font-variant-numeric:tabular-nums lining-nums}
/* all-sans system has no italic face, keep emphasis upright (accent words use colour, not slant) */
i,em{font-style:normal}

/* ============ LAYOUT ============ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.sec{padding:clamp(84px,12vw,168px) 0}
/* Navy sections show the WHOLE team photo "contained" inside the band (never cropped, 
   no side person cut, no heads cut), with a navy base + blue-tint gradient over it for
   the brand "blue filter" and white-text legibility. Tune --glass-top/--glass-bot. */
.sec.dark{
  position:relative;
  --glass-top:.38;--glass-bot:.53;
  background:linear-gradient(180deg,rgba(17,49,82,var(--glass-top)),rgba(11,33,56,var(--glass-bot)));
  color:var(--paper);
  border-top:1px solid rgba(255,255,255,.07);
  border-bottom:1px solid rgba(0,0,0,.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
@supports ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
  .sec.dark{backdrop-filter:saturate(1.12);-webkit-backdrop-filter:saturate(1.12)}
}
/* keep every non-navy section opaque so the fixed team photo shows ONLY through navy */
.sec:not(.dark):not(.paper2){background-color:var(--paper)}
.sec.paper2{background:var(--paper-2)}
/* closing "talk to the team" CTA band, compact padding so the heading (top) and the
   button stay visible together instead of being spread out by the full .sec spacing */
section.sec.dark.on-dark:has(a.btn-fill[href$="contact.html"]){padding-top:clamp(40px,5vw,76px);padding-bottom:clamp(40px,5vw,76px)}
section[id]{scroll-margin-top:78px}
.grid2{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,96px);align-items:start}
/* Two-column heading/text bands: align the section title's first line with the body
   text on the right — reset the title's top margin so it starts at the column top,
   and lift the small eyebrow kicker just above it. Desktop only; columns stack <=980px. */
@media(min-width:981px){
  .grid2 > div:first-child:has(> .h-sec) > .h-sec{margin-top:0 !important}
  .grid2 > div:first-child:has(> .h-sec):has(> .eyebrow){position:relative}
  .grid2 > div:first-child:has(> .h-sec):has(> .eyebrow) > .eyebrow{position:absolute;left:0;bottom:calc(100% + 14px)}
}
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;margin-bottom:clamp(48px,6vw,76px)}
.head-row h2{max-width:16ch;margin-top:22px}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-family:var(--sans);
  font-size:.73rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:15px 28px;border:1px solid;border-radius:2px;background:none;transition:.45s var(--ease)}
.btn .arr{transition:transform .45s var(--ease)}
.btn:hover .arr{transform:translateX(6px)}
.btn-fill{background:var(--bronze);border-color:var(--bronze);color:#fff}
.btn-fill:hover{background:var(--bronze-d);border-color:var(--bronze-d)}
.btn-line{border-color:currentColor;color:inherit;opacity:.92}
.btn-line:hover{background:currentColor}
.on-dark .btn-line:hover{color:var(--ink)}
.btn-line.lite:hover{color:var(--paper)}
.txtlink{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;color:var(--bronze-d);position:relative}
.on-dark .txtlink{color:var(--bronze-l)}
.txtlink::after{content:"";position:absolute;left:0;bottom:-4px;height:1px;width:0;background:currentColor;transition:width .45s var(--ease)}
.txtlink:hover::after{width:100%}
.txtlink .arr{transition:transform .45s var(--ease)}
.txtlink:hover .arr{transform:translateX(5px)}

/* ============ MEDIA TREATMENT ============ */
.media{position:relative;overflow:hidden;background:var(--ink-2)}
.media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,33,56,.55) 0%,rgba(11,33,56,0) 40%);pointer-events:none}
.media:hover img{transform:scale(1.04)}

/* ============ HEADER ============ */
header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;
  justify-content:space-between;padding:21px var(--gut);
  transition:background .55s var(--ease),padding .55s var(--ease),box-shadow .55s var(--ease),color .55s var(--ease);
  color:var(--paper)}
header.scrolled{background:rgba(11,33,56,.88);backdrop-filter:blur(10px) saturate(1.1);-webkit-backdrop-filter:blur(10px) saturate(1.1);
  padding:13px var(--gut);box-shadow:0 1px 0 var(--line-d);color:var(--paper)}
.brand{display:flex;align-items:center;gap:13px;z-index:2}
.brand-logo{height:34px;width:auto;flex:none;display:block;transition:transform .6s var(--ease)}
.foot-top .brand-logo{height:28px}
@media(max-width:520px){.brand-logo{height:30px}}
.brand:hover .brand-logo{transform:translateY(-2px)}
.brand .mark{height:30px;width:auto;flex:none;transition:transform .6s var(--ease)}
.brand:hover .mark{transform:translateY(-2px)}
.brand .divider{width:1px;height:30px;background:currentColor;opacity:.26;flex:none}
.brand .name{font-family:var(--serif);font-weight:600;font-size:1.24rem;letter-spacing:.09em;line-height:1;text-transform:uppercase}
.brand .name span{display:block;font-family:var(--sans);font-size:.5rem;letter-spacing:.46em;
  text-transform:uppercase;opacity:.66;margin-top:6px;font-weight:500;padding-left:.06em}
nav{display:flex;align-items:center;gap:2px;flex:1}
nav .lk:first-child{margin-left:auto}
nav a.lk{position:relative;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;
  font-weight:500;padding:10px 15px;opacity:.78;transition:opacity .3s var(--ease)}
nav a.lk::after{content:"";position:absolute;left:15px;right:15px;bottom:4px;height:1px;
  background:var(--bronze-l);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
nav a.lk:hover{opacity:1}
nav a.lk.active{opacity:1}
nav a.lk.active::after{transform:scaleX(1)}
nav .cta{margin-left:auto;border:1px solid currentColor;border-radius:2px;padding:9px 18px;
  font-size:.69rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600;opacity:.95;
  white-space:nowrap;transition:.45s var(--ease)}
nav .cta:hover{background:var(--bronze);border-color:var(--bronze);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:3;color:inherit}
.burger span{width:24px;height:1.5px;background:currentColor;transition:.4s var(--ease)}
.burger.x span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ============ DROPDOWN NAV (About) ============ */
.lk-drop{position:relative;display:inline-flex;align-items:center}
.lk-parent .caret{display:inline-block;font-size:.5em;margin-left:6px;opacity:.6;transition:transform .35s var(--ease),opacity .3s var(--ease)}
.lk-drop:hover .caret,.lk-drop:focus-within .caret{opacity:1;transform:rotate(180deg)}
.drop-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:216px;
  background:rgba(11,33,56,.97);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);
  border:1px solid var(--line-d);border-radius:6px;padding:8px;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease);
  box-shadow:0 26px 70px rgba(11,33,56,.55);z-index:60}
.drop-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.lk-drop:hover .drop-menu,.lk-drop:focus-within .drop-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(3px)}
.drop-menu a{padding:10px 16px;border-radius:3px;font-size:.69rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;color:var(--paper);opacity:.76;white-space:nowrap;transition:.25s var(--ease)}
.drop-menu a:hover{background:rgba(99,150,200,.13);opacity:1;color:var(--bronze-l)}
.drop-menu a.current{color:var(--bronze-l);opacity:1}
/* About → rich "explore" mega-menu: each item gets a heading, a short description and a ↗ arrow (mirrors the About-page cards) */
.drop-menu.mega{min-width:0;width:min(440px,calc(100vw - 28px));background:var(--paper);border-color:var(--line);padding:6px;box-shadow:0 30px 70px rgba(11,33,56,.22)}
.drop-menu.mega a{display:grid;grid-template-columns:1fr 38px;column-gap:14px;align-items:center;padding:15px 16px;border-radius:8px;white-space:normal;text-transform:none;letter-spacing:normal;font-weight:400;opacity:1;color:var(--ink);transition:background .35s var(--ease)}
.drop-menu.mega a + a{border-top:1px solid var(--line)}
.drop-menu.mega .dd-h{grid-column:1;grid-row:1;font-family:var(--serif);font-weight:600;font-size:1.12rem;letter-spacing:-.01em;line-height:1.15;color:var(--ink);transition:color .4s var(--ease),transform .5s var(--ease)}
.drop-menu.mega .dd-desc{grid-column:1;grid-row:2;margin-top:5px;font-size:.82rem;font-weight:300;line-height:1.45;color:var(--muted);letter-spacing:0;text-transform:none}
.drop-menu.mega .dd-go{grid-column:2;grid-row:1/3;align-self:center;justify-self:end;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-size:.95rem;color:var(--bronze-d);opacity:1;transition:.45s var(--ease)}
.drop-menu.mega a:hover{background:linear-gradient(90deg,rgba(29,92,155,.07),transparent 72%);color:var(--ink)}
.drop-menu.mega a:hover .dd-h{color:var(--bronze-d);transform:translateX(5px)}
.drop-menu.mega a:hover .dd-go{background:var(--ink);border-color:var(--ink);color:var(--paper);transform:rotate(-45deg)}
.drop-menu.mega a.current{background:rgba(29,92,155,.06)}
.drop-menu.mega a.current .dd-h{color:var(--bronze-d)}
.drop-menu.mega a.current .dd-go{background:var(--ink);border-color:var(--ink);color:var(--paper)}
/* centered nav (desktop): brand left · links centered · lang pinned right */
@media(min-width:981px){
  header{display:grid;grid-template-columns:1fr auto 1fr}
  nav{justify-content:center}
  nav .lk:first-child{margin-left:0}
  nav .langtog{position:absolute;right:var(--gut);top:50%;transform:translateY(-50%);margin-left:0}
  /* international pages use the 7-language picker, pin it right and keep it on ONE row,
     like the EN/PT toggle, so every header is the same height (no wrap-induced growth) */
  nav .langpick{position:absolute;right:var(--gut);top:50%;transform:translateY(-50%);margin-left:0;flex-wrap:nowrap}
}

/* ============ HERO (home) ============ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden;background:var(--ink-2)}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;object-position:50% 24%}
.hero .bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(11,33,56,.72) 0%,rgba(11,33,56,.34) 42%,rgba(11,33,56,.06) 68%,transparent 100%),
    linear-gradient(180deg,rgba(11,33,56,.5) 0%,rgba(11,33,56,.14) 30%,rgba(11,33,56,.4) 64%,rgba(11,33,56,.93) 100%)}
.hero .bg::before{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(80% 70% at 78% 18%,rgba(99,150,200,.16),transparent 60%)}
.hero-inner{position:relative;z-index:2;width:100%;padding:140px var(--gut) clamp(40px,5vh,52px)}
.hero h1{margin:24px 0 28px;max-width:19ch}
.hero .lead{max-width:54ch}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px}
.hero-metrics{display:flex;gap:clamp(28px,5vw,72px);flex-wrap:wrap;align-items:flex-end;margin-top:clamp(30px,4vw,48px)}
.hmetric .v{font-family:var(--serif);font-size:clamp(1.5rem,2.2vw,2rem);line-height:1;color:var(--bronze-l)}
.hmetric .v small{font-size:.5em;vertical-align:super;color:#beced7}
.hmetric .v small.pl{vertical-align:.4em}
.hmetric p{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#a6b7c4;margin-top:11px}
/* (scroll-down cue removed) */
@keyframes sweep{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ============ PAGE BANNER (sub-pages) ============ */
.pagehead{position:relative;overflow:hidden;background:var(--ink-2);color:var(--paper);
  padding:clamp(146px,18vw,212px) 0 clamp(58px,8vw,94px)}
.pagehead .bg{position:absolute;inset:0;z-index:0}
.pagehead .bg img{width:100%;height:100%;object-fit:cover}
.pagehead .bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(100deg,rgba(0,0,0,.64) 22%,rgba(0,0,0,.3) 60%,rgba(0,0,0,.12) 100%),
    linear-gradient(180deg,transparent 40%,rgba(0,0,0,.5))}
/* Track Record final CTA: opaque navy so the fixed team photo behind doesn't show there. */
.sec.dark.cta-solid{background:linear-gradient(180deg,#12314f,#0a1f38)}
/* Careers "Open Day" CTA: a lighter palette blue (ink-700 → ink-soft) instead of the deep navy,
   still dark enough for white text and to let the brand-blue "Send CV" button stand out */
.sec.dark.cta-solid.cta-lite{background:linear-gradient(180deg,#21466e,#1a3e63)}
.pagehead .num{position:absolute;right:var(--gut);top:50%;transform:translateY(-46%);z-index:1;
  font-family:var(--serif);font-size:clamp(8rem,27vw,23rem);line-height:.66;color:rgba(99,150,200,.08);pointer-events:none;user-select:none}
.pagehead .wrap{position:relative;z-index:2}
.pagehead h1{font-size:clamp(2.5rem,6vw,5rem);margin-top:18px}
.pagehead .lead{margin-top:22px;max-width:58ch}
/* FAQ hub pages: shorten the banner + tighten the grid's top gap so the topic
   cards are visible without scrolling (scoped to pages that render the .faqgrid) */
body:has(.faqgrid) .pagehead{padding-top:clamp(100px,12vw,140px);padding-bottom:clamp(28px,3.5vw,46px)}
.sec:has(.faqgrid){padding-top:clamp(30px,4vw,50px)}

/* ============ WHO WE ARE ============ */
.statement{font-family:var(--serif);font-size:clamp(1.7rem,3.3vw,2.7rem);line-height:1.26;font-weight:300;letter-spacing:-.015em}
.statement i{font-style:normal;color:var(--bronze-d)}
.who-media{aspect-ratio:4/4.6;border-radius:3px}
.figtag{position:absolute;left:22px;bottom:20px;z-index:2;font-size:.66rem;letter-spacing:.18em;
  text-transform:uppercase;color:#d3e0ea;display:flex;align-items:center;gap:10px}
.figtag::before{content:"";width:22px;height:1px;background:var(--bronze-l)}

/* ============ SERVICES ============ */
.svc-intro{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);margin-bottom:clamp(40px,5vw,64px)}
.intro-photo{margin:clamp(30px,4vw,52px) 0 0;border-radius:4px;overflow:hidden;aspect-ratio:3/2;background:var(--ink-2)}
.intro-photo img{width:100%;height:100%;object-fit:cover;display:block}
.svc-list{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:1.05fr 1.55fr;gap:clamp(18px,2.4vw,40px);align-items:start;
  padding:clamp(28px,3vw,44px) 6px;border-bottom:1px solid var(--line);transition:.5s var(--ease);color:inherit}
.svc:hover{background:linear-gradient(90deg,rgba(29,92,155,.06),transparent 55%)}
.svc h3{font-size:clamp(1.5rem,2.6vw,2.15rem);transition:color .4s var(--ease),transform .5s var(--ease)}
.svc:hover h3{color:var(--bronze-d)}
.svc:hover h3{transform:translateX(10px)}
.svc .items{display:flex;flex-wrap:wrap;gap:9px;padding-top:8px}
.svc .items>span{font-size:.78rem;letter-spacing:.01em;padding:7px 15px;border:1px solid var(--line);
  border-radius:2px;color:#44535e;transition:.4s var(--ease)}
.svc:hover .items>span{border-color:rgba(29,92,155,.5);color:var(--bronze-d)}
.svc .desc{font-size:.98rem;color:var(--muted);font-weight:300;padding-top:7px;line-height:1.6}
/* Track Record only: deal rows become dynamic CARDS (not a flat list) */
body.trk .svc-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:clamp(16px,1.6vw,22px);border-top:0}
body.trk .svc{display:flex;flex-direction:column;gap:14px;align-items:stretch;
  padding:clamp(24px,2.2vw,34px);border:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:9px;
  background:var(--paper);position:relative;overflow:hidden;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s var(--ease)}
body.trk .svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--bronze);transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease)}
body.trk .svc:hover{background:var(--paper);transform:translateY(-6px);box-shadow:0 28px 60px rgba(11,33,56,.13);border-color:rgba(29,92,155,.45)}
body.trk .svc:hover::before{transform:scaleY(1)}
body.trk .svc>div:first-child{display:flex;flex-direction:column-reverse;gap:13px;align-items:flex-start}
body.trk .svc h3{font-size:clamp(1.4rem,1.9vw,1.75rem)}
body.trk .svc:hover h3{transform:none;color:var(--ink)}
body.trk .svc .items{padding-top:0}
body.trk .svc .desc{padding-top:0;margin-top:auto}
body.trk .svc .desc b{color:var(--bronze-d);font-weight:700}
.svc.has-go{cursor:pointer;grid-template-columns:1fr 1.4fr 42px}
button.svc{font:inherit;color:inherit;width:100%;text-align:left;background:none;border:0;border-bottom:1px solid var(--line);border-radius:0}
button.svc:focus-visible{outline:2px solid var(--bronze-d);outline-offset:-3px}
.svc.has-go .go{align-self:center;justify-self:end;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--bronze-d);transition:.45s var(--ease)}
.svc.has-go .go svg{width:16px;height:16px}
.svc.has-go:hover .go{background:var(--ink);border-color:var(--ink);color:var(--paper);transform:rotate(-45deg)}
/* Services page keeps its practice numeration (01–04) */
.svc-numbered .svc.has-go{grid-template-columns:64px 1fr 1.4fr 42px}
.svc-numbered .svc .ix{font-family:var(--serif);font-size:1.05rem;color:var(--bronze-d);padding-top:6px;transition:transform .5s var(--ease)}
.svc-numbered .svc.has-go:hover .ix{transform:translateX(10px)}
.eyebrow .ix{font-variant-numeric:tabular-nums;opacity:.7}
/* landing "What We Do": static, non-interactive list, index · title only (full details live on the Services page) */
.svc-static .svc{grid-template-columns:1fr;align-items:center;cursor:default}
.svc-static .svc:hover{background:none;padding-left:0}
.svc-static .svc:hover h3{color:inherit}
/* Home "Four integrated practices" list, numbered, vertically centred (non-interactive) */
.svc-static.svc-numbered .svc{grid-template-columns:56px 1fr}
.svc-static.svc-numbered .svc .ix{padding-top:0}

/* ============ SERVICE DETAIL MODAL ============ */
.svc-modal{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;padding:clamp(16px,4vw,48px);
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s var(--ease)}
.svc-modal.open{opacity:1;visibility:visible}
.svc-modal .scrim{position:absolute;inset:0;background:rgba(11,33,56,.6);backdrop-filter:blur(6px) saturate(1.05);cursor:pointer}
.svc-modal .panel{position:relative;z-index:1;width:min(760px,100%);max-height:88vh;overflow:auto;
  background:var(--paper);border:1px solid var(--line);border-radius:4px;box-shadow:0 40px 120px rgba(11,33,56,.42);
  padding:clamp(30px,4.6vw,62px);transform:translateY(26px) scale(.985);transition:transform .55s var(--ease)}
.svc-modal.open .panel{transform:none}
.svc-modal .panel::-webkit-scrollbar{width:9px}
.svc-modal .panel::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px}
.smClose{position:absolute;top:clamp(20px,2.4vw,28px);right:clamp(20px,2.4vw,28px);z-index:2;flex:none;
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--paper);cursor:pointer;
  display:grid;place-items:center;color:var(--text);transition:.45s var(--ease)}
.smClose:hover{background:var(--ink);border-color:var(--ink);color:var(--paper);transform:rotate(90deg)}
.smClose svg{width:16px;height:16px}
.smHead{padding-right:52px;padding-bottom:clamp(22px,2.6vw,30px);border-bottom:1px solid var(--line);margin-bottom:clamp(24px,3vw,34px)}
.smHead h2{font-size:clamp(1.9rem,3.8vw,2.9rem);margin-top:16px}
.smLead{font-size:clamp(1.04rem,1.4vw,1.2rem);color:var(--muted);font-weight:300;line-height:1.62;max-width:60ch}
.smList{margin-top:clamp(24px,3vw,36px);border-top:1px solid var(--line)}
.smItem{padding:clamp(17px,2vw,23px) 0;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:minmax(170px,.82fr) 1.55fr;gap:clamp(14px,2.2vw,34px);align-items:start;transition:.4s var(--ease)}
.smItem:hover{padding-left:8px}
.smItem h4{font-family:var(--serif);font-weight:400;font-size:1.18rem;color:var(--bronze-d);letter-spacing:-.01em;line-height:1.22}
.smItem p{font-size:.96rem;color:var(--muted);font-weight:300;line-height:1.62}
.smFoot{margin-top:clamp(26px,3vw,38px);display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}
.smFoot .note{font-size:.9rem;color:var(--muted);font-weight:300;max-width:40ch}
.smMeta{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.smMeta span{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-weight:500;white-space:nowrap}
.smItem ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.smItem ul li{position:relative;padding-left:18px;font-size:.96rem;color:var(--muted);font-weight:300;line-height:1.55}
.smItem ul li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;border-radius:50%;background:var(--bronze)}
body.modal-open{overflow:hidden}

/* careers, clickable open-position rows (open a detail modal) */
.job-list{margin-top:22px;border-top:1px solid var(--line-d)}
.job-row{width:100%;text-align:left;background:none;border:0;border-bottom:1px solid var(--line-d);cursor:pointer;display:grid;grid-template-columns:1fr auto;align-items:center;gap:18px;padding:20px 2px;color:inherit;font:inherit;transition:padding-left .45s var(--ease)}
.job-row:hover{padding-left:12px}
.job-row .jt{font-family:var(--serif);font-size:1.2rem;color:var(--paper);line-height:1.2}
.job-row .jm{display:block;margin-top:7px;font-size:.73rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-d)}
.job-row .jgo{flex:none;display:inline-flex;align-items:center;gap:9px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze-l);white-space:nowrap}
.job-row .jgo svg{width:17px;height:17px;transition:transform .4s var(--ease)}
.job-row:hover .jgo svg{transform:translateX(5px)}
.job-row:focus-visible{outline:2px solid var(--bronze-l);outline-offset:3px}
@media(max-width:520px){.job-row .jgo span{display:none}}

/* careers, application modal (Send your CV, with file upload) */
.apply-modal{position:fixed;inset:0;z-index:2200;display:grid;place-items:center;padding:clamp(14px,4vw,46px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s var(--ease)}
.apply-modal.open{opacity:1;visibility:visible}
.apply-modal .scrim{position:absolute;inset:0;background:rgba(6,18,31,.66);backdrop-filter:blur(6px) saturate(1.05);-webkit-backdrop-filter:blur(6px) saturate(1.05);cursor:pointer}
.apply-modal .panel{position:relative;z-index:1;width:min(600px,100%);max-height:92vh;overflow:auto;background:var(--ink);color:var(--paper);border:1px solid var(--line-d);border-radius:5px;padding:clamp(26px,4vw,44px);box-shadow:0 40px 120px rgba(0,0,0,.5);transform:translateY(16px) scale(.99);transition:transform .5s var(--ease)}
.apply-modal.open .panel{transform:none}
.apply-modal .panel::-webkit-scrollbar{width:9px}
.apply-modal .panel::-webkit-scrollbar-thumb{background:var(--line-d);border-radius:9px}
.apply-modal h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin:14px 0 0;color:var(--paper)}
.apply-modal .apply-for{margin-top:12px;font-size:.82rem;letter-spacing:.04em;color:var(--bronze-l)}
.apply-modal form{margin-top:clamp(20px,3vw,28px)}
.apply-modal .ap-cap{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze-l);margin-bottom:9px}
.apply-modal .btn-fill{margin-top:8px;width:100%;justify-content:center}
.apply-modal #applyMsg{margin-top:14px;font-size:.9rem;min-height:1.25em;line-height:1.5}
.apply-modal .apply-fallback{margin-top:16px;font-size:.82rem;color:var(--muted-d)}
.apply-modal .apply-fallback a{color:var(--bronze-l);border-bottom:1px solid rgba(99,150,200,.4)}
.ap-file-row{grid-column:1/-1;margin-bottom:20px}
.filedrop{display:flex;align-items:center;gap:13px;cursor:pointer;background:rgba(255,255,255,.04);border:1px dashed var(--line-d);border-radius:2px;padding:14px 16px;font-size:.93rem;color:#8e9ca8;transition:.3s var(--ease)}
.filedrop:hover{border-color:var(--bronze);background:rgba(99,150,200,.06);color:#aebdc9}
.filedrop svg{flex:none;width:19px;height:19px;color:var(--bronze-l)}
.filedrop .fd-name{color:var(--paper);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-file{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0;opacity:0}
.sr-file:focus-visible + .filedrop{border-color:var(--bronze);box-shadow:0 0 0 2px rgba(99,150,200,.4)}

/* ============ BAND ============ */
.band{position:relative;height:clamp(280px,42vw,500px)}
.band .wrap{position:absolute;inset:0;display:flex;align-items:flex-end;padding-bottom:clamp(36px,5vw,64px);z-index:2}
.band .q{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.5rem);line-height:1.24;color:var(--paper);
  font-weight:300;max-width:24ch;letter-spacing:-.01em}
.band .q i{font-style:normal;color:var(--bronze-l)}
.band .txtlink{color:var(--bronze-l);margin-top:clamp(16px,2vw,24px)}
.band:hover .txtlink::after{width:100%}
.band:hover .txtlink .arr{transform:translateX(5px)}

/* ============ VALUES ============ */
.values-sec{position:relative;overflow:hidden}
.values-sec .tex{position:absolute;inset:0;z-index:0;opacity:.16}
.values-sec .tex img{width:100%;height:100%;object-fit:cover}
.values-sec .tex::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--ink) 30%,rgba(17,49,82,.7))}
.values-sec .wrap{position:relative;z-index:1}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d);margin-top:8px}
.val{background:var(--ink);padding:clamp(34px,3.4vw,52px) clamp(26px,2.6vw,40px);transition:.55s var(--ease)}
.val:hover{background:var(--ink-soft)}
.val .vn{font-family:var(--serif);font-size:1rem;color:var(--bronze-l);letter-spacing:.04em;margin-bottom:22px}
.val h3{font-size:clamp(1.4rem,2vw,1.7rem);margin-bottom:16px;color:var(--paper)}
.val p{font-size:.98rem;color:#aab9c5;font-weight:300;line-height:1.65}
/* light values (Values page) */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);border-top:1px solid var(--line);padding-top:clamp(40px,5vw,66px)}
.vitem .vn{font-family:var(--serif);font-size:1.1rem;color:var(--bronze-d);display:block;margin-bottom:18px}
.vitem h3{font-size:clamp(1.5rem,2.2vw,2rem);margin-bottom:15px}
.vitem p{color:var(--muted);font-weight:300;font-size:1.04rem;line-height:1.62}
@media(max-width:860px){.vgrid{grid-template-columns:1fr;gap:0}.vitem{padding:28px 0;border-bottom:1px solid var(--line)}}

/* ---- Values page: compact photo gallery, title on each card, description reveals on hover ---- */
.cv-sec{padding-top:clamp(40px,5vw,72px)}
.cv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.5vw,24px);
  margin-top:clamp(10px,3vw,40px)}
.cv-card{position:relative;aspect-ratio:5/7;overflow:hidden;border-radius:6px;isolation:isolate;background:var(--ink);
  box-shadow:0 20px 44px -26px rgba(11,33,56,.5),0 3px 10px -6px rgba(11,33,56,.4);
  transition:box-shadow .55s var(--ease),transform .55s var(--ease)}
.cv-card>img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.05);transition:transform 1.1s var(--ease)}
/* resting wash, keeps the title legible at the foot of the photo */
.cv-card::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(11,33,56,0) 28%,rgba(11,33,56,.5) 68%,rgba(11,33,56,.92) 100%)}
/* reveal wash, fades up over the whole photo so the description reads cleanly */
.cv-card::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;
  background:linear-gradient(168deg,rgba(29,92,155,.34) 0%,rgba(17,49,82,.84) 46%,rgba(11,33,56,.96) 100%);
  transition:opacity .55s var(--ease)}
.cv-num{position:absolute;top:clamp(13px,1vw,17px);left:clamp(15px,1.1vw,19px);z-index:4;
  font-family:var(--serif);font-weight:600;font-size:.92rem;letter-spacing:.06em;
  color:var(--bronze-l);opacity:.92;font-variant-numeric:lining-nums tabular-nums}
.cv-body{position:absolute;left:0;right:0;bottom:0;z-index:4;
  padding:clamp(17px,1.4vw,24px);color:#eaf2f8}
.cv-eyebrow{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;font-weight:600;color:var(--bronze-l);margin-bottom:9px}
.cv-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.12rem,1.32vw,1.42rem);
  line-height:1.12;letter-spacing:-.02em;color:#fff;
  min-height:2.24em;display:flex;flex-direction:column;justify-content:flex-end}  /* reserve 2 lines so the eyebrow row aligns across cards (EN & PT); bottom-anchor the text so the title→description gap is identical on 1- and 2-line titles */
.cv-title i{font-style:normal;color:var(--bronze-l)}
.cv-desc{color:rgba(234,242,248,.88);font-family:var(--sans);font-weight:300;
  font-size:.82rem;line-height:1.5;margin-top:0;opacity:0;max-height:0;overflow:hidden;
  transition:opacity .4s var(--ease),max-height .6s var(--ease),margin-top .6s var(--ease)}
/* reveal, on hover or keyboard focus */
.cv-card:hover,.cv-card:focus-within{box-shadow:0 34px 64px -26px rgba(11,33,56,.6);transform:translateY(-3px)}
.cv-card:hover>img,.cv-card:focus-within>img{transform:scale(1.12)}
.cv-card:hover::before,.cv-card:focus-within::before{opacity:1}
.cv-card:hover .cv-desc,.cv-card:focus-within .cv-desc{opacity:1;max-height:24em;margin-top:13px}
.cv-card:focus-visible{outline:2px solid var(--bronze-l);outline-offset:3px}
@media(prefers-reduced-motion:reduce){.cv-card>img{transform:none}.cv-card:hover,.cv-card:focus-within{transform:none}}
/* touch / no-hover devices: there is no hover, so show every description up front */
@media(hover:none){
  .cv-card::before{opacity:1}
  .cv-desc{opacity:1;max-height:24em;margin-top:13px}
}
@media(max-width:1024px){.cv-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
/* phones: no hover, one column, image becomes a banner and the text sits below it so the
   full description always fits (card height grows with its content) */
@media(max-width:560px){
  .cv-grid{grid-template-columns:1fr;gap:16px}
  .cv-card{aspect-ratio:auto}
  .cv-card>img{position:relative;height:clamp(180px,52vw,250px);transform:none}
  .cv-card::after,.cv-card::before{display:none}
  .cv-body{position:static;padding:clamp(20px,5.5vw,26px)}
  .cv-title{min-height:0}            /* stacked single column: no need to reserve title lines */
  .cv-desc{opacity:1;max-height:none;margin-top:12px}
}

/* ============ TRACK RECORD ============ */
.tr-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:center}
.figure{font-family:var(--serif);font-size:clamp(4.4rem,12vw,9.5rem);line-height:.82;letter-spacing:-.03em;color:var(--ink)}
.figure small{font-size:.32em;vertical-align:super;color:var(--bronze-d)}
.tr-points{margin-top:38px;border-top:1px solid var(--line)}
.tr-points .row{display:flex;gap:20px;align-items:baseline;padding:19px 0;border-bottom:1px solid var(--line)}
.tr-points .row .n{font-family:var(--serif);font-size:.95rem;color:var(--bronze-d);flex:none;width:30px}
.tr-points .row .t{font-size:1rem;color:var(--text)}
.tr-points .row .t b{font-weight:500}
.tr-note{font-size:.78rem;color:var(--muted);letter-spacing:.02em;margin-top:26px}
.tr-media{aspect-ratio:4/4.4;border-radius:3px}
/* stat figures */
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(28px,3vw,44px);
  border-top:1px solid var(--line);padding-top:clamp(36px,4vw,58px)}
.stat .sv{font-family:var(--serif);font-size:clamp(2.5rem,4.4vw,3.9rem);line-height:1;color:var(--ink);letter-spacing:-.02em}
.stat .sv small{font-size:.4em;vertical-align:super;color:var(--bronze-d)}
.stat .sv small.pl{vertical-align:.55em}
.stat .sl{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-top:13px;line-height:1.45;font-weight:500}
/* selected work / projects */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,3.6vw,56px)}
.proj-rail{display:flex;gap:clamp(24px,3.2vw,52px);overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:18px;scrollbar-width:none;-ms-overflow-style:none}
.proj-rail::-webkit-scrollbar{display:none}
.proj-rail .project{flex:0 0 calc((100% - clamp(24px,3.2vw,52px)) / 2);scroll-snap-align:start}
@media(pointer:fine){.proj-rail,.team-rail{cursor:grab}}
.proj-rail.is-dragging,.team-rail.is-dragging{scroll-snap-type:none;scroll-behavior:auto;cursor:grabbing;user-select:none}
[data-rail] img{-webkit-user-drag:none;user-select:none}
.project .project-media{aspect-ratio:4/3;border-radius:3px;overflow:hidden;background:var(--ink-2);margin-bottom:clamp(18px,2vw,24px)}
.project .project-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.project:hover .project-media img{transform:scale(1.04)}
.project .cat{display:inline-flex;align-items:center;gap:11px;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--bronze-d)}
.project .cat::before{content:"";width:22px;height:1px;background:var(--bronze)}
.project h3{font-size:clamp(1.45rem,2.3vw,1.95rem);margin:15px 0 12px}
.project p{color:var(--muted);font-weight:300;font-size:1rem;line-height:1.62;max-width:48ch}
/* clickable deal cards linked to their news article */
a.project{display:block;color:inherit}
a.project:hover h3{color:var(--bronze-d);transition:color .4s var(--ease)}
.project .story-link{display:inline-flex;align-items:center;gap:9px;margin-top:16px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--bronze-d)}
.project .story-link .arr{transition:transform .45s var(--ease)}
a.project:hover .story-link .arr{transform:translateX(6px)}
/* "in the news" link on detailed deal rows */
a.svc-news{display:inline-flex;align-items:center;gap:7px;margin-top:10px;font-size:.74rem;letter-spacing:.06em;font-weight:600;color:var(--bronze-d)}
a.svc-news::before{content:"";width:16px;height:1px;background:var(--bronze);transition:width .4s var(--ease)}
.svc:hover a.svc-news::before{width:26px}

/* ============ TEAM ============ */
.lead-card{display:grid;grid-template-columns:clamp(250px,26vw,330px) 1fr;gap:clamp(28px,3vw,52px);align-items:center;
  padding:clamp(26px,3vw,40px);border:1px solid var(--line);border-radius:3px;background:var(--paper);margin-bottom:48px}
.lead-card .ava{aspect-ratio:4/5;width:100%;border-radius:3px}
.lead-card h3{font-size:clamp(1.7rem,2.6vw,2.3rem)}
.lead-card .role{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bronze-d);margin-top:8px;font-weight:600}
.lead-card .note{margin-top:18px;color:var(--muted);font-size:1rem;font-weight:300;max-width:46ch}
.lead-card .award{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--bronze-d);font-weight:600}
.lead-card .award::before{content:"";width:18px;height:1px;background:var(--bronze)}
.ava{display:grid;place-items:center;background:linear-gradient(155deg,var(--ink-700),var(--ink-2));
  position:relative;overflow:hidden;border:1px solid var(--line)}
.ava span{font-family:var(--serif);color:var(--bronze-l);letter-spacing:.03em}
.ava::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(130% 130% at 50% 0,rgba(99,150,200,.1),transparent 60%),linear-gradient(to top,rgba(11,33,56,.32),transparent 46%)}
.ava img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 20%;z-index:1;transition:transform .6s var(--ease)}
.person:hover .ava img{transform:scale(1.05)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.2vw,30px)}
.person .ava{aspect-ratio:4/5;border-radius:3px;margin-bottom:15px;transition:.55s var(--ease)}
.person .ava span{font-size:2.1rem;transition:.55s var(--ease)}
.person:hover .ava{transform:translateY(-4px);border-color:rgba(29,92,155,.4)}
.person:hover .ava span{transform:scale(1.07);color:var(--bronze)}
.person h3{font-size:1.14rem;font-weight:500;letter-spacing:-.01em}
.person .role{font-size:.82rem;color:var(--muted);margin-top:4px;line-height:1.4}
.sub-h{display:flex;align-items:center;gap:18px;margin:clamp(56px,6vw,84px) 0 clamp(26px,3vw,40px)}
.sub-h span{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--bronze-d);white-space:nowrap}
.sub-h::after{content:"";flex:1;height:1px;background:var(--line)}
.adv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,28px)} /* same card width as .team-grid */
.adv{display:flex;align-items:center;gap:18px;padding:22px 24px;border:1px solid var(--line);border-radius:3px;background:var(--paper)}
.adv .ava{width:54px;height:54px;border-radius:50%;flex:none}
.adv .ava span{font-size:1.15rem}
.adv h3{font-size:1.04rem;font-weight:500}
.adv .role{font-size:.76rem;color:var(--muted);margin-top:2px}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px)}
.cinfo .row{padding:24px 0;border-bottom:1px solid var(--line-d)}
.cinfo .row:first-child{padding-top:0}
.cinfo .k{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze-l);margin-bottom:9px}
.cinfo .v{font-family:var(--serif);font-size:1.28rem;line-height:1.45}
.cinfo .v a{transition:color .3s}
.cinfo .v a:hover{color:var(--bronze-l)}
/* ============ CONTACT, single-viewport split (intro+details left · form right) ============ */
.contact-hero{position:relative;overflow:hidden;background:var(--ink-2);color:var(--paper);
  min-height:100vh;min-height:100svh;display:flex;align-items:center;
  padding:clamp(90px,12vh,128px) 0 clamp(56px,7vh,72px)}
.contact-hero .bg{position:absolute;inset:0;z-index:0}
/* Same background treatment as the Refer-a-Business hero (.rb-bg): brand-navy
   tint instead of neutral black, for a consistent look across the two photo heroes. */
.contact-hero .bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.94) saturate(1.06) contrast(1.02)}
.contact-hero .bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(100deg,rgba(11,33,56,.93) 0%,rgba(11,33,56,.86) 38%,rgba(11,33,56,.6) 52%,rgba(11,33,56,.46) 62%,rgba(11,33,56,.8) 100%),
    linear-gradient(180deg,rgba(11,33,56,.5) 0%,rgba(11,33,56,0) 34%,rgba(11,33,56,.42) 100%)}
.contact-hero .wrap{position:relative;z-index:2;width:100%}
.contact-split{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(34px,5.5vw,88px);align-items:center}
.cx-intro h1{font-size:clamp(2.4rem,1.6vw+3.2vh,4.4rem);margin-top:clamp(10px,1.6vh,18px)}
.cx-intro .lead{margin:clamp(12px,2vh,22px) 0 0;max-width:40ch}
.cx-intro .cinfo{margin-top:clamp(20px,3.4vh,40px)}
.contact-hero .cinfo .row{padding:clamp(11px,1.7vh,20px) 0}
.contact-hero .cinfo .row:first-child{padding-top:0}
.contact-hero .cinfo .v{font-size:clamp(1.06rem,.5vw+1vh,1.28rem)}
/* form panel, glass so inputs stay legible over the photo. 2-col grid keeps the
   panel short enough to sit inside one screen; wide controls span both columns. */
.cx-form{background:rgba(11,33,56,.55);border:1px solid var(--line-d);border-radius:4px;
  backdrop-filter:blur(8px) saturate(1.05);-webkit-backdrop-filter:blur(8px) saturate(1.05);
  padding:clamp(20px,2.6vh,30px) clamp(20px,2.4vw,32px);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(9px,1.5vh,16px) clamp(14px,1.5vw,22px);align-content:start}
.cx-form .full{grid-column:1/-1}
.cx-form .field{margin-bottom:0}
.cx-form .field label{margin-bottom:clamp(4px,.7vh,7px)}
.cx-form .field input,.cx-form .field select{padding-top:clamp(9px,1.2vh,13px);padding-bottom:clamp(9px,1.2vh,13px)}
.cx-form .field textarea{min-height:clamp(58px,7vh,92px);padding-top:clamp(9px,1.2vh,13px);padding-bottom:clamp(9px,1.2vh,13px)}
.cx-form #sendBtn{margin-top:clamp(2px,.6vh,7px);width:100%;justify-content:center}
.cx-form #formMsg{margin-top:0;min-height:0}
.cx-form .tr-note{margin-top:clamp(6px,1vh,12px);font-size:.72rem;line-height:1.45;color:var(--muted-d)}
@media(max-width:860px){
  .contact-hero{align-items:flex-start;padding-top:clamp(92px,12vh,120px)}
  .contact-split{grid-template-columns:1fr;gap:clamp(22px,3vh,34px);align-items:stretch}
  .cx-intro h1{font-size:clamp(2.1rem,8vw,3rem)}
  .cx-intro .lead{margin-top:clamp(10px,1.6vh,16px)}
  .cx-intro .cinfo{margin-top:clamp(14px,2.2vh,24px)}
  .contact-hero .cinfo .row{padding:clamp(8px,1.3vh,14px) 0}
  .cx-form{grid-template-columns:1fr}
  .cx-form .field textarea{min-height:clamp(54px,8vh,92px)}
  .map-cue{display:none}
}
/* short viewports: drop the forced single-screen so the panel can never clip, let it flow and scroll */
@media(max-height:760px){
  .contact-hero{min-height:0;align-items:flex-start;padding-top:clamp(84px,11vh,108px)}
  .map-cue{display:none}
}
/* cue at the foot of the first screen, points to the office map below */
.map-cue{position:absolute;left:50%;bottom:clamp(14px,2.4vh,28px);transform:translateX(-50%);z-index:2;
  display:inline-flex;flex-direction:column;align-items:center;gap:10px;
  font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:#a6b7c4;transition:color .3s var(--ease)}
.map-cue:hover{color:var(--bronze-l)}
.map-cue .vln{width:1px;height:clamp(24px,4vh,38px);position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--bronze-l),transparent)}
.map-cue .vln::after{content:"";position:absolute;inset:0;background:var(--bronze-l);animation:sweepv 2.6s var(--ease) infinite}
@keyframes sweepv{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}
.cactions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.field{margin-bottom:20px}
.field label{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze-l);margin-bottom:9px}
.field input,.field textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line-d);border-radius:2px;
  padding:14px 16px;color:var(--paper);font-family:var(--sans);font-size:.96rem;transition:.3s var(--ease)}
.field input::placeholder,.field textarea::placeholder{color:#7f8d9a}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--bronze);background:rgba(99,150,200,.06)}
.field textarea{resize:vertical;min-height:118px}
#formMsg{font-size:.86rem;color:var(--bronze-l);margin-top:12px;min-height:18px;line-height:1.5}
/* refer-a-business form: 2-col grid + styled select */
.ref-form{max-width:760px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(16px,2.4vw,26px)}
.form-grid .field.full{grid-column:1/-1}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.field select{width:100%;background-color:rgba(255,255,255,.04);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9'%3E%3Cpath d='M1 1l6 6 6-6' fill='none' stroke='%231d5c9b' stroke-width='1.6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
  border:1px solid var(--line-d);border-radius:2px;padding:14px 42px 14px 16px;color:var(--paper);
  font-family:var(--sans);font-size:.96rem;transition:.3s var(--ease);-webkit-appearance:none;appearance:none;cursor:pointer}
.field select:focus{outline:none;border-color:var(--bronze);background-color:rgba(99,150,200,.06)}
.field select option{color:var(--ink);background:var(--paper)}
/* refer-business: fit the whole form within one viewport on any screen height.
   Spacing + type scale with viewport HEIGHT (vh/svh) so short screens compress instead of scrolling. */
.ref-fit{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(76px,11vh,116px) 0 clamp(26px,5vh,52px)}
.ref-intro{max-width:62ch;margin:0 auto clamp(16px,3.4vh,40px);text-align:center}
.ref-fit .h-sec{font-size:clamp(1.6rem,1.7vw+1.6vh,3rem);line-height:1.05;margin-top:clamp(8px,1.4vh,16px)}
.ref-fit .lead{font-size:clamp(.95rem,.55vw+.9vh,1.2rem);line-height:1.5;margin:clamp(8px,1.5vh,16px) auto 0}
.ref-fit .field{margin-bottom:clamp(9px,1.7vh,18px)}
.ref-fit .field label{margin-bottom:clamp(4px,.8vh,9px)}
.ref-fit .field input,.ref-fit .field select{padding-top:clamp(9px,1.25vh,14px);padding-bottom:clamp(9px,1.25vh,14px)}
.ref-fit .field textarea{min-height:clamp(56px,9vh,118px);padding-top:clamp(9px,1.25vh,14px);padding-bottom:clamp(9px,1.25vh,14px)}
.ref-fit #sendBtn{margin-top:clamp(4px,1vh,12px)}
/* keep the form two-up even on phones so it stays within the fold */
@media(max-width:560px){.ref-fit .form-grid{grid-template-columns:1fr 1fr;gap:0 14px}}

/* ============ CONTACT MAP ============ */
.map-sec{position:relative;height:clamp(360px,54vw,560px);background:var(--ink-2);overflow:hidden;isolation:isolate}
.map-canvas{position:absolute;inset:0;background:#e6ebef}
.map-img{width:100%;height:100%;object-fit:cover;object-position:50% 42%;display:block}
.map-card{position:absolute;z-index:600;left:var(--gut);bottom:clamp(20px,4vw,40px);
  max-width:min(340px,calc(100% - var(--gut) * 2));
  background:rgba(11,33,56,.92);backdrop-filter:blur(10px) saturate(1.1);-webkit-backdrop-filter:blur(10px) saturate(1.1);
  border:1px solid var(--line-d);border-radius:4px;padding:clamp(20px,2.4vw,26px) clamp(22px,2.4vw,28px);
  color:var(--paper);box-shadow:0 24px 60px rgba(11,33,56,.42);
  transition:transform .45s var(--ease),border-color .45s var(--ease)}
.map-card:hover{transform:translateY(-3px);border-color:rgba(99,150,200,.5)}
.map-addr{display:block;font-family:var(--serif);font-size:1.12rem;line-height:1.45;margin:14px 0 16px}
.map-dir{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;color:var(--bronze-l)}
.map-dir .arr{transition:transform .45s var(--ease)}
.map-card:hover .map-dir .arr{transform:translate(3px,-3px)}
/* Leaflet chrome toned to the brand */
.leaflet-container{font-family:var(--sans);background:#e6ebef}
.leaflet-bar a,.leaflet-bar a:hover{background:var(--paper);color:var(--ink);border-bottom-color:var(--line)}
.leaflet-bar a:hover{background:#fff}
.leaflet-bar{border:1px solid var(--line);box-shadow:0 8px 24px rgba(11,33,56,.18)}
.leaflet-control-attribution{background:rgba(255,255,255,.78)!important;color:var(--muted)!important;font-size:10px}
.leaflet-control-attribution a{color:var(--bronze-d)!important}
.map-pin{filter:drop-shadow(0 6px 10px rgba(11,33,56,.35))}
/* contact map: fill the viewport so clicking the "map" cue lands on the map alone */
#map-sec{height:100vh;height:100svh;scroll-margin-top:0}
#map-sec .leaflet-top{top:clamp(84px,11vh,96px)}
/* return cue on the full-screen map, back up to the contact form */
.map-up{position:absolute;left:50%;top:clamp(88px,12vh,112px);transform:translateX(-50%);z-index:600;
  display:inline-flex;align-items:center;gap:9px;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink);background:rgba(255,255,255,.88);border:1px solid var(--line);border-radius:999px;
  padding:9px 18px 9px 16px;box-shadow:0 6px 18px rgba(11,33,56,.14);
  backdrop-filter:blur(6px) saturate(1.1);-webkit-backdrop-filter:blur(6px) saturate(1.1);
  transition:color .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease)}
.map-up:hover{color:var(--bronze-d);border-color:rgba(29,92,155,.5);transform:translateX(-50%) translateY(-2px)}
.map-up .arr{font-size:1.1em;line-height:1;transition:transform .3s var(--ease)}
.map-up:hover .arr{transform:translateY(-2px)}

/* ============ BLOG / INSIGHTS ============ */
.cat-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(34px,4vw,52px)}
.cat-filter button{font:inherit;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  color:var(--muted);background:none;border:1px solid var(--line);border-radius:2px;padding:9px 16px;cursor:pointer;transition:.35s var(--ease)}
.cat-filter button:hover{border-color:rgba(29,92,155,.5);color:var(--bronze-d)}
.cat-filter button.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px)}
.post{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:3px;background:var(--paper);
  overflow:hidden;transition:transform .5s var(--ease),border-color .5s var(--ease)}
.post:hover{border-color:rgba(29,92,155,.5);transform:translateY(-4px)}
.post .pmedia{aspect-ratio:16/10;background:var(--ink-2);position:relative;overflow:hidden}
.post .pmedia img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.post:hover .pmedia img{transform:scale(1.05)}
.post .pbody{padding:clamp(20px,2vw,28px);display:flex;flex-direction:column;flex:1}
.post .ptag{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze-d);font-weight:600;margin-bottom:13px}
.post h3{font-size:clamp(1.18rem,1.5vw,1.4rem);line-height:1.22}
.post .pexc{font-size:.95rem;color:var(--muted);font-weight:300;margin-top:12px;line-height:1.6;flex:1}
.post .pmeta{font-size:.73rem;color:var(--muted-d);letter-spacing:.02em;margin-top:20px;display:flex;gap:14px;align-items:center}
.post.hide{display:none}
@media(max-width:860px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.posts{grid-template-columns:1fr}}

/* ============ FOOTER ============ */
footer{position:relative;background:var(--ink-2);color:var(--paper);padding:clamp(36px,3.6vw,56px) 0 20px;overflow:hidden}
/* hairline accent along the very top edge */
footer::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.09) 22%,rgba(255,255,255,.09) 78%,transparent)}
.foot-top{display:grid;grid-template-columns:1.7fr 1.5fr 1fr 1.2fr;gap:clamp(28px,3.4vw,56px);padding-bottom:clamp(26px,3vw,38px)}
.foot-top>div:first-child{max-width:38ch}
.foot-top .brand{color:var(--paper);margin-bottom:22px}
.foot-top .brand-logo{height:30px}
.foot-top .desc{font-size:.95rem;color:#9fb0be;font-weight:300;line-height:1.75;max-width:36ch}
.foot-col h4{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze-l);margin-bottom:13px;font-weight:600}
/* links: no layout-shift on hover — an animated bronze underline hugs the text instead */
.foot-col a{position:relative;display:block;width:max-content;max-width:100%;color:#c4d1db;font-size:.92rem;padding:4px 0;line-height:1.25;transition:color .35s var(--ease)}
.foot-col a::after{content:"";position:absolute;left:0;bottom:3px;width:0;height:1px;background:var(--bronze-l);transition:width .4s var(--ease)}
.foot-col a:hover{color:#fff}
.foot-col a:hover::after{width:100%}
/* Navigate (2nd column) flows into 2 balanced columns so its links don't drive the footer height */
.foot-top .foot-col:nth-of-type(2){column-count:2;column-gap:clamp(22px,2.2vw,42px)}
.foot-top .foot-col:nth-of-type(2) h4{column-span:all}
.foot-top .foot-col:nth-of-type(2) a{break-inside:avoid}
/* "Perguntas Frequentes / FAQ", kept in footer but intentionally small & discreet (hidden-in-plain-sight SEO hub) */
footer .foot-col a[href$="perguntas-frequentes.html"],
footer .foot-col a[href$="faq.html"]{font-size:.74rem;color:#76838f;opacity:.9;letter-spacing:.01em}
footer .foot-col a[href$="perguntas-frequentes.html"]:hover,
footer .foot-col a[href$="faq.html"]:hover{color:var(--bronze-l);opacity:1}
/* Contact column: address block + emphasised email */
.foot-col .static{display:block;color:#9fb0be;font-size:.9rem;font-weight:300;padding:10px 0 0;line-height:1.6}
.foot-top .foot-col:last-child a[href^="mailto"]{color:#e7edf2}
.foot-bot{display:flex;justify-content:space-between;align-items:center;margin-top:clamp(16px,2vw,24px);padding-top:clamp(16px,1.8vw,22px);border-top:1px solid var(--line-d);flex-wrap:wrap;gap:14px;
  font-size:.74rem;color:#7f8d9a;letter-spacing:.04em}
/* small "back to top" trail at the very foot of the page */
.to-top{display:flex;flex-direction:column;align-items:center;gap:6px;width:max-content;
  margin:clamp(14px,2vw,22px) auto 0;font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;
  color:#7f8d9a;transition:color .3s var(--ease)}
.to-top:hover{color:var(--bronze-l)}
.to-top .vln{width:1px;height:18px;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--bronze-l),transparent)}
.to-top .vln::after{content:"";position:absolute;inset:0;background:var(--bronze-l);animation:sweepup 2.6s var(--ease) infinite}
@keyframes sweepup{0%{transform:translateY(100%)}60%,100%{transform:translateY(-100%)}}

/* ============ REVEAL ============ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(24px)}
  .reveal.in{opacity:1;transform:none;transition:opacity .95s var(--ease),transform .95s var(--ease)}
  .reveal[data-d="1"].in{transition-delay:.07s}
  .reveal[data-d="2"].in{transition-delay:.16s}
  .reveal[data-d="3"].in{transition-delay:.26s}
  .reveal[data-d="4"].in{transition-delay:.37s}
  .reveal[data-d="5"].in{transition-delay:.48s}
}
/* Touch devices: cancel decorative hover transforms so a tap can't leave a
   card "stuck" lifted/zoomed (these effects stay on real pointer devices). */
@media (hover:none){
  .media:hover img{transform:none}
  .svc:hover h3{transform:none}
  .svc-numbered .svc:hover .ix{transform:none}
  .svc.has-go:hover .go{transform:none}
  .person:hover .ava{transform:none}
  .person:hover .ava img{transform:scale(1)}
  .person:hover .ava span{transform:none}
  .brand:hover .mark{transform:none}
  .brand:hover .brand-logo{transform:none}
  .project:hover .project-media img{transform:none}
}
/* respect reduced-motion: stop decorative infinite "sweep" trails + use instant anchor scrolls */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .map-cue .vln::after,.to-top .vln::after{animation:none}
}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  nav .lk,nav .cta,nav .lk-drop{display:none}
  .burger{display:flex;justify-content:center;min-height:44px}
  /* compact dropdown panel anchored top-right, does NOT take over the whole screen */
  nav.open{position:fixed;top:66px;right:14px;left:auto;bottom:auto;
    width:min(290px,calc(100vw - 28px));max-height:calc(100dvh - 84px);overflow-y:auto;
    background:var(--ink);color:var(--paper);border:1px solid rgba(99,150,200,.16);border-radius:12px;
    box-shadow:0 26px 64px rgba(0,0,0,.5);display:flex;flex-direction:column;align-items:stretch;gap:1px;
    padding:10px;z-index:999;animation:navPop .32s var(--ease) both}
  @keyframes navPop{from{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:none}}
  nav.open .lk,nav.open .cta{display:block;font-size:.98rem;letter-spacing:.1em;padding:13px 14px;opacity:.92;
    text-align:left;border-radius:7px;transition:background .25s var(--ease)}
  nav.open .lk:hover,nav.open .cta:hover{background:rgba(99,150,200,.1)}
  nav.open .lk:first-child{margin-left:0}
  nav.open .lk::after{display:none}
  nav.open .cta{margin:6px 0 0;border:1px solid var(--bronze);color:var(--bronze-l);text-align:center}
  nav.open .lk-drop{display:flex;flex-direction:column;align-items:stretch;gap:0}
  nav.open .lk-parent .caret{display:none}
  nav.open .drop-menu{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;box-shadow:none;padding:0 0 2px 10px;min-width:0}
  nav.open .drop-menu::before{display:none}
  nav.open .drop-menu a{font-size:.9rem;letter-spacing:.08em;padding:9px 12px;opacity:.72;color:var(--paper);display:block;text-align:left;border-radius:6px}
  nav.open .drop-menu a:hover{background:rgba(99,150,200,.1)}
  /* mega menu inside the dark mobile panel: drop the white card, keep heading + description on dark */
  nav.open .drop-menu.mega{width:auto;background:none;box-shadow:none;border:none;padding:0 0 2px 8px}
  nav.open .drop-menu.mega a{display:grid;grid-template-columns:1fr 30px;column-gap:10px;padding:10px;border-radius:7px;color:var(--paper)}
  nav.open .drop-menu.mega a + a{border-top:none}
  nav.open .drop-menu.mega .dd-h{font-size:.95rem;color:var(--paper)}
  nav.open .drop-menu.mega .dd-desc{font-size:.76rem;color:var(--muted-d);margin-top:3px}
  nav.open .drop-menu.mega .dd-go{width:28px;height:28px;border-color:var(--line-d);color:var(--bronze-l);font-size:.82rem}
  nav.open .drop-menu.mega a:hover{background:rgba(99,150,200,.1)}
  nav.open .drop-menu.mega a:hover .dd-h{transform:none;color:var(--paper)}
  nav.open .drop-menu.mega a:hover .dd-go{background:transparent;border-color:var(--line-d);color:var(--bronze-l);transform:none}
  /* dim + lock the rest of the page behind the panel */
  body.nav-open{overflow:hidden}
  body.nav-open::before{content:"";position:fixed;inset:0;z-index:998;background:rgba(8,24,42,.5);
    backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:navFade .32s var(--ease) both}
  @keyframes navFade{from{opacity:0}to{opacity:1}}
  .grid2,.svc-intro,.tr-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .who-media,.tr-media{aspect-ratio:16/10}
  .values{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .adv-grid{grid-template-columns:repeat(3,1fr)}
  .lead-card{grid-template-columns:200px 1fr}
  .svc.has-go{grid-template-columns:1fr}
  .svc-numbered .svc.has-go{grid-template-columns:48px 1fr}
  .svc.has-go .desc,.svc.has-go .items,.svc.has-go .go{grid-column:1/-1}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .svc{grid-template-columns:1fr}
  .svc-static.svc-numbered .svc{grid-template-columns:56px 1fr}
  .svc-numbered .svc.has-go{grid-template-columns:40px 1fr}
  .svc .items,.svc .desc{grid-column:1/-1}
  .smItem{grid-template-columns:1fr;gap:5px}
  .smItem:hover{padding-left:0}
  .team-grid,.adv-grid{grid-template-columns:repeat(2,1fr)}
  .hero-metrics{gap:26px}
  .lead-card{grid-template-columns:1fr}
  .lead-card .ava{width:200px}
  .foot-top{grid-template-columns:1fr}
  .foot-top .foot-col:nth-of-type(2){column-count:1}
  .figure{font-size:clamp(3.6rem,20vw,5rem)}
  .statgrid{grid-template-columns:1fr 1fr;gap:30px 24px}
  .proj-grid{grid-template-columns:1fr;gap:44px}
  .proj-rail .project{flex-basis:84vw}
}

/* ============ I18N / LANGUAGE ============ */
html[lang="en"] .lang-pt{display:none!important}
html[lang="pt"] .lang-en{display:none!important}
.langtog{display:inline-flex;align-items:center;gap:7px;margin-left:18px;flex:none;line-height:1}
.langtog button{background:none;border:0;cursor:pointer;color:inherit;font-family:var(--sans);
  font-size:.7rem;letter-spacing:.13em;font-weight:600;opacity:.5;padding:6px 2px;line-height:1;
  transition:opacity .3s var(--ease),color .3s var(--ease)}
.langtog button:hover{opacity:.82}
.langtog button.on{opacity:1;color:var(--bronze-l)}
.langtog .sep{opacity:.32;font-size:.62rem;user-select:none}
@media(max-width:980px){
  .langtog{margin-left:auto;margin-right:14px;gap:8px}
  /* larger, finger-friendly tap targets on touch screens (was ~24px) */
  .langtog button{font-size:.82rem;padding:11px 10px;min-height:44px;
    display:inline-flex;align-items:center;justify-content:center}
  nav.open .langtog{margin:8px 4px 2px;order:9;justify-content:flex-start}
  nav.open .langtog button{font-size:.95rem;padding:8px 12px}
}

/* ============ SUB-SERVICE → REFER A BUSINESS (services modal) ============ */
.svc-modal .smPickHint{font-size:.78rem;letter-spacing:.02em;color:var(--bronze-d);font-weight:500;
  display:flex;align-items:center;gap:10px;margin:22px 0 12px}
.svc-modal .smPickHint::before{content:"";width:24px;height:1px;background:var(--bronze);flex:none}
.svc-modal .smItem[role="link"]{cursor:pointer}
.svc-modal .smItem[role="link"] h4{display:inline-flex;align-items:center;gap:10px}
.svc-modal .smItem[role="link"] h4::after{content:"→";font-family:var(--sans);font-weight:500;font-size:.82em;
  color:var(--bronze);opacity:0;transform:translateX(-5px);
  transition:opacity .4s var(--ease),transform .4s var(--ease)}
.svc-modal .smItem[role="link"]:hover,.svc-modal .smItem[role="link"]:focus-visible{
  background:linear-gradient(90deg,rgba(29,92,155,.09),transparent 72%);outline:none}
.svc-modal .smItem[role="link"]:hover h4::after,
.svc-modal .smItem[role="link"]:focus-visible h4::after{opacity:1;transform:none}
.svc-modal .smItem[role="link"]:focus-visible{box-shadow:inset 0 0 0 2px rgba(29,92,155,.5);border-radius:3px}

/* ============ REFER, SERVICES-OF-INTEREST PICKER ============ */
.svc-field{position:relative}
.svc-field .msel{position:relative}
.msel-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-d);border-radius:2px;
  padding:14px 16px;color:var(--paper);font-family:var(--sans);font-size:.96rem;line-height:1.3;
  text-align:left;cursor:pointer;transition:.3s var(--ease)}
.ref-fit .msel-btn{padding-top:clamp(9px,1.25vh,14px);padding-bottom:clamp(9px,1.25vh,14px)}
.msel-btn:hover{border-color:rgba(99,150,200,.5)}
.msel-btn:focus-visible,.msel-btn[aria-expanded="true"]{outline:none;border-color:var(--bronze);background:rgba(99,150,200,.06)}
.msel-val{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msel-val.is-ph{color:#7f8d9a}
.msel-caret{flex:none;width:14px;height:9px;transition:transform .3s var(--ease);
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9'%3E%3Cpath d='M1 1l6 6 6-6' fill='none' stroke='%231d5c9b' stroke-width='1.6'/%3E%3C/svg%3E") no-repeat center/contain}
.msel-btn[aria-expanded="true"] .msel-caret{transform:rotate(180deg)}
.msel-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:50;
  width:min(620px,calc(100vw - 40px));max-height:min(82vh,660px);overflow:auto;
  background:#0f2b47;border:1px solid var(--line-d);border-radius:5px;
  box-shadow:0 26px 64px rgba(11,33,56,.55);padding:clamp(16px,1.8vh,22px) clamp(18px,1.8vw,24px)}
.msel-pop.up{top:auto;bottom:calc(100% + 6px)}
.msel-pop[hidden]{display:none}
.msel-pop::-webkit-scrollbar{width:9px}
.msel-pop::-webkit-scrollbar-thumb{background:var(--line-d);border-radius:9px}
.msel-pop .svc-pick{display:grid;grid-template-columns:1fr 1fr;gap:clamp(10px,1.3vh,16px) clamp(24px,2.6vw,40px)}
@media(max-width:620px){.msel-pop{width:min(420px,calc(100vw - 32px))}.msel-pop .svc-pick{grid-template-columns:1fr}}
.svc-field .svc-pick-note{font-size:.8rem;color:var(--bronze-l);font-weight:300;line-height:1.5;margin:10px 0 0}
.svc-field .spg{border:0;margin:0;padding:0;min-width:0}
.svc-field .spg-title{display:block;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--bronze-l);opacity:.85;margin:0 0 6px;padding:0}
.svc-field .svc-opt{display:flex;align-items:flex-start;gap:11px;cursor:pointer;position:relative;
  margin:0;padding:5px 0;font-size:.92rem;font-weight:300;letter-spacing:normal;text-transform:none;
  color:#c4d1db;line-height:1.4;transition:color .25s var(--ease)}
.svc-field .svc-opt:hover{color:var(--paper)}
.svc-field .svc-opt input{position:absolute;opacity:0;width:1px;height:1px;margin:0;padding:0}
.svc-field .svc-box{flex:none;width:18px;height:18px;margin-top:1px;border:1px solid var(--line-d);border-radius:4px;
  background:rgba(255,255,255,.04);display:grid;place-items:center;transition:.22s var(--ease)}
.svc-field .svc-box::after{content:"";width:5px;height:9px;margin-top:-2px;border:solid #fff;
  border-width:0 2px 2px 0;transform:rotate(45deg) scale(0);transition:transform .2s var(--ease)}
.svc-field .svc-opt input:checked + .svc-box{background:var(--bronze);border-color:var(--bronze)}
.svc-field .svc-opt input:checked + .svc-box::after{transform:rotate(45deg) scale(1)}
.svc-field .svc-opt input:focus-visible + .svc-box{outline:2px solid var(--bronze-l);outline-offset:2px}

/* ============ LARGE-SCREEN READABILITY CAPS ============ */
/* The fluid --maxw grows to ~1920px on big/27" screens. Cap a few otherwise-unbounded
   blocks so their lines/rows stay comfortable. Each cap only engages once its container
   exceeds it, so screens <=1500px (the 1240px column) are completely unaffected. */
.hero-metrics{max-width:920px}        /* keep the metrics row anchored under the hero text */
#about .statement{max-width:26ch}     /* keep the mission statement at ~24ch serif lines (index only; news.html statement untouched) */
.svc .desc{max-width:62ch}            /* service descriptions: comfortable ~62ch instead of ~90ch when the row is wide */

/* ============ NEWS ARTICLE (generated post pages) ============ */
.art-meta{display:flex;flex-wrap:wrap;gap:9px 16px;align-items:center;margin-top:22px;
  font-size:.8rem;letter-spacing:.03em;color:var(--muted)}
.on-dark .art-meta,.pagehead .art-meta,.hero .art-meta,.contact-hero .art-meta{color:var(--muted-d)}
.post .pmeta .dot,.art-meta .dot{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.5;flex:none}
.article-body{max-width:70ch;margin:0 auto}
.article-body > *:first-child{font-size:clamp(1.12rem,1.5vw,1.32rem);line-height:1.66;color:var(--muted);font-weight:300;margin-bottom:1.4em}
.article-body p{font-size:clamp(1.01rem,1.2vw,1.12rem);line-height:1.78;font-weight:300;color:var(--text);margin:0 0 1.3em}
.article-body h2{font-family:var(--serif);font-weight:600;letter-spacing:-.02em;
  font-size:clamp(1.4rem,2.1vw,1.85rem);line-height:1.14;color:var(--text);margin:1.75em 0 .5em}
.article-body blockquote{margin:1.7em 0;padding:2px 0 2px 26px;border-left:2px solid var(--bronze);
  font-family:var(--serif);font-style:normal;font-weight:400;line-height:1.4;color:var(--bronze-d);
  font-size:clamp(1.2rem,1.8vw,1.5rem)}
.article-body blockquote cite{display:block;margin-top:14px;font-family:var(--sans);font-style:normal;
  font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-d)}
.art-listen{max-width:70ch;margin:clamp(30px,3.6vw,48px) auto 0;padding-top:clamp(22px,2.6vw,30px);
  border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.art-listen .ll{font-size:.69rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--bronze-d);margin-right:4px}
.art-listen .btn{padding:11px 20px;font-size:.7rem}
.art-back-wrap{max-width:70ch;margin:clamp(30px,3.4vw,44px) auto 0}
.art-back{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;color:var(--bronze-d)}
.art-back .arr{transition:transform .45s var(--ease)}
.art-back:hover .arr{transform:translateX(-5px)}

/* Taller news cards, show more of each photo so heads/subjects aren't cropped out */
.post .pmedia{aspect-ratio:4/3}

/* ============ PREMIUM INTERACTIONS (Bain-inspired) ============ */
/* hero backdrop, slow cinematic Ken Burns drift (premium, ambient motion) */
@media (prefers-reduced-motion:no-preference){
  .hero .bg img{animation:kenburns 26s var(--ease) infinite alternate;will-change:transform}
  @keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.13) translate3d(0,-2.5%,0)}}
}

/* sub-page banners, gentle scroll parallax (JS sets --py; scale guarantees full cover) */
.pagehead .bg img{transform:translate3d(0,var(--py,0),0) scale(1.16);will-change:transform}

/* magnetic CTAs add an inline transform via JS, keep its easing smooth + elastic */
.btn{will-change:transform}

/* ============ HOME, INTERACTIVE PLATFORM EXPLORER ============ */
.pf{display:grid;grid-template-columns:.94fr 1.06fr;gap:clamp(30px,4.4vw,72px);align-items:start;margin-top:clamp(8px,1vw,16px)}
.pf-tabs{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.pf-tab{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(15px,1.9vw,26px);
  width:100%;text-align:left;background:none;border:0;border-bottom:1px solid var(--line);cursor:pointer;
  padding:clamp(19px,2.3vw,29px) 4px;color:inherit;font:inherit;transition:padding .5s var(--ease),background .5s var(--ease)}
.pf-tab::before{content:"";position:absolute;left:0;top:-1px;bottom:-1px;width:2px;background:var(--bronze);
  transform:scaleY(0);transform-origin:center;transition:transform .55s var(--ease)}
.pf-tab .pf-ix{font-family:var(--serif);font-size:1.05rem;color:var(--bronze-d);transition:color .5s var(--ease),transform .5s var(--ease)}
.pf-tab .pf-name{display:block;font-family:var(--serif);font-size:clamp(1.35rem,2.05vw,1.95rem);line-height:1.1;
  letter-spacing:-.02em;transition:color .4s var(--ease),transform .5s var(--ease)}
.pf-tab .pf-tag{display:block;margin-top:7px;font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted);font-weight:500;transition:color .4s var(--ease)}
.pf-tab .pf-arr{flex:none;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;
  color:var(--bronze-d);opacity:0;transform:translateX(-6px) rotate(-20deg);transition:.5s var(--ease)}
.pf-tab .pf-arr svg{width:15px;height:15px}
.pf-tab:hover .pf-name{color:var(--bronze-d)}
.pf-tab:hover .pf-ix{transform:translateX(2px)}
.pf-tab.is-active{background:linear-gradient(90deg,rgba(29,92,155,.07),transparent 64%);padding-left:clamp(16px,1.6vw,24px)}
.pf-tab.is-active::before{transform:scaleY(1)}
.pf-tab.is-active .pf-ix{color:var(--bronze)}
.pf-tab.is-active .pf-name{color:var(--bronze-d);transform:translateX(2px)}
.pf-tab.is-active .pf-tag{color:var(--bronze-d)}
.pf-tab.is-active .pf-arr{opacity:1;transform:none;background:var(--ink);border-color:var(--ink);color:var(--paper)}
.pf-tab:focus-visible{outline:2px solid var(--bronze-d);outline-offset:-2px}

.pf-stage{position:relative}
.pf-panel{display:grid;gap:clamp(20px,2.2vw,28px)}
.pf-panel[hidden]{display:none}
.pf-media{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:16/10;background:var(--ink-2)}
.pf-media img{width:100%;height:100%;object-fit:cover}
.pf-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(160deg,rgba(17,49,82,.04),rgba(11,33,56,.46))}
.pf-badge{position:absolute;left:20px;bottom:17px;z-index:2;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;
  color:#d3e0ea;display:flex;align-items:center;gap:10px;font-weight:600}
.pf-badge::before{content:"";width:22px;height:1px;background:var(--bronze-l)}
.pf-lead{font-size:clamp(1.05rem,1.35vw,1.24rem);font-weight:300;line-height:1.6;color:var(--text);max-width:52ch}
.pf-items{display:flex;flex-wrap:wrap;gap:9px}
.pf-items>span{font-size:.76rem;letter-spacing:.01em;padding:7px 14px;border:1px solid var(--line);
  border-radius:999px;color:#44535e}
.pf-panel .txtlink{align-self:start}
@media (prefers-reduced-motion:no-preference){
  .pf-panel.is-active{animation:pfIn .6s var(--ease) both}
  @keyframes pfIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
  .pf-panel.is-active .pf-media img{animation:pfZoom 1.1s var(--ease) both}
  @keyframes pfZoom{from{transform:scale(1.06)}to{transform:scale(1)}}
}
@media(max-width:860px){
  .pf{grid-template-columns:1fr;gap:clamp(24px,5vw,38px)}
  .pf-tab .pf-arr{display:none}
  .pf-tab{grid-template-columns:auto 1fr}
}
@media (hover:none){.pf-tab.is-active .pf-name,.pf-tab.is-active .pf-ix,.pf-tab:hover .pf-ix{transform:none}}

/* ============ NEWS MODAL (reuses the .svc-modal shell) ============ */
.svc-modal.news-modal .panel{padding:0;width:min(780px,100%)}
.news-modal .nm-hero{aspect-ratio:4/3;background:var(--ink-2);overflow:hidden;border-radius:4px 4px 0 0}
.news-modal .nm-hero img{width:100%;height:100%;object-fit:cover;object-position:center top}
.news-modal .nm-inner{padding:clamp(26px,4.4vw,54px)}
.news-modal .nm-title{font-family:var(--serif);font-weight:600;letter-spacing:-.02em;line-height:1.08;
  font-size:clamp(1.7rem,3.4vw,2.6rem);margin:16px 0 0;color:var(--text)}
.news-modal .art-meta{margin-top:16px}
.news-modal .article-body{max-width:none;margin-top:clamp(22px,2.8vw,32px);padding-top:clamp(22px,2.8vw,32px);border-top:1px solid var(--line)}
.news-modal .art-listen{max-width:none}
.news-modal .nm-cta{margin-top:clamp(24px,3vw,34px);padding-top:clamp(20px,2.4vw,28px);border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:16px 26px;align-items:center}
.post{cursor:pointer}
@media(max-width:560px){.news-modal .nm-hero{aspect-ratio:4/3}}

/* ============ HERO, GEOMETRIC · single full-bleed photo per slide ============ */
.hero-geo .hero-canvas{position:absolute;inset:0;z-index:0;overflow:hidden;background:var(--ink-2)}
.hero-main{position:absolute;inset:0;z-index:0}
.hero-geo .hp-img{opacity:0;transition:opacity 2.4s var(--ease),transform 2.4s var(--ease);will-change:transform;backface-visibility:hidden}
.hero-geo .hp-img.is-on{opacity:1}
.hero-main .hp-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%;
  transform:scale(1.04)}
/* per-photo framing so the subject is never cut badly */
.hero-main .hp-img:nth-child(1){object-position:50% 46%}  /* 25 de Abril bridge */
.hero-main .hp-img:nth-child(2){object-position:50% 32%}  /* Farol da Barra, Aveiro, keep lantern + tower */
.hero-main .hp-img:nth-child(3){object-position:50% 55%}  /* Elétrico 28, Baixa — keep the tram in frame */
.hero-main .hp-img:nth-child(4){object-position:50% 46%}  /* Praça do Comércio at night */
/* neutral darkening only where text sits (left + bottom), no blue cast, no diagonal facet */
.hero-canvas::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,.34) 34%,rgba(0,0,0,0) 58%),
    linear-gradient(180deg,rgba(0,0,0,.34) 0%,rgba(0,0,0,0) 22%,rgba(0,0,0,.1) 58%,rgba(0,0,0,.82) 100%)}
/* cinematic Ken Burns, restarts each time a photo becomes active so the zoom is deterministic.
   Direction (zin/zout) is set per appearance in JS so each photo alternates in/out.
   Tight scale band (1.04–1.10) keeps the cross-fade between photos gentle; min-scale > max-pan so an edge never shows. */
@media (prefers-reduced-motion:no-preference){
  .hero-main .hp-img.is-on{animation:hbIn 14s cubic-bezier(.42,0,.58,1) forwards}
  .hero-main .hp-img.is-on.zout{animation-name:hbOut}
  @keyframes hbIn{from{transform:scale(1.04) translate3d(-.8%,.8%,0)}  to{transform:scale(1.10) translate3d(.8%,-.9%,0)}}
  @keyframes hbOut{from{transform:scale(1.10) translate3d(.8%,-.9%,0)}to{transform:scale(1.04) translate3d(-.8%,.8%,0)}}
}
/* (slide-indicator dots removed, no longer needed) */
@media(max-width:860px){
  .hero-canvas::after{background:
    linear-gradient(90deg,rgba(0,0,0,.66),rgba(0,0,0,.34) 56%,rgba(0,0,0,.4)),
    linear-gradient(180deg,rgba(0,0,0,.34),rgba(0,0,0,.08) 30%,rgba(0,0,0,.84))}
}

/* ============ STATS BAND ON DARK (home "By the Numbers") ============ */
.on-dark .statgrid{border-top-color:var(--line-d)}
.on-dark .stat .sv{color:var(--paper)}
.on-dark .stat .sv small{color:var(--bronze-l)}
.on-dark .stat .sl{color:var(--muted-d)}

/* ============ HOME, TEAM RAIL (horizontal carousel) ============ */
.team-rail{display:flex;gap:clamp(16px,1.8vw,24px);overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:14px;scrollbar-width:none;-ms-overflow-style:none}
.team-rail::-webkit-scrollbar{display:none}
.team-rail .person{flex:0 0 clamp(186px,21vw,236px);scroll-snap-align:start}
.team-rail .person .ava{aspect-ratio:4/5;border-radius:3px;margin-bottom:14px}
.rail-nav{display:flex;gap:10px}
.rail-nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:transparent;
  cursor:pointer;display:grid;place-items:center;color:var(--ink);transition:.4s var(--ease)}
.rail-nav button:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.rail-nav button svg{width:18px;height:18px}
.rail-nav button[disabled]{opacity:.32;cursor:default}
.rail-nav button[disabled]:hover{background:transparent;color:var(--ink);border-color:var(--line)}
@media(max-width:560px){.team-rail .person{flex-basis:64vw}}

/* ============================================================
   TEAM PROFILE PAGES  (team/<slug>.html)
   ============================================================ */
/* Hero */
.pf-hero{position:relative;overflow:hidden;background:var(--ink-2);color:var(--paper);padding:clamp(116px,16vw,188px) 0 clamp(56px,8vw,100px)}
.pf-hero .bg{position:absolute;inset:0;z-index:0;opacity:.14}
.pf-hero .bg img{width:100%;height:100%;object-fit:cover}
.pf-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,33,56,.55),rgba(11,33,56,.94))}
.pf-hero .wrap{position:relative;z-index:2}
.pf-grid{display:grid;grid-template-columns:300px 1fr;gap:clamp(34px,5vw,76px);align-items:center}
.pf-photo{position:relative;align-self:start}
.pf-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 16%;border-radius:3px;position:relative;z-index:1}
.pf-photo::before{content:"";position:absolute;inset:20px -20px -20px 20px;border:2px solid var(--blue);border-radius:3px;z-index:0}
.pf-meta h1{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.7rem);line-height:1.02;letter-spacing:-.02em;margin-top:14px}
.pf-meta .role{font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;color:var(--bronze-l);font-weight:600;margin-top:14px}
.pf-meta .pf-intro{margin-top:22px;max-width:56ch;color:#cdd9e2;font-weight:300;font-size:1.06rem;line-height:1.62}
.pf-meta .award{display:inline-flex;align-items:center;gap:9px;margin-top:20px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze-l)}
.pf-meta .award::before{content:"";width:18px;height:1px;background:var(--blue)}
.pf-actions{display:flex;flex-wrap:wrap;gap:14px 26px;align-items:center;margin-top:30px}
.pf-actions .pf-mail{color:#cdd9e2;font-size:.95rem;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:3px;transition:.3s var(--ease)}
.pf-actions .pf-mail:hover{color:#fff;border-color:#fff}
/* About */
.pf-about .pf-cols{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.6fr);gap:clamp(28px,5vw,80px);align-items:start}
.pf-about h2{font-family:var(--serif);font-size:clamp(1.8rem,3.2vw,2.7rem);color:var(--navy);letter-spacing:-.02em}
.pf-about h2 i{font-style:normal;color:var(--bronze-d)}
.pf-bio p{color:var(--muted);font-size:1.07rem;line-height:1.78;font-weight:300}
.pf-bio p + p{margin-top:1.1em}
.pf-facts{margin-top:34px;display:grid;gap:0}
.pf-fact{border-top:1px solid var(--line);padding:14px 0}
.pf-fact .k{font-size:.71rem;letter-spacing:.13em;text-transform:uppercase;color:var(--bronze-d);font-weight:600}
.pf-fact .v{margin-top:6px;color:var(--ink);font-weight:300}
/* Experience timeline */
.pf-exp h2{font-family:var(--serif);font-size:clamp(1.8rem,3.2vw,2.7rem);color:var(--navy);text-align:center;margin-bottom:clamp(42px,5vw,66px)}
.pf-tl{max-width:760px;margin:0 auto;position:relative;padding-left:36px}
.pf-tl::before{content:"";position:absolute;left:9px;top:7px;bottom:7px;width:2px;background:var(--line)}
.pf-item{position:relative;padding-bottom:clamp(34px,4vw,52px)}
.pf-item:last-child{padding-bottom:0}
.pf-item::before{content:"";position:absolute;left:-36px;top:3px;width:20px;height:20px;border-radius:50%;background:var(--paper-2);border:3px solid var(--navy);box-shadow:0 0 0 4px var(--paper-2)}
.pf-period{font-style:italic;font-size:.82rem;color:var(--bronze-d);font-weight:600}
.pf-role-t{font-family:var(--serif);font-size:1.22rem;color:var(--navy);margin-top:6px;letter-spacing:-.01em}
.pf-desc{margin-top:9px;color:var(--muted);font-weight:300;line-height:1.7}
/* Back link */
.pf-back{display:inline-flex;align-items:center;gap:8px;color:var(--bronze-d);font-size:.85rem;letter-spacing:.04em;margin-top:clamp(40px,5vw,60px)}
.pf-back:hover{color:var(--navy)}
/* Clickable team cards */
a.person{display:block;color:inherit;text-decoration:none}
a.lead-card{color:inherit;text-decoration:none}
.pf-more{margin-top:11px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze-d);display:inline-flex;align-items:center;gap:7px;opacity:0;transform:translateY(4px);transition:.4s var(--ease)}
.person:hover .pf-more,.lead-card:hover .pf-more{opacity:1;transform:none}
.lead-card.is-link:hover{border-color:rgba(29,92,155,.4)}
@media(max-width:820px){
  .pf-grid{grid-template-columns:1fr;gap:30px}
  .pf-photo{max-width:300px}
  .pf-photo::before{inset:14px -14px -14px 14px}
  .pf-about .pf-cols{grid-template-columns:1fr;gap:20px}
}

/* ============================================================
   TEAM GRID, polished cards with lighthouse mark
   ============================================================ */
.team-grid{grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,28px)}
a.person{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:clamp(15px,1.3vw,20px);color:inherit;text-decoration:none;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
a.person:hover{transform:translateY(-5px);border-color:rgba(29,92,155,.35);box-shadow:0 22px 55px -30px rgba(11,33,56,.5)}
.pf-card-ph{position:relative;margin-bottom:20px}
.pf-card-ph::before{content:"";position:absolute;inset:12px -12px -12px 12px;border:1.5px solid var(--blue);border-radius:3px;z-index:0;opacity:.45;
  transition:inset .5s var(--ease),opacity .5s var(--ease)}
a.person:hover .pf-card-ph::before{opacity:.9;inset:9px -9px -9px 9px}
.pf-card-ph .ava{position:relative;z-index:1;aspect-ratio:4/5;border-radius:3px;margin:0}
a.person:hover .pf-card-ph .ava{transform:none}
a.person h3{font-size:1.12rem;font-weight:600;letter-spacing:-.01em;color:var(--navy);line-height:1.2}
a.person .role{font-size:.8rem;color:var(--muted);margin-top:5px;font-weight:400;line-height:1.4;text-transform:none;letter-spacing:0}
.pf-cta{display:inline-flex;align-items:center;gap:7px;margin-top:auto;padding-top:14px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze-d);font-weight:600}
.pf-cta span[aria-hidden]{transition:transform .4s var(--ease)}
a.person:hover .pf-cta{color:var(--blue)}
a.person:hover .pf-cta span[aria-hidden]{transform:translateX(4px)}
/* lead card (Gonçalo): frame the photo, keep its horizontal layout */
a.lead-card{color:inherit;text-decoration:none}
a.lead-card .pf-card-ph{margin-bottom:0}
a.lead-card .pf-card-ph .ava{aspect-ratio:4/5}
a.lead-card .pf-card-ph::before{inset:10px -10px -10px 10px;opacity:.5}
a.lead-card:hover .pf-card-ph::before{opacity:.95;inset:8px -8px -8px 8px}
.lead-card .pf-cta{margin-top:18px}
/* advisory board reuses .person card styling */
@media(max-width:1080px){.team-grid,.adv-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.team-grid,.adv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.team-grid,.adv-grid{grid-template-columns:1fr}}

/* ============================================================
   REFER A BUSINESS, split layout, background, carousels
   ============================================================ */
.rb{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--ink-2);color:var(--paper);
  padding:clamp(78px,9vh,100px) 0 clamp(18px,3vh,32px)}
.rb-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.rb-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 50%;opacity:1;filter:brightness(.94) saturate(1.06) contrast(1.02)}
.rb-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(11,33,56,.93) 0%,rgba(11,33,56,.86) 38%,rgba(11,33,56,.6) 52%,rgba(11,33,56,.46) 62%,rgba(11,33,56,.8) 100%),
  linear-gradient(180deg,rgba(11,33,56,.5) 0%,rgba(11,33,56,0) 34%,rgba(11,33,56,.42) 100%)}
.rb-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,80px);align-items:center}
.rb-left{display:flex;flex-direction:column;gap:clamp(10px,1.6vh,18px);min-width:0;text-shadow:0 1px 2px rgba(0,0,0,.45)}
.rb-head .eyebrow{color:var(--bronze-l)}
.rb-h1{font-family:var(--serif);font-size:clamp(1.75rem,2.9vw,2.6rem);margin-top:6px;letter-spacing:-.02em;line-height:1.02}
.rb-intro{margin-top:8px;color:#c2d0db;font-weight:300;font-size:clamp(.9rem,.98vw,1.02rem);line-height:1.46;max-width:48ch}
.rb-car-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.rb-car-bar .eyebrow{color:var(--bronze-l)}
.rb-car-nav{display:flex;gap:9px}
.rb-arrow{width:34px;height:34px;border:1px solid var(--line-d);border-radius:50%;background:transparent;color:var(--paper);
  font-size:1.15rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.3s var(--ease)}
.rb-arrow:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-1px)}
.rb-car-title{font-family:var(--serif);font-size:clamp(1.15rem,1.6vw,1.55rem);margin:5px 0 8px;letter-spacing:-.02em}
.rb-car-vp{overflow:hidden}
.rb-car-track{display:flex;transition:transform .55s var(--ease);will-change:transform}
.rb-slide{flex:0 0 100%;min-width:100%;box-sizing:border-box;padding-right:2px}
.rb-slide .vn{font-family:var(--serif);font-size:1rem;color:var(--bronze-l);font-weight:600;letter-spacing:.06em}
.rb-slide h3{font-size:clamp(1rem,1.2vw,1.18rem);margin-top:4px;color:var(--paper)}
.rb-slide p{margin-top:6px;color:#bdccd9;font-weight:300;font-size:.9rem;line-height:1.44;max-width:46ch}
.rb-dots{display:flex;gap:7px;margin-top:9px}
.rb-dots button{width:7px;height:7px;border-radius:50%;border:0;background:var(--line-d);cursor:pointer;padding:0;transition:.35s var(--ease)}
.rb-dots button[aria-current="true"]{background:var(--bronze-l);width:22px;border-radius:4px}
.rb-right{min-width:0}
.rb-form-head{margin-bottom:clamp(7px,1.2vh,12px)}
.rb-form-head .eyebrow{color:var(--bronze-l)}
.rb-h2{font-family:var(--serif);font-size:clamp(1.35rem,2vw,1.9rem);margin-top:6px;letter-spacing:-.02em}
.rb-right .ref-form{max-width:none;margin:0;background:rgba(11,33,56,.55);border:1px solid var(--line-d);border-radius:4px;
  backdrop-filter:blur(8px) saturate(1.05);-webkit-backdrop-filter:blur(8px) saturate(1.05);
  padding:clamp(15px,2vh,24px) clamp(16px,2vw,26px)}
.rb-right .ref-form .form-grid{gap:0 clamp(14px,1.5vw,22px)}
.rb-right .ref-form label{margin-bottom:clamp(4px,.7vh,7px)}
.rb-right .ref-form .field{margin-bottom:clamp(8px,1.4vh,14px)}
.rb-right .ref-form .field input,.rb-right .ref-form .field select{padding-top:clamp(8px,1.15vh,12px);padding-bottom:clamp(8px,1.15vh,12px)}
.rb-right .ref-form textarea{min-height:clamp(56px,6.5vh,84px)}
.rb-right .ref-form #sendBtn{margin-top:clamp(4px,1vh,10px);width:100%;justify-content:center}
@media(max-width:1024px){
  .rb{min-height:0;padding-top:clamp(100px,16vh,130px);align-items:flex-start}
  .rb-inner{grid-template-columns:1fr;gap:clamp(34px,6vw,52px)}
}

/* ===== News ticker, scrolling strip directly below the hero ===== */
.ticker{position:relative;z-index:3;display:flex;align-items:stretch;
  background:var(--ink-2);color:#cdd9e2;font-family:var(--sans);
  border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.07);
  box-shadow:0 1px 0 rgba(0,0,0,.25)}
.ticker-lead{flex:none;display:flex;align-items:center;gap:9px;
  padding:0 clamp(15px,1.8vw,24px);background:var(--blue);color:#fff;text-decoration:none;
  font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;
  position:relative;z-index:2;transition:background .35s var(--ease)}
.ticker-lead:hover{background:var(--bronze-d)}
.ticker-lead::after{content:"";position:absolute;top:0;right:-14px;bottom:0;width:14px;
  background:linear-gradient(90deg,var(--ink-2),transparent);pointer-events:none}
.ticker-pulse{width:8px;height:8px;border-radius:50%;background:#fff;flex:none;
  box-shadow:0 0 0 0 rgba(255,255,255,.55);animation:tkPulse 2.4s var(--ease) infinite}
.ticker-vp{flex:1;min-width:0;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%)}
.ticker-track{display:flex;width:max-content;animation:tkScroll 56s linear infinite}
.ticker:hover .ticker-track,.ticker:focus-within .ticker-track{animation-play-state:paused}
.ticker-seq{display:flex;align-items:center;flex:none}
.tk-item{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;text-decoration:none;
  color:#c4d2dd;font-size:.82rem;letter-spacing:.005em;
  padding:11px clamp(14px,1.5vw,20px);transition:color .3s var(--ease)}
.tk-item:hover{color:#fff}
.tk-txt{transition:color .3s var(--ease)}
.tk-arr{color:var(--bronze-l);font-size:.78rem;transition:transform .3s var(--ease),color .3s var(--ease)}
.tk-item:hover .tk-arr{transform:translate(2px,-2px);color:#fff}
.tk-dot{flex:none;width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.22)}
.tk-forbes{color:#fff}
.tk-badge{flex:none;font-weight:700;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:#0b2138;background:var(--bronze-l);padding:3px 8px;border-radius:3px;line-height:1}
.tk-forbes .tk-arr{color:#fff}
/* ── Publication wordmark logos, monochrome, inherit currentColor so they adapt to light/dark ── */
.plogo{font-style:normal;display:inline-block;line-height:1;white-space:nowrap;vertical-align:baseline;text-transform:none}
.plogo-forbes{font-family:"Didot","Didot LT STD","Bodoni 72","Bodoni MT",Georgia,"Times New Roman",serif;font-weight:700;letter-spacing:-.005em}
.plogo-veco{font-family:Georgia,"Iowan Old Style","Times New Roman",serif;font-weight:700;letter-spacing:-.01em}
.plogo-fdi{font-family:var(--sans);font-weight:600;letter-spacing:.005em}
.plogo-fdi b{font-weight:800;letter-spacing:.04em}
.plogo-ie{font-family:var(--sans);font-weight:500;letter-spacing:.01em}
.plogo-ie b{font-weight:800;letter-spacing:.02em}
.plogo-eco{font-family:var(--sans);font-weight:800;letter-spacing:.06em}
.plogo-je{font-family:Georgia,"Iowan Old Style","Times New Roman",serif;font-weight:700;letter-spacing:-.01em}
.plogo-idealista{font-family:var(--sans);font-weight:700;letter-spacing:-.02em;text-transform:lowercase}
.plogo-di{font-family:Georgia,"Iowan Old Style","Times New Roman",serif;font-weight:600;letter-spacing:0}
.plogo-nit{font-family:var(--sans);font-weight:800;letter-spacing:-.01em}
/* ticker logo badge, replaces the old text pill on press items */
.tk-plogo{flex:none;color:#fff;font-size:1rem}
/* in small uppercase eyebrows (award chips, post tags) enlarge the wordmark so letterforms read as a logo */
.award .plogo,.ptag .plogo{font-size:1.28em;position:relative;top:.03em}
.ptag .plogo{color:var(--ink)}
/* ── "Na Imprensa" press-logo marquee, outlets that covered Harbor, scrolling loop, each linked ── */
.presslogos{display:flex;align-items:stretch;position:relative;z-index:3;
  background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.presslogos-lab{flex:none;display:inline-flex;align-items:center;
  padding:0 clamp(18px,2.4vw,34px);
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--bronze-d)}
.presslogos-lab::after{content:"";width:26px;height:1px;background:var(--bronze);margin-left:14px}
.pl-vp{flex:1;min-width:0;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.pl-track{display:flex;width:max-content;animation:tkScroll 42s linear infinite}
/* keep the marquee scrolling continuously, no pause on hover (it read as a freeze) */
.pl-seq{display:flex;align-items:center;flex:none}
.presslogo{flex:none;display:inline-flex;align-items:center;text-decoration:none;color:var(--ink);opacity:.55;
  padding:16px clamp(26px,3.4vw,52px);
  transition:opacity .3s var(--ease),color .3s var(--ease)}
.presslogo:hover,.presslogo:focus-visible{opacity:1;color:var(--bronze-d)}
.presslogo .plogo{font-size:1.5rem}
.presslogo .plogo-fdi{font-size:1.25rem}
.presslogo .plogo-ie{font-size:1.3rem}
.presslogo .plogo-eco{font-size:1.5rem}
.presslogo .plogo-je{font-size:1.18rem}
.presslogo .plogo-idealista{font-size:1.35rem}
.presslogo .plogo-di{font-size:1.12rem}
.presslogo .plogo-nit{font-size:1.5rem}
@media(max-width:560px){
  .presslogos-lab{padding:0 14px}
  .presslogos-lab::after{margin-left:10px;width:16px}
  .presslogo{padding:13px 24px}
  .presslogo .plogo{font-size:1.2rem}
  .presslogo .plogo-fdi{font-size:1rem}
  .presslogo .plogo-ie{font-size:1.05rem}
  .presslogo .plogo-eco{font-size:1.2rem}
  .presslogo .plogo-je{font-size:.95rem}
  .presslogo .plogo-idealista{font-size:1.08rem}
  .presslogo .plogo-di{font-size:.92rem}
  .presslogo .plogo-nit{font-size:1.2rem}
}
@media(prefers-reduced-motion:reduce){
  .pl-track{animation:none;width:auto}
  .pl-seq[aria-hidden="true"]{display:none}
  .pl-vp{overflow-x:auto;scrollbar-width:none}
  .pl-vp::-webkit-scrollbar{display:none}
}
@keyframes tkScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes tkPulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}70%{box-shadow:0 0 0 9px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
@media(max-width:560px){
  .ticker-lead{font-size:0;gap:0;padding:0 14px}
  .ticker-lead .lang-en,.ticker-lead .lang-pt{display:none}
  .tk-item{font-size:.78rem;padding:10px 14px}
}
@media(prefers-reduced-motion:reduce){
  .ticker-track{animation:none;width:auto}
  .ticker-seq[aria-hidden="true"]{display:none}
  .ticker-vp{overflow-x:auto;scrollbar-width:none}
  .ticker-vp::-webkit-scrollbar{display:none}
  .ticker-pulse{animation:none}
}

/* ============ FIXED TEAM-PHOTO BACKDROP (liquid glass) ============ */
/* A single fixed, blurred, blue-tinted team photo painted behind the whole page
   (z-index:-1 → above the white canvas, below all content). It is revealed ONLY
   through the translucent navy sections (.sec.dark) and the footer. app.js fades it
   in while a navy section is in the viewport and out otherwise, so the team photo
   "appears and disappears" as you scroll while the image itself stays fixed.
   To use the real photo: replace assets/img/team-group.jpg (same filename). */
.team-bg{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:var(--ink-2);            /* navy base, keeps text legible while photo is faded out */
}
/* the team photo, SHARP (no blur). Fades in while a navy section is in view.
   Uses team-group-home.jpg (full people, tall crop) everywhere — the older wide team-group.jpg
   already had the feet cropped and, in the shorter inner navy bands, cut heads/bodies.
   center 30% keeps whole faces (no half-heads) in the shorter bands revealed on inner pages. */
.team-bg::before{
  content:"";position:absolute;inset:-2vh -2vw;
  background:url("img/team-group-home.jpg") center 30%/cover no-repeat;
  filter:brightness(.96) saturate(1.06);
  /* nudge the backdrop down on every inner page so the navy bands never clip the
     team's heads (this is the framing approved on the Track Record page) */
  transform:translateY(70px);
  opacity:0;transition:opacity 1.05s cubic-bezier(.22,.61,.36,1);
  will-change:opacity;
}
.team-bg.on::before{opacity:1}
/* homepage only: tighter crop, framed on the group (~45%) so the full-viewport navy
   bands show heads AND feet without cropping either on wide/short screens */
body.home .team-bg::before{background-image:url("img/team-group-home.jpg");background-position:center 22%;transform:none}
/* homepage navy bands ("Em Números" + manifesto): fill the viewport and centre their
   content so the fixed team photo bleeds edge-to-edge — no white neighbour section
   peeking as a band top/bottom while a navy section is in view */
body.home #numbers,body.home #manifesto,body.home main>.sec.dark.on-dark:not([id]){min-height:100vh;min-height:100svh;display:flex;align-items:center}
/* "Em Números" gets its own opaque night-shot backdrop (the fixed team photo now appears
   ONLY in the manifesto band) — dark image + navy wash keeps the white stats legible */
body.home #numbers{background:linear-gradient(rgba(11,33,56,.72),rgba(11,33,56,.78)),url("img/praca-comercio-noite.jpg") center/cover no-repeat}
body.home #numbers>.wrap,body.home #manifesto>.wrap,body.home main>.sec.dark.on-dark:not([id])>.wrap{width:100%}
/* The last navy band (the id-less "Our Mission" CTA) sits directly above the footer, so the
   shared centre-45% backdrop lets the footer clip the team's feet as the band scrolls up.
   On desktop, give THIS band its own viewport-fixed crop framed lower (center 72%) so heads
   AND feet both clear the footer while it's in view. Mobile keeps the shared contain backdrop. */
@media (min-width:641px){
  body.home main>.sec.dark.on-dark:not([id]){
    background-color:var(--ink-2);
    background-image:linear-gradient(rgba(11,33,56,.5),rgba(11,33,56,.58)),url("img/av-liberdade-aerial.jpg");
    background-size:cover;
    background-position:center,center;
    background-repeat:no-repeat;
    background-attachment:fixed;
  }
}
/* mobile: same aerial image (non-fixed) so the band never falls back to the team photo */
@media (max-width:640px){
  body.home main>.sec.dark.on-dark:not([id]){
    background-color:var(--ink-2);
    background-image:linear-gradient(rgba(11,33,56,.5),rgba(11,33,56,.58)),url("img/av-liberdade-aerial.jpg");
    background-size:cover;background-position:center;background-repeat:no-repeat;
  }
}
/* subtle brand-blue wash over the photo (the "blue filter") */
.team-bg::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 14%,rgba(29,92,155,.16),transparent 62%);
}
@media (prefers-reduced-motion:reduce){.team-bg::before{transition:none}}
/* phones: show the WHOLE team (contain) instead of the centre few (cover would over-crop a wide
   group photo on a narrow screen). Navy base fills the letterbox. Desktop/tablet unaffected. */
@media (max-width:640px){
  .team-bg::before{background-size:contain;background-position:center center;transform:none}
}

/* ===== Track Record · filterable grid (W3) ===== */
.tr-filter{display:flex;flex-wrap:wrap;gap:10px;margin:clamp(26px,3vw,44px) 0 clamp(28px,3.4vw,46px)}
.tr-chip{font:inherit;cursor:pointer;padding:9px 18px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.8rem;letter-spacing:.01em;font-weight:500;line-height:1;transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease)}
.tr-chip:hover{border-color:rgba(29,92,155,.5);color:var(--ink)}
.tr-chip:focus-visible{outline:2px solid var(--bronze);outline-offset:2px}
.tr-chip.is-active{background:var(--ink-2);border-color:var(--ink-2);color:var(--paper)}
.tr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,26px)}
@media (max-width:920px){.tr-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.tr-grid{grid-template-columns:1fr}}
.tr-card{position:relative;display:block;aspect-ratio:3/2;border-radius:11px;overflow:hidden;text-decoration:none;color:#fff;background:var(--ink-2);box-shadow:0 12px 34px rgba(11,33,56,.12);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.tr-card>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.tr-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,25,45,0) 32%,rgba(9,25,45,.5) 60%,rgba(9,25,45,.92));transition:background .45s var(--ease)}
.tr-card:hover{transform:translateY(-6px);box-shadow:0 30px 62px rgba(11,33,56,.26)}
.tr-card:hover>img{transform:scale(1.05)}
.tr-card:hover::after{background:linear-gradient(180deg,rgba(9,25,45,.12),rgba(9,25,45,.72) 52%,rgba(9,25,45,.96))}
.tr-badge{position:absolute;top:13px;left:13px;z-index:3;font-size:.57rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;color:#fff;background:rgba(11,33,56,.6);border:1px solid rgba(255,255,255,.2);padding:5px 10px;border-radius:5px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.tr-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(15px,1.5vw,20px)}
.tr-title{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}
.tr-title h3{color:#fff;margin:0;font-size:clamp(1.05rem,1.45vw,1.3rem);line-height:1.15;letter-spacing:-.01em}
.tr-fig{color:#a9c8ea;font-weight:700;font-size:clamp(.86rem,1.15vw,1.02rem);white-space:nowrap;letter-spacing:.01em}
.tr-extra{color:rgba(255,255,255,.86)}
.tr-extra-in{min-height:0;overflow:hidden}
.tr-val{margin:0;font-size:.88rem;line-height:1.5;font-weight:300}
.tr-news{display:inline-flex;align-items:center;gap:7px;margin-top:9px;font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#fff}
.tr-news .arr{transition:transform .45s var(--ease)}
.tr-card:hover .tr-news .arr{transform:translateX(5px)}
.tr-card[hidden]{display:none}
.tr-note{margin-top:clamp(32px,4vw,52px);font-size:.92rem;font-style:italic;color:var(--muted);max-width:70ch}
@media (hover:hover){
  .tr-extra{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows .5s var(--ease),opacity .4s var(--ease),margin .5s var(--ease)}
  .tr-card:hover .tr-extra,.tr-card:focus-within .tr-extra{grid-template-rows:1fr;opacity:1;margin-bottom:10px}
}

/* Track Record · department groups (no filter) */
.tr-group{margin-top:clamp(40px,4.6vw,66px)}
.tr-group:first-of-type{margin-top:clamp(22px,2.4vw,32px)}
.tr-group-title{display:flex;align-items:center;gap:15px;margin:0 0 clamp(18px,2vw,26px);font-size:clamp(1.12rem,1.5vw,1.4rem);font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.tr-group-title::before{content:"";width:26px;height:2px;background:var(--bronze);flex:none}
.tr-group-title::after{content:"";flex:1;height:1px;background:var(--line)}

/* ===== Legal footer block + legal pages (RGPD / DL 7-2004 compliance) ===== */
.foot-legal{border-top:1px solid rgba(255,255,255,.09);margin-top:clamp(22px,2.6vw,30px);padding-top:clamp(16px,2vw,22px);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px 28px}
.foot-legal-links{display:flex;flex-wrap:wrap;gap:8px 20px}
.foot-legal-links a{font-size:.8rem;color:#c4d1db;letter-spacing:.01em;transition:color .35s var(--ease)}
.foot-legal-links a:hover{color:var(--bronze-l)}
.foot-legal-id{width:100%;font-size:.72rem;line-height:1.6;color:#76838f;margin-top:2px}
.legal{max-width:74ch;margin:0 auto}
.legal h2{font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.2;margin:clamp(30px,4vw,46px) 0 12px}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{font-size:1rem;line-height:1.72;color:var(--muted);font-weight:300}
.legal p{margin-bottom:13px}
.legal ul{padding-left:20px;margin:0 0 15px}
.legal li{margin-bottom:6px}
.legal strong{color:var(--ink);font-weight:600}
.legal a{color:var(--bronze-d);text-decoration:underline;text-underline-offset:2px}
.legal .upd{font-size:.82rem;color:var(--muted);margin-bottom:18px}
.legal .flag{background:rgba(197,138,60,.09);border-left:3px solid var(--bronze-d);padding:12px 16px;border-radius:0 3px 3px 0;font-size:.9rem;color:var(--ink);margin:0 0 20px}

.form-privacy{font-size:.78rem;line-height:1.55;color:var(--muted);margin:16px 0 0}
.on-dark .form-privacy{color:#9fb0be}
.form-privacy a{color:var(--bronze-d);text-decoration:underline;text-underline-offset:2px}
.on-dark .form-privacy a{color:var(--bronze-l)}
