
:root {
  --ink: #111827;
  --muted: #617086;
  --navy: #061827;
  --navy-2: #0a2940;
  --navy-3: #134967;
  --blue: #136783;
  --cream: #f6efe2;
  --cream-2: #ede2ce;
  --paper: #fffaf0;
  --surface: #ffffff;
  --gold: #d6b45d;
  --gold-2: #f1d886;
  --line: rgba(17,24,39,.12);
  --soft-line: rgba(255,255,255,.18);
  --shadow: 0 24px 70px rgba(6,24,39,.16);
  --shadow-soft: 0 14px 40px rgba(6,24,39,.10);
  --radius: 26px;
  --max: 1200px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--ink); background: var(--cream); line-height: 1.65; padding-bottom: 0; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--gold); }
p { margin: 0 0 1rem; }
img { max-width: 100%; height: auto; display: block; }
address { font-style: normal; }
.wrap { width: min(100% - 44px, var(--max)); margin: 0 auto; }
.visually-hidden, .skip-link:not(:focus) { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.skip-link:focus { position: fixed; left: 16px; top: 16px; z-index: 1000; background: var(--gold); color: var(--navy); padding: .8rem 1rem; border-radius: 999px; font-weight: 900; }
.site-header { position: sticky; top: 0; z-index: 100; box-shadow: 0 10px 30px rgba(6,24,39,.08); }
.topbar { background: var(--navy); color: rgba(255,255,255,.82); font-size: .92rem; }
.topbar-inner { min-height: 38px; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.topbar-actions { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.topbar a { color: rgba(255,255,255,.86); }
.topbar a:hover { color: var(--gold-2); }
.navbar { background: rgba(255,255,255,.88); backdrop-filter: blur(16px); border-bottom: 1px solid rgba(6,24,39,.08); }
.nav-inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; }
.brand { display: inline-flex; align-items: center; gap: .8rem; min-width: max-content; }
.brand-mark { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 16px; background: linear-gradient(135deg, var(--navy), var(--navy-3)); color: var(--gold-2); font-weight: 950; box-shadow: inset 0 1px 0 rgba(255,255,255,.18); }
.brand-copy strong { display: block; line-height: 1; letter-spacing: .18em; font-size: 1.05rem; }
.brand-copy small { display: block; color: var(--muted); letter-spacing: .04em; font-size: .78rem; margin-top: .25rem; }
.menu { display: flex; align-items: center; gap: .12rem; }
.menu > a, .nav-dropdown > a { display: inline-flex; align-items: center; min-height: 42px; padding: .55rem .82rem; border-radius: 999px; font-weight: 760; color: #243548; }
.menu > a:hover, .nav-dropdown:hover > a, .nav-dropdown:focus-within > a { background: var(--cream); color: var(--navy); }
.nav-cta { background: var(--navy) !important; color: #fff !important; padding-inline: 1rem !important; box-shadow: 0 10px 24px rgba(6,24,39,.18); }
body[data-section="about"] .nav-about, body[data-section="services"] .nav-services > a, body[data-section="team"] .nav-team, body[data-section="blog"] .nav-blog, body[data-section="news"] .nav-news, body[data-section="contact"] .nav-contact { background: var(--cream); color: var(--navy); }
.nav-dropdown { position: relative; }
.mega-menu { position: absolute; right: -180px; top: calc(100% + 14px); width: min(860px, 92vw); display: grid; grid-template-columns: 250px 1fr; gap: 1.2rem; padding: 1rem; background: rgba(255,255,255,.97); border: 1px solid var(--line); border-radius: 28px; box-shadow: var(--shadow); opacity: 0; transform: translateY(-8px); pointer-events: none; transition: .18s ease; }
.nav-dropdown:hover .mega-menu, .nav-dropdown:focus-within .mega-menu { opacity: 1; transform: translateY(0); pointer-events: auto; }
.mega-kicker { color: var(--gold); text-transform: uppercase; letter-spacing: .16em; font-size: .72rem; font-weight: 950; margin: 0 0 .5rem; }
.mega-menu strong { display: block; font-family: Georgia, serif; color: var(--navy); font-size: 1.5rem; line-height: 1.15; }
.mega-links { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .5rem; }
.mega-links a { display: flex; align-items: center; gap: .55rem; padding: .72rem .8rem; border-radius: 16px; color: var(--ink); background: #fff8eb; border: 1px solid rgba(214,180,93,.18); font-weight: 760; }
.mega-links a span { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 10px; background: var(--navy); color: var(--gold-2); }
.nav-toggle { display: none; width: 46px; height: 46px; border: 0; border-radius: 15px; background: var(--navy); padding: 11px; cursor: pointer; }
.nav-toggle i { display: block; height: 2px; background: #fff; margin: 5px 0; border-radius: 999px; }
.eyebrow { color: var(--gold); text-transform: uppercase; letter-spacing: .18em; font-weight: 950; font-size: .76rem; margin: 0 0 .9rem; }
.hero-home { position: relative; overflow: hidden; color: #fff; background: radial-gradient(circle at 16% 10%, rgba(214,180,93,.30), transparent 26%), linear-gradient(135deg, var(--navy), #0b2a42 62%, #061827); }
.hero-home::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 64px 64px; mask-image: linear-gradient(to bottom, black, transparent 72%); }
.hero-grid { position: relative; min-height: 720px; display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; padding: 70px 0; }
.hero-copy h1, .page-hero h1, .split h2, .section-heading h2, .cta-band h2, .rich-text h2, .profile-aside h2, .contact-details h2, .search-main h1 { font-family: Georgia, "Times New Roman", serif; line-height: 1.04; letter-spacing: -.035em; margin: 0 0 1rem; }
.hero-copy h1 { font-size: clamp(3.4rem, 7vw, 7.3rem); max-width: 850px; }
.lead { color: rgba(255,255,255,.82); font-size: clamp(1.05rem, 1.6vw, 1.28rem); max-width: 760px; }
.hero-copy .lead { max-width: 690px; }
.hero-actions, .cta-actions, .center-actions { display: flex; flex-wrap: wrap; gap: .85rem; align-items: center; margin-top: 1.8rem; }
.center-actions { justify-content: center; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; border: 0; border-radius: 999px; padding: .92rem 1.22rem; font-weight: 950; background: var(--gold); color: var(--navy); box-shadow: 0 14px 34px rgba(214,180,93,.28); cursor: pointer; transition: transform .16s ease, box-shadow .16s ease; }
.button:hover { transform: translateY(-2px); color: var(--navy); box-shadow: 0 18px 42px rgba(214,180,93,.36); }
.button.secondary { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.24); box-shadow: none; }
.button.secondary:hover { color: #fff; background: rgba(255,255,255,.18); }
.button.light { background: #fff; color: var(--navy); }
.button.ghost-light { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.34); box-shadow: none; }
.button.full { width: 100%; }
.hero-visual { position: relative; min-height: 560px; }
.hero-photo { position: absolute; inset: 0; border-radius: 38px; overflow: hidden; box-shadow: 0 30px 90px rgba(0,0,0,.34); transform: rotate(1deg); border: 1px solid rgba(255,255,255,.18); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; }
.hero-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(6,24,39,.52), transparent 55%); }
.glass-card { position: absolute; backdrop-filter: blur(18px); background: rgba(255,255,255,.86); color: var(--navy); border: 1px solid rgba(255,255,255,.55); border-radius: 24px; padding: 1rem; box-shadow: 0 22px 60px rgba(0,0,0,.22); }
.glass-card strong { display: block; font-size: 2rem; line-height: 1; }
.glass-card span { display: block; color: var(--muted); font-size: .86rem; margin-top: .28rem; }
.glass-card.one { top: 8%; left: -2%; }
.glass-card.two { right: -1%; top: 43%; }
.glass-card.three { left: 8%; bottom: 8%; }
.trust-strip { position: relative; margin-top: -42px; z-index: 2; }
.trust-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: .8rem; background: rgba(255,255,255,.94); border: 1px solid var(--line); border-radius: 28px; padding: .8rem; box-shadow: var(--shadow); }
.trust-item { padding: 1.1rem; border-radius: 20px; background: linear-gradient(180deg, #fff, #fff8eb); }
.trust-item strong { display: block; color: var(--navy); font-size: 1.3rem; }
.trust-item span { color: var(--muted); font-size: .92rem; }
.section { padding: clamp(68px, 8vw, 110px) 0; }
.tinted { background: #fbf6eb; }
.deep { background: linear-gradient(135deg, #071827, #0e3853); color: rgba(255,255,255,.82); }
.deep h2, .deep h3 { color: #fff; }
.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.split h2, .section-heading h2 { font-size: clamp(2.15rem, 4vw, 4.1rem); color: var(--navy); }
.section-heading { max-width: 850px; margin: 0 auto 2.4rem; text-align: center; }
.section-heading p:not(.eyebrow) { color: var(--muted); font-size: 1.08rem; }
.card-grid, .people-grid, .post-grid, .testimonial-grid, .feature-grid { display: grid; gap: 1.25rem; }
.services-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.people-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.post-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
.service-card, .person-card, .post-card, .contact-details, .contact-form, .side-card, .profile-aside, .testimonial, .feature-card, .search-box, .article-meta { background: rgba(255,255,255,.88); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-soft); }
.reveal-card { transform: translateY(16px); opacity: 0; transition: opacity .5s ease, transform .5s ease, box-shadow .18s ease; }
.reveal-card.is-visible { transform: translateY(0); opacity: 1; }
.service-card { position: relative; overflow: hidden; padding: 1.55rem; min-height: 300px; display: flex; flex-direction: column; }
.service-card::after { content: ''; position: absolute; inset: auto -45px -70px auto; width: 150px; height: 150px; border-radius: 50%; background: rgba(214,180,93,.14); }
.service-card:hover { box-shadow: var(--shadow); }
.service-icon { width: 54px; height: 54px; display: grid; place-items: center; border-radius: 18px; background: linear-gradient(135deg, var(--navy), var(--navy-3)); color: var(--gold-2); font-size: 1.35rem; font-weight: 900; margin-bottom: 1rem; }
.card-kicker { color: #96722b; text-transform: uppercase; letter-spacing: .16em; font-weight: 950; font-size: .7rem; margin: 0 0 .42rem; }
.service-card h3, .post-card h3, .person-card h3, .feature-card h3 { margin: 0 0 .65rem; line-height: 1.16; color: var(--navy); }
.service-card h3, .post-card h3 { font-size: 1.3rem; }
.service-card p, .post-card p, .role, .feature-card p { color: var(--muted); }
.text-link { color: var(--navy); font-weight: 950; margin-top: auto; display: inline-flex; align-items: center; gap: .35rem; }
.text-link::after { content: '\2192'; color: var(--gold); }
.photo-split { align-items: center; }
.image-stack { position: relative; min-height: 520px; }
.image-stack .photo-card { position: absolute; overflow: hidden; border-radius: 32px; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.6); }
.image-stack .photo-card img { width: 100%; height: 100%; object-fit: cover; }
.image-stack .main-photo { inset: 0 12% 12% 0; }
.image-stack .small-photo { right: 0; bottom: 0; width: 42%; height: 48%; }
.pull-card { position: absolute; left: 6%; bottom: 8%; max-width: 280px; background: rgba(255,255,255,.9); color: var(--navy); border-radius: 22px; padding: 1rem; box-shadow: var(--shadow-soft); }
.pull-card strong { display: block; font-size: 1.25rem; }
.check-list { list-style: none; padding: 0; margin: 1.2rem 0 0; display: grid; gap: .65rem; }
.check-list li { display: grid; grid-template-columns: 28px 1fr; gap: .65rem; align-items: start; }
.check-list li::before { content: '\2713'; width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%; background: var(--navy); color: var(--gold-2); font-weight: 950; }
.feature-card { padding: 1.25rem; background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.15); box-shadow: none; }
.feature-card p { color: rgba(255,255,255,.72); }
.feature-card .num { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 14px; background: var(--gold); color: var(--navy); font-weight: 950; margin-bottom: 1rem; }
.person-card { padding: 1.1rem; display: grid; grid-template-columns: 86px minmax(0, 1fr); gap: 1rem; align-items: center; }
.portrait { width: 86px; height: 86px; border-radius: 24px; display: grid; place-items: center; color: #fff; background: radial-gradient(circle at 22% 18%, rgba(241,216,134,.95), rgba(214,180,93,.75) 35%, rgba(6,24,39,.98) 36%, #134967); box-shadow: 0 16px 38px rgba(6,24,39,.20); }
.portrait span { font-weight: 950; letter-spacing: .08em; }
.portrait.large { width: 190px; height: 190px; font-size: 2.3rem; margin: 0 auto 1rem; border-radius: 38px; }
.tags { display: flex; gap: .45rem; flex-wrap: wrap; margin-top: .65rem; }
.tags span { background: #fff5df; border: 1px solid rgba(214,180,93,.28); color: #37475a; border-radius: 999px; padding: .2rem .55rem; font-size: .76rem; font-weight: 850; }
.testimonial-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.testimonial { padding: 1.45rem; background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.15); box-shadow: none; }
.testimonial p { color: rgba(255,255,255,.82); }
.testimonial strong { color: var(--gold-2); }
.post-card { padding: 1.25rem; display: grid; grid-template-columns: 86px 1fr; gap: 1rem; }
.date-pill { width: 78px; height: 78px; border-radius: 20px; background: var(--navy); color: #fff; display: grid; place-items: center; text-align: center; line-height: 1.08; font-size: .78rem; }
.date-pill span { display: block; color: var(--gold-2); font-size: 1.45rem; font-weight: 950; }
.community-strip { position: relative; overflow: hidden; color: #fff; background: linear-gradient(135deg, rgba(6,24,39,.88), rgba(10,41,64,.84)), var(--bg); background-size: cover; background-position: center; }
.community-strip h2 { color: #fff; }
.community-strip p { color: rgba(255,255,255,.82); }
.page-hero { position: relative; overflow: hidden; color: #fff; background: linear-gradient(135deg, var(--navy), var(--navy-3)); padding: clamp(76px, 9vw, 118px) 0; }
.photo-hero { background-image: linear-gradient(90deg, rgba(6,24,39,.90), rgba(6,24,39,.70) 46%, rgba(6,24,39,.18)), var(--hero-img); background-size: cover; background-position: center; }
.page-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 2rem; align-items: end; }
.page-hero h1 { font-size: clamp(2.8rem, 6vw, 5.9rem); max-width: 950px; }
.page-hero-copy .lead { max-width: 780px; }
.hero-meta-card { padding: 1.25rem; border-radius: 24px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); backdrop-filter: blur(14px); }
.hero-meta-card span { display: block; color: var(--gold-2); text-transform: uppercase; letter-spacing: .16em; font-size: .7rem; font-weight: 950; margin-bottom: .45rem; }
.hero-meta-card strong { display: block; font-size: 1.2rem; line-height: 1.2; margin-bottom: .55rem; }
.hero-meta-card p { color: rgba(255,255,255,.78); margin: 0; }
.content-section { background: var(--cream); }
.content-layout { display: grid; grid-template-columns: 320px minmax(0, 1fr); gap: clamp(1.5rem, 5vw, 3.2rem); align-items: start; }
.side-card { padding: 1.35rem; position: sticky; top: 132px; }
.side-card h2 { color: var(--navy); font-size: 1.55rem; }
.side-card p { color: var(--muted); }
.side-card ul { list-style: none; padding: 0; margin: 1rem 0; display: grid; gap: .5rem; }
.side-card li a, .side-card li span { display: block; padding: .72rem .85rem; border-radius: 14px; background: #fff5df; border: 1px solid rgba(214,180,93,.20); font-weight: 820; }
.rich-text { background: rgba(255,255,255,.86); border: 1px solid var(--line); border-radius: calc(var(--radius) + 4px); box-shadow: var(--shadow-soft); padding: clamp(1.45rem, 4vw, 3rem); }
.rich-text p, .rich-text li { font-size: 1.06rem; color: #2d3c4f; }
.rich-text h2 { color: var(--navy); font-size: clamp(1.8rem, 3vw, 2.6rem); margin-top: 2rem; }
.rich-text h3 { color: var(--navy); font-size: 1.25rem; margin: 1.5rem 0 .5rem; }
.content-list { padding-left: 1.35rem; margin: .7rem 0 1.2rem; }
.content-list li + li { margin-top: .42rem; }
blockquote { margin: 1.5rem 0; padding: 1.2rem 1.3rem; border-left: 5px solid var(--gold); background: #fff5df; border-radius: 0 18px 18px 0; }
.archive-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.blog-note { margin-bottom: 1.2rem; background: #fff8e6; border: 1px solid rgba(214,180,93,.35); border-radius: 18px; padding: 1rem 1.1rem; color: #574723; }
.profile-grid { display: grid; grid-template-columns: 330px minmax(0,1fr); gap: 2rem; align-items: start; }
.profile-aside { padding: 1.7rem; text-align: center; position: sticky; top: 132px; }
.profile-aside h2 { color: var(--navy); font-size: 1.75rem; }
.profile-aside .button { margin-top: .7rem; }
.related-section { padding-top: 0; }
.article-layout { display: grid; grid-template-columns: 280px minmax(0,1fr); gap: 2rem; align-items: start; }
.article-meta { position: sticky; top: 132px; padding: 1.25rem; }
.article-meta span { display: block; color: var(--muted); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; font-weight: 950; }
.contact-section { background: #fbf6eb; }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 1.5rem; align-items: start; }
.contact-details, .contact-form { padding: clamp(1.4rem, 4vw, 2.3rem); }
.contact-details h2, .contact-form h2 { color: var(--navy); font-size: clamp(1.8rem, 3vw, 2.6rem); }
.contact-methods { display: grid; gap: .75rem; margin: 1.25rem 0; }
.contact-methods a, .contact-methods p { margin: 0; padding: 1rem; border-radius: 18px; background: #fff5df; border: 1px solid rgba(214,180,93,.24); }
.contact-methods span { display: block; color: var(--muted); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; font-weight: 950; }
.map-panel { min-height: 260px; overflow: hidden; border-radius: 24px; background: #050403; display: grid; align-items: end; padding: 1.2rem; color: #fff; }
.map-panel strong { font-size: 1.2rem; }
.map-panel.bespoke-map {
  position: relative;
  display: block;
  min-height: 340px;
  padding: 0;
  border: 1px solid rgba(216,173,24,.36);
  border-radius: 24px;
  background: #050403;
  box-shadow: 0 24px 70px rgba(0,0,0,.18);
  isolation: isolate;
}
.map-panel.bespoke-map:hover {
  color: #fff;
  border-color: rgba(216,173,24,.70);
}
.bespoke-map-canvas,
.bespoke-map-canvas svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.bespoke-map-canvas svg {
  object-fit: cover;
}
.bespoke-map::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(5,4,3,.06), rgba(5,4,3,.66)),
    radial-gradient(circle at 58% 54%, rgba(216,173,24,.18), transparent 28%);
  pointer-events: none;
}
.bespoke-map-info {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 2;
  display: grid;
  gap: .32rem;
  max-width: 430px;
  padding: 1rem;
  border: 1px solid rgba(216,173,24,.36);
  border-radius: 18px;
  background: rgba(5,4,3,.84);
  box-shadow: 0 16px 45px rgba(0,0,0,.28);
  backdrop-filter: blur(12px);
}
.bespoke-map-info strong {
  font-size: clamp(1.05rem, 1.5vw, 1.32rem);
  line-height: 1.15;
}
.bespoke-map-info span {
  color: rgba(255,255,255,.82);
  line-height: 1.45;
}
.map-kicker,
.bespoke-map-info .map-action {
  color: var(--gold-2);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .72rem;
  font-weight: 950;
}
.bespoke-map-info .map-action {
  margin-top: .2rem;
}
.contact-form { display: grid; gap: .9rem; }
.contact-form label { display: grid; gap: .35rem; color: #33465a; font-weight: 850; }
.contact-form input, .contact-form textarea, .search-box input { width: 100%; border: 1px solid var(--line); border-radius: 16px; padding: .92rem 1rem; font: inherit; background: #fff; color: var(--ink); }
.contact-form input:focus, .contact-form textarea:focus, .search-box input:focus { outline: 3px solid rgba(214,180,93,.24); border-color: var(--gold); }
.form-note, .form-status { color: var(--muted); font-size: .92rem; margin: 0; }
.search-main { padding: clamp(60px, 8vw, 100px) 0; }
.search-main h1 { color: var(--navy); font-size: clamp(2.6rem, 5vw, 4.8rem); }
.search-box { padding: 1.25rem; margin-bottom: 1.2rem; }
.search-results { display: grid; gap: .75rem; }
.search-result { display: block; padding: 1rem; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.86); }
.search-result strong { color: var(--navy); }
.search-result p { color: var(--muted); margin: .15rem 0 0; }
.cta-band { background: linear-gradient(135deg, var(--navy), var(--navy-3)); color: #fff; padding: clamp(58px, 7vw, 84px) 0; }
.cta-inner { display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center; }
.cta-band h2 { color: #fff; font-size: clamp(2rem, 3.3vw, 3.4rem); }
.cta-band p { color: rgba(255,255,255,.80); max-width: 680px; }
.sticky-contact { position: fixed; right: 18px; bottom: 18px; z-index: 90; display: grid; gap: .45rem; }
.sticky-contact a { display: grid; padding: .75rem .9rem; min-width: 176px; background: rgba(6,24,39,.92); color: #fff; border: 1px solid rgba(255,255,255,.16); border-radius: 16px; box-shadow: 0 16px 38px rgba(6,24,39,.28); backdrop-filter: blur(12px); }
.sticky-contact a:hover { color: var(--gold-2); }
.sticky-contact span { color: var(--gold-2); font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 950; }
.sticky-contact strong { font-size: .94rem; }
.site-footer { background: #061724; color: rgba(255,255,255,.76); padding: 62px 0 28px; }
.footer-grid { display: grid; grid-template-columns: 1.1fr 1fr .9fr; gap: 2.2rem; }
.footer-brand { color: #fff; margin-bottom: 1rem; }
.site-footer h2 { color: #fff; font-size: 1.1rem; margin: 0 0 .9rem; }
.footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.footer-links.two-col { grid-template-columns: repeat(2, minmax(0,1fr)); }
.footer-map { display: inline-flex; margin-top: .3rem; color: var(--gold-2); font-weight: 900; }
.footer-bottom { margin-top: 2.2rem; padding-top: 1.25rem; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; gap: 1rem; font-size: .92rem; }
@media (prefers-reduced-motion: reduce) { * { scroll-behavior: auto !important; transition: none !important; } .reveal-card { opacity: 1; transform: none; } }
@media (max-width: 1040px) {
  .topbar-inner { justify-content: center; flex-wrap: wrap; padding: .45rem 0; }
  .topbar-inner > span { display: none; }
  .nav-toggle { display: block; }
  .menu { position: absolute; left: 18px; right: 18px; top: calc(100% + 8px); background: rgba(255,255,255,.98); border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); padding: .75rem; display: none; flex-direction: column; align-items: stretch; max-height: calc(100vh - 128px); overflow: auto; }
  .menu.is-open { display: flex; }
  .menu > a, .nav-dropdown > a { width: 100%; border-radius: 14px; justify-content: flex-start; }
  .nav-dropdown { display: grid; }
  .mega-menu { position: static; width: auto; display: grid; grid-template-columns: 1fr; opacity: 1; transform: none; pointer-events: auto; box-shadow: none; background: #fff7e8; margin: .3rem 0 .6rem; border-radius: 18px; padding: .8rem; }
  .mega-links { grid-template-columns: 1fr; }
  .hero-grid, .split, .page-hero-grid, .content-layout, .profile-grid, .article-layout, .contact-grid, .cta-inner, .footer-grid { grid-template-columns: 1fr; }
  .hero-grid { min-height: auto; }
  .hero-visual { min-height: 440px; }
  .side-card, .profile-aside, .article-meta { position: static; }
  .services-grid, .people-grid, .post-grid, .feature-grid, .archive-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .trust-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .sticky-contact { left: 14px; right: 14px; bottom: 14px; grid-template-columns: repeat(3, 1fr); }
  .sticky-contact a { min-width: 0; text-align: center; padding: .62rem .5rem; }
  body { padding-bottom: 78px; }
}
@media (max-width: 720px) {
  .wrap { width: min(100% - 30px, var(--max)); }
  .brand-copy small { display: none; }
  .hero-grid { padding: 56px 0 74px; }
  .hero-copy h1 { font-size: clamp(2.85rem, 15vw, 4.45rem); }
  .hero-visual { min-height: 340px; }
  .hero-photo { border-radius: 28px; }
  .glass-card strong { font-size: 1.35rem; }
  .glass-card { padding: .75rem; min-width: 120px; }
  .glass-card.two { top: 48%; }
  .trust-strip { margin-top: -28px; }
  .trust-grid, .services-grid, .people-grid, .post-grid, .feature-grid, .archive-grid, .testimonial-grid { grid-template-columns: 1fr; }
  .section { padding: 58px 0; }
  .image-stack { min-height: 390px; }
  .image-stack .main-photo { inset: 0 0 18% 0; }
  .image-stack .small-photo { width: 54%; height: 42%; }
  .pull-card { left: 5%; right: 5%; max-width: none; bottom: 9%; }
  .page-hero { padding: 62px 0; }
  .page-hero h1 { font-size: clamp(2.55rem, 14vw, 4rem); }
  .person-card, .post-card { grid-template-columns: 72px minmax(0,1fr); }
  .portrait, .date-pill { width: 72px; height: 72px; border-radius: 18px; }
  .sticky-contact strong { font-size: .78rem; }
  .sticky-contact span { font-size: .62rem; }
  .footer-links.two-col { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
}


/* V5 premium fix: black/gold Verralls direction + explicit links */
:root{--gold:#d6aa16;--gold-2:#ffd76a;--navy:#050505;--navy-2:#090909;--navy-3:#141414;--cream:#fff7df;--ink:#101010;--muted:#6e6e6e;--line:rgba(214,170,22,.22);--shadow:0 28px 80px rgba(0,0,0,.28);}
body{background:#050505}.topbar{background:#000;border-bottom:1px solid rgba(214,170,22,.22);color:rgba(255,255,255,.78)}.topbar a{color:var(--gold-2)}.navbar{background:rgba(0,0,0,.94);border-bottom:1px solid rgba(214,170,22,.28);backdrop-filter:blur(18px)}.brand-mark{background:#fff;color:#000;border:2px solid var(--gold);box-shadow:0 0 0 3px rgba(214,170,22,.10)}.brand-copy strong{color:#fff}.brand-copy small{color:var(--gold-2)}.menu>a,.nav-dropdown>a{color:#fff}.menu>a:hover,.nav-dropdown:hover>a,.nav-dropdown:focus-within>a{background:rgba(214,170,22,.16);color:#fff}.nav-cta{background:var(--gold)!important;color:#000!important;box-shadow:0 14px 34px rgba(214,170,22,.32)}body[data-section="about"] .nav-about,body[data-section="services"] .nav-services>a,body[data-section="team"] .nav-team,body[data-section="blog"] .nav-blog,body[data-section="news"] .nav-news,body[data-section="contact"] .nav-contact{background:rgba(214,170,22,.20);color:#fff}.mega-menu{background:rgba(6,6,6,.98);border-color:rgba(214,170,22,.28);box-shadow:0 24px 80px rgba(0,0,0,.55)}.mega-menu strong{color:#fff}.mega-links a{background:rgba(255,255,255,.06);border-color:rgba(214,170,22,.18);color:#fff}.mega-links a span{background:var(--gold);color:#000}.hero-home{background:radial-gradient(circle at 80% 30%,rgba(214,170,22,.16),transparent 26%),linear-gradient(135deg,#000,#080808 56%,#14120a);}.team-hero-home .hero-grid{min-height:690px}.team-hero-home .hero-copy h1{font-size:clamp(3.2rem,6.2vw,6.45rem);max-width:820px}.team-hero-home .lead{max-width:670px}.team-hero-home .hero-photo{transform:none;border-radius:26px;border:1px solid rgba(214,170,22,.42);box-shadow:0 34px 100px rgba(0,0,0,.56)}.team-hero-home .hero-photo img{object-position:center center;filter:saturate(.94) contrast(1.06)}.team-hero-home .hero-photo:after{background:linear-gradient(90deg,rgba(0,0,0,.40),transparent 38%),linear-gradient(to top,rgba(0,0,0,.32),transparent 48%)}.glass-card{background:rgba(0,0,0,.72);border:1px solid rgba(214,170,22,.38);color:#fff;box-shadow:0 20px 70px rgba(0,0,0,.48)}.glass-card strong{color:var(--gold-2);font-size:1.45rem}.glass-card span{color:rgba(255,255,255,.75)}.button{background:var(--gold);color:#000}.button:hover{color:#000}.button.secondary{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(214,170,22,.35)}.button.secondary:hover{background:rgba(214,170,22,.18);color:#fff}.trust-strip{background:#050505}.trust-grid{background:rgba(9,9,9,.96);border-color:rgba(214,170,22,.28);box-shadow:0 24px 70px rgba(0,0,0,.45)}.trust-item{background:linear-gradient(180deg,#111,#080808);border:1px solid rgba(214,170,22,.12)}.trust-item strong{color:#fff}.trust-item span{color:#bdbdbd}.tinted{background:#0b0b0b}.tinted .section-heading h2,.tinted .service-card h3,.tinted .post-card h3,.tinted .person-card h3{color:#fff}.tinted .section-heading p:not(.eyebrow),.tinted .service-card p{color:#bcbcbc}.tinted .service-card,.tinted .person-card,.tinted .post-card{background:linear-gradient(180deg,#141414,#080808);border-color:rgba(214,170,22,.18);box-shadow:0 24px 60px rgba(0,0,0,.32)}.service-icon{background:#000;color:var(--gold-2);border:1px solid rgba(214,170,22,.28)}.text-link{color:var(--gold-2)}.deep{background:linear-gradient(135deg,#000,#141006)}.site-footer{background:#000;border-top:1px solid rgba(214,170,22,.28)}.footer-bottom{border-top:1px solid rgba(214,170,22,.16)}
.supplied-photo-note{font-size:.82rem;color:#c9a23a;margin-top:.8rem}
@media(max-width:760px){.team-hero-home .hero-grid{min-height:auto}.team-hero-home .hero-visual{min-height:380px}.glass-card.two{right:4%;top:50%}.glass-card.three{left:4%;bottom:4%}}

/* === V8 professional refinement: calmer premium layout, correct logo, stable menus === */
:root{
  --ink:#15120d;
  --muted:#625a4b;
  --navy:#080705;
  --navy-2:#15110a;
  --navy-3:#2b210f;
  --cream:#f7f0e3;
  --cream-2:#ede0c8;
  --paper:#fffaf0;
  --surface:#ffffff;
  --gold:#cfa315;
  --gold-2:#f0d36b;
  --line:rgba(36,27,8,.13);
  --shadow:0 28px 90px rgba(20,14,3,.18);
  --shadow-soft:0 16px 42px rgba(20,14,3,.10);
  --max:1240px;
}
body{background:var(--cream); color:var(--ink);}
.site-header{box-shadow:0 8px 26px rgba(0,0,0,.15)}
.topbar{background:#060503; border-bottom:1px solid rgba(207,163,21,.35); color:rgba(255,255,255,.86)}
.topbar a{color:#f0d36b}.topbar a:hover{color:#fff}
.navbar{background:rgba(10,8,5,.96); border-bottom:1px solid rgba(207,163,21,.34); backdrop-filter:blur(18px)}
.nav-inner{min-height:74px}.brand-image{gap:0}.brand-image img{height:42px;width:auto;max-width:190px;object-fit:contain}.brand-mark,.brand-copy{display:none!important}
.menu> a,.nav-dropdown>a{color:rgba(255,255,255,.91);font-weight:800}.menu> a:hover,.nav-dropdown:hover>a,.nav-dropdown:focus-within>a{background:rgba(207,163,21,.16);color:#fff}.nav-cta{background:linear-gradient(135deg,#dcb316,#b78908)!important;color:#080705!important;box-shadow:0 12px 30px rgba(207,163,21,.25)}
body[data-section="about"] .nav-about,body[data-section="services"] .nav-services>a,body[data-section="team"] .nav-team,body[data-section="blog"] .nav-blog,body[data-section="news"] .nav-news,body[data-section="contact"] .nav-contact{background:rgba(207,163,21,.18);color:#fff}
.nav-dropdown{padding-block:14px;margin-block:-14px}.nav-dropdown::after{content:"";position:absolute;left:-20px;right:-20px;top:100%;height:28px}.mega-menu{top:calc(100% - 2px);right:-230px;background:rgba(17,14,9,.98);border:1px solid rgba(207,163,21,.34);box-shadow:0 28px 80px rgba(0,0,0,.34);transition:opacity .22s ease,transform .22s ease;z-index:200}.mega-menu strong{color:#fff}.mega-links a{background:rgba(255,255,255,.06);color:rgba(255,255,255,.88);border:1px solid rgba(207,163,21,.18)}.mega-links a:hover{background:rgba(207,163,21,.16);color:#fff}.mega-links a span{background:#cfa315;color:#080705}.mega-kicker,.eyebrow{color:#dcb316}
.hero-home{background:radial-gradient(circle at 78% 20%,rgba(207,163,21,.16),transparent 32%),linear-gradient(115deg,#030302 0%,#080705 48%,#1b1509 100%);}
.hero-grid{min-height:auto;padding:clamp(72px,7vw,105px) 0;grid-template-columns:minmax(0,.98fr) minmax(440px,.92fr);gap:clamp(2.4rem,5vw,5.5rem)}
.hero-copy h1{font-size:clamp(3.1rem,5.2vw,5.65rem);line-height:.98;max-width:760px;letter-spacing:-.045em}.lead{font-size:clamp(1.05rem,1.35vw,1.22rem);line-height:1.65}.hero-copy .lead{max-width:640px;color:rgba(255,255,255,.86)}
.hero-visual{min-height:500px;display:flex;align-items:center;justify-content:center}.hero-photo{position:relative;inset:auto;width:100%;max-width:600px;aspect-ratio:535/333;border-radius:28px;transform:none;border:1px solid rgba(207,163,21,.38);background:#050403;box-shadow:0 34px 90px rgba(0,0,0,.45),0 0 0 10px rgba(207,163,21,.04)}.hero-photo img{width:100%;height:100%;object-fit:contain;background:#050403}.hero-photo::after{display:none}.glass-card{background:rgba(8,7,5,.88);color:#fff;border:1px solid rgba(207,163,21,.42);border-radius:18px;padding:.85rem 1rem;box-shadow:0 18px 44px rgba(0,0,0,.38)}.glass-card strong{font-size:1.35rem;color:#f0d36b}.glass-card span{color:rgba(255,255,255,.78);font-size:.82rem}.glass-card.one{top:2%;left:2%}.glass-card.two{right:3%;bottom:4%;top:auto}.glass-card.three{left:4%;bottom:4%;max-width:225px}
.trust-strip{margin-top:0;background:#080705;border-top:1px solid rgba(207,163,21,.22);border-bottom:1px solid rgba(207,163,21,.22);padding:18px 0}.trust-grid{background:transparent;border:0;box-shadow:none}.trust-item{background:rgba(255,255,255,.055);border:1px solid rgba(207,163,21,.20)}.trust-item strong{color:#fff}.trust-item span{color:rgba(255,255,255,.72)}
.section{padding:clamp(64px,7vw,98px) 0}.tinted{background:#f7f0e3}.service-card,.person-card,.post-card,.contact-details,.contact-form,.side-card,.profile-aside,.testimonial,.feature-card,.search-box,.article-meta,.rich-text{background:rgba(255,255,255,.94);border:1px solid rgba(88,67,14,.15);box-shadow:var(--shadow-soft)}.button{background:linear-gradient(135deg,#dcb316,#bf900c);color:#080705}.button.secondary{background:transparent;color:#fff;border:1px solid rgba(240,211,107,.55)}.button.secondary:hover{background:rgba(207,163,21,.16)}
.photo-hero,.page-hero,.cta-band,.deep{background:linear-gradient(135deg,#070604,#171107 64%,#2b210f);}.page-hero h1{font-size:clamp(2.55rem,4.8vw,5.2rem)}
.sticky-contact a{background:rgba(8,7,5,.92);border-color:rgba(207,163,21,.32)}.sticky-contact span{color:#f0d36b}.site-footer{background:#050403;border-top:1px solid rgba(207,163,21,.22)}
@media(max-width:1040px){.menu{background:rgba(12,10,7,.98);border-color:rgba(207,163,21,.32)}.mega-menu{right:auto;background:rgba(255,255,255,.04);border-color:rgba(207,163,21,.22)}.hero-grid{grid-template-columns:1fr}.hero-visual{min-height:auto}.hero-photo{max-width:720px}.hero-copy h1{font-size:clamp(3rem,10vw,5rem)}.sticky-contact{display:none}}
@media(max-width:720px){.topbar{display:none}.nav-inner{min-height:68px}.brand-image img{height:38px}.hero-grid{padding:52px 0}.hero-copy h1{font-size:clamp(2.6rem,13vw,4rem)}.hero-actions{margin-top:1.2rem}.glass-card{display:none}.services-grid,.people-grid,.post-grid,.feature-grid,.archive-grid,.trust-grid,.testimonial-grid{grid-template-columns:1fr!important}.wrap{width:min(100% - 28px,var(--max))}}


/* ===== Verralls agency v10 premium direction ===== */
:root {
  --ink: #111111;
  --muted: #6e675d;
  --navy: #050505;
  --navy-2: #0c0c0c;
  --navy-3: #15120a;
  --cream: #f3ecdd;
  --cream-2: #e6dac5;
  --paper: #fffaf0;
  --surface: #ffffff;
  --gold: #d8ad18;
  --gold-2: #f0cf55;
  --deep-gold: #9d7812;
  --line: rgba(17,17,17,.12);
  --soft-line: rgba(216,173,24,.28);
  --shadow: 0 26px 80px rgba(0,0,0,.24);
  --shadow-soft: 0 18px 46px rgba(0,0,0,.10);
  --radius: 20px;
  --max: 1420px;
}
body { background: var(--cream); color: #121212; }
a:hover { color: var(--gold); }
.wrap { width: min(100% - 64px, var(--max)); }
.site-header { background: #030303; box-shadow: none; border-bottom: 1px solid rgba(216,173,24,.36); }
.topbar { background: #030303; color: rgba(255,255,255,.86); border-bottom: 1px solid rgba(216,173,24,.25); font-size: .88rem; }
.topbar-inner { min-height: 40px; }
.topbar-location { position: relative; padding-left: 1.45rem; text-transform: uppercase; letter-spacing: .05em; }
.topbar-location::before { content: '\2022'; position: absolute; left: .25rem; top: -.08rem; color: var(--gold); font-size: 1.4rem; line-height: 1; }
.topbar-actions { gap: 1.2rem; }
.topbar a { color: rgba(255,255,255,.92); font-weight: 760; }
.topbar a:hover { color: var(--gold-2); }
.navbar { background: #030303; border-bottom: 1px solid rgba(216,173,24,.45); backdrop-filter: none; }
.nav-inner { min-height: 104px; }
.brand { gap: 0; }
.brand-logo { width: clamp(150px, 12vw, 205px); height: auto; display: block; }
.footer-logo-img { width: 160px; }
.menu { gap: 1.15rem; }
.menu > a, .nav-dropdown > a {
  color: #f6f1e6;
  min-height: 48px;
  padding: .55rem .3rem;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: .055em;
  font-size: .92rem;
  font-weight: 880;
}
.menu > a:hover, .nav-dropdown:hover > a, .nav-dropdown:focus-within > a, .nav-dropdown.is-open > a {
  background: transparent;
  color: var(--gold-2);
}
.nav-dropdown > a::after { content: '\2304'; color: var(--gold); margin-left: .45rem; font-size: .85rem; transform: translateY(-1px); }
.nav-cta {
  background: transparent !important;
  color: var(--gold-2) !important;
  border: 1px solid var(--deep-gold);
  padding: .82rem 1.55rem !important;
  border-radius: 2px !important;
  box-shadow: 0 16px 42px rgba(216,173,24,.06);
}
.nav-cta:hover, body[data-section="contact"] .nav-contact {
  background: var(--gold) !important;
  color: #070707 !important;
}
body[data-section="about"] .nav-about,
body[data-section="services"] .nav-services > a,
body[data-section="team"] .nav-team,
body[data-section="blog"] .nav-blog,
body[data-section="news"] .nav-news {
  background: transparent;
  color: var(--gold-2);
}
.nav-dropdown { position: relative; }
.nav-dropdown::after { content: ''; position: absolute; left: -30px; right: -30px; top: 100%; height: 24px; }
.mega-menu {
  right: -210px;
  top: calc(100% + 16px);
  width: min(920px, 94vw);
  grid-template-columns: 255px 1fr;
  gap: 1.25rem;
  padding: 1rem;
  background:
    radial-gradient(circle at 84% 8%, rgba(216,173,24,.16), transparent 28%),
    linear-gradient(135deg, rgba(18,16,11,.98), rgba(5,5,5,.98) 54%, rgba(12,10,6,.98));
  border: 1px solid rgba(216,173,24,.38);
  border-radius: 22px;
  box-shadow: 0 30px 90px rgba(0,0,0,.45);
  backdrop-filter: blur(18px);
  transition: opacity .18s ease, transform .18s ease;
  z-index: 50;
}
.nav-dropdown:hover .mega-menu,
.nav-dropdown:focus-within .mega-menu,
.nav-dropdown.is-open .mega-menu { opacity: 1; transform: translateY(0); pointer-events: auto; }
.mega-menu strong { color: #fff; font-family: Georgia, "Times New Roman", serif; font-size: 1.55rem; }
.mega-kicker { color: var(--gold-2); }
.mega-links { gap: .55rem; }
.mega-links a {
  background:
    linear-gradient(135deg, rgba(255,255,255,.072), rgba(216,173,24,.035) 55%, rgba(255,255,255,.045));
  border: 1px solid rgba(216,173,24,.26);
  color: #fff;
  border-radius: 14px;
  padding: .86rem .95rem;
  gap: .82rem;
  overflow: hidden;
  position: relative;
}
.mega-links a::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent, rgba(255,215,106,.10), transparent);
  opacity: 0;
  transition: opacity .18s ease;
}
.mega-links a:hover { background: linear-gradient(135deg, rgba(216,173,24,.14), rgba(255,255,255,.065)); color: #fff; border-color: rgba(216,173,24,.55); }
.mega-links a:hover::after { opacity: 1; }
.mega-links a span {
  position: relative;
  z-index: 1;
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  display: grid;
  place-items: center;
  background: transparent;
  color: var(--gold-2);
  border-radius: 0;
  font-size: 1.08rem;
  line-height: 1;
  text-shadow: 0 0 16px rgba(255,215,106,.34);
}
.mega-links a span::before {
  content: '';
  position: absolute;
  inset: 5px;
  z-index: -1;
  border: 1px solid rgba(255,215,106,.76);
  border-radius: 10px;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,215,106,.22), transparent 38%),
    linear-gradient(135deg, rgba(216,173,24,.12), rgba(13,13,13,.88) 68%);
  box-shadow:
    inset 0 0 18px rgba(255,215,106,.08),
    0 0 22px rgba(216,173,24,.16);
  transform: rotate(45deg);
}
.nav-toggle { background: #111; border: 1px solid rgba(216,173,24,.42); }
.eyebrow { color: var(--gold-2); letter-spacing: .16em; }
.hero-copy h1, .page-hero h1, .split h2, .section-heading h2, .cta-band h2, .rich-text h2, .profile-aside h2, .contact-details h2, .search-main h1 {
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: -.025em;
}
.agency-hero {
  position: relative;
  width: 100%;
  margin-left: 0;
  min-height: clamp(650px, calc(100svh - 116px), 820px);
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 75% 28%, rgba(216,173,24,.20), transparent 28%),
    linear-gradient(115deg, #030303 0%, #060504 44%, #120d05 100%);
  color: #fff;
  border-bottom: 1px solid rgba(216,173,24,.38);
}
.agency-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, #030303 0%, rgba(3,3,3,.98) 30%, rgba(3,3,3,.76) 40%, rgba(3,3,3,.28) 52%, rgba(3,3,3,.08) 66%, transparent 100%),
    linear-gradient(0deg, rgba(3,3,3,.96) 0%, rgba(3,3,3,.42) 25%, transparent 58%),
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: auto, auto, 72px 72px, 72px 72px;
  opacity: .9;
  mask-image: linear-gradient(to bottom, black, rgba(0,0,0,.88) 70%, transparent 100%);
  pointer-events: none;
}
.agency-hero::after {
  content: '';
  position: absolute;
  z-index: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 60%;
  background: linear-gradient(0deg, rgba(3,3,3,.97), rgba(3,3,3,.56) 43%, transparent 100%), url('../img/photos/gibraltar-rock-waterfront.jpg');
  background-size: cover;
  background-position: 48% bottom;
  opacity: .42;
  filter: saturate(.52) contrast(1.18);
  pointer-events: none;
}
.agency-hero-inner { position: static; min-height: inherit; display: flex; align-items: center; }
.agency-copy { position: relative; z-index: 3; width: min(39vw, 590px); padding: clamp(3.1rem, 6vw, 6.5rem) 0 clamp(3rem, 5vw, 5.6rem); }
.agency-copy h1 { font-size: clamp(2.95rem, 4vw, 4.65rem); line-height: 1.02; max-width: 590px; margin-bottom: 1rem; }
.gold-rule { display: block; width: 84px; height: 2px; margin: 1.35rem 0 1.45rem; background: linear-gradient(90deg, var(--gold), transparent); }
.agency-copy .lead { color: rgba(255,255,255,.88); font-size: clamp(1.04rem, 1.18vw, 1.18rem); line-height: 1.72; max-width: 560px; }
.agency-hero-art { position: absolute; z-index: 1; top: 0; right: 0; bottom: 0; width: min(68vw, 1320px); overflow: hidden; pointer-events: none; }
.agency-hero-art::before { content: ''; position: absolute; inset: 0; z-index: 2; background: linear-gradient(90deg, #030303 0%, rgba(3,3,3,.78) 10%, rgba(3,3,3,.28) 28%, transparent 50%), linear-gradient(270deg, #030303 0%, rgba(3,3,3,.58) 4%, transparent 14%), linear-gradient(0deg, #030303 0%, rgba(3,3,3,.22) 18%, transparent 46%); }
.agency-hero-art img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: contrast(1.08) saturate(1.02); }
.agency-hero .button { border-radius: 2px; padding: 1rem 1.55rem; text-transform: uppercase; letter-spacing: .055em; background: linear-gradient(135deg, #f1ce55, #c6920a); color: #090909; box-shadow: 0 22px 50px rgba(216,173,24,.22); }
.agency-hero .button.secondary { background: rgba(0,0,0,.24); color: var(--gold-2); border: 1px solid rgba(216,173,24,.55); box-shadow: none; }
.agency-hero .button.secondary:hover { background: rgba(216,173,24,.12); color: #fff; }
.agency-feature-strip { margin-top: 0; background: linear-gradient(180deg, #fbf5e9, #f3ead8); border-bottom: 1px solid rgba(17,17,17,.08); }
.agency-feature-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 0; }
.agency-feature { padding: clamp(1.6rem, 3vw, 2.2rem) clamp(1.4rem, 3vw, 2.4rem); border-right: 1px solid rgba(17,17,17,.10); }
.agency-feature:last-child { border-right: 0; }
.feature-icon { color: var(--deep-gold); font-size: 2.1rem; line-height: 1; margin-bottom: .85rem; filter: grayscale(.35); }
.agency-feature h2 { margin: 0 0 .45rem; text-transform: uppercase; letter-spacing: .08em; font-size: 1rem; line-height: 1.25; color: #0d0d0d; }
.agency-feature p { margin: 0; color: #4d473c; line-height: 1.58; }
.trust-grid { box-shadow: none; }
.section { padding: clamp(72px, 8vw, 118px) 0; }
.tinted { background: #f9f1e4; }
.service-card, .person-card, .post-card, .contact-details, .contact-form, .side-card, .profile-aside, .testimonial, .feature-card, .search-box, .article-meta, .rich-text {
  border-color: rgba(17,17,17,.10);
  border-radius: 18px;
  box-shadow: 0 18px 48px rgba(0,0,0,.08);
}
.service-card:hover, .person-card:hover, .post-card:hover { transform: translateY(-4px); border-color: rgba(216,173,24,.44); box-shadow: 0 26px 70px rgba(0,0,0,.13); }
.service-icon, .feature-card .num { background: var(--gold); color: #090909; }
.text-link { color: #8d6a0b; }
.photo-card, .hero-meta-card, .map-panel { border-radius: 18px; }
.page-hero { background: #030303; border-bottom: 1px solid rgba(216,173,24,.35); padding: clamp(86px, 9vw, 132px) 0; }
.photo-hero { background-image: linear-gradient(90deg, rgba(3,3,3,.96), rgba(3,3,3,.78) 52%, rgba(3,3,3,.26)), var(--hero-img); background-size: cover; background-position: center center; background-repeat: no-repeat; }
.service-banner-hero {
  min-height: clamp(420px, 43vw, 640px);
  display: flex;
  align-items: flex-end;
  padding: clamp(112px, 9vw, 150px) 0 clamp(54px, 5.5vw, 86px);
  background-image:
    linear-gradient(90deg, rgba(3,3,3,.78) 0%, rgba(3,3,3,.56) 34%, rgba(3,3,3,.18) 64%, rgba(3,3,3,.06) 100%),
    linear-gradient(0deg, rgba(3,3,3,.46) 0%, rgba(3,3,3,.08) 48%, rgba(3,3,3,0) 100%),
    var(--hero-img);
  background-size: cover;
  background-position: var(--hero-pos, center center);
  background-repeat: no-repeat;
  border-bottom: 1px solid rgba(216,173,24,.42);
}
.service-banner-hero .page-hero-grid {
  grid-template-columns: minmax(0, 760px);
  align-items: end;
}
.service-banner-hero .page-hero-copy {
  max-width: 760px;
}
.service-banner-hero h1 {
  max-width: 760px;
  text-shadow: 0 8px 28px rgba(0,0,0,.62);
}
.service-banner-hero .lead {
  max-width: 700px;
  color: rgba(255,255,255,.88);
  text-shadow: 0 4px 18px rgba(0,0,0,.74);
}
.service-banner-hero .hero-meta-card {
  display: none;
}
.page-hero h1 { font-size: clamp(3.2rem, 6.1vw, 6.2rem); line-height: .98; }
.hero-meta-card { background: rgba(5,5,5,.70); border: 1px solid rgba(216,173,24,.34); color: #fff; }
.hero-meta-card span { color: var(--gold-2); }
.hero-meta-card p { color: rgba(255,255,255,.78); }
.cta-band { background: radial-gradient(circle at 80% 20%, rgba(216,173,24,.18), transparent 30%), #030303; border-top: 1px solid rgba(216,173,24,.28); border-bottom: 1px solid rgba(216,173,24,.28); }
.cta-band .button.light { border-radius: 2px; background: var(--gold); color: #080808; }
.cta-band .button.ghost-light { border-radius: 2px; color: var(--gold-2); border-color: rgba(216,173,24,.52); }
.site-footer { background: #030303; border-top: 1px solid rgba(216,173,24,.25); }
.footer-brand { color: #fff; }
@media (min-width: 1041px) { .sticky-contact { display: none; } }
@media (max-width: 1180px) {
  .menu { gap: .72rem; }
  .agency-copy h1 { font-size: clamp(3rem, 4.75vw, 4.55rem); }
  .agency-copy { width: min(47vw, 590px); }
  .agency-hero-art { width: 68vw; }
}
@media (max-width: 1040px) {
  .wrap { width: min(100% - 40px, var(--max)); }
  .topbar-location { text-transform: none; letter-spacing: 0; }
  .nav-inner { min-height: 86px; }
  .brand-logo { width: 170px; }
  .menu { background: rgba(5,5,5,.98); border-color: rgba(216,173,24,.35); }
  .menu > a, .nav-dropdown > a { color: #fff; padding: .8rem 1rem; }
  .mega-menu { background: rgba(18,18,18,.96); border-radius: 16px; }
  .agency-hero { min-height: auto; }
  .agency-hero-inner { display: block; min-height: 0; padding-top: 0; }
  .agency-copy { width: 100%; padding: 4rem 0 2rem; }
  .agency-copy h1 { max-width: 780px; }
  .agency-hero-art { position: relative; right: auto; top: auto; bottom: auto; width: calc(100% + 40px); max-width: none; margin-left: -20px; height: clamp(430px, 54vw, 540px); border-top: 1px solid rgba(216,173,24,.25); }
  .agency-hero-art::before { background: linear-gradient(0deg, #030303 0%, transparent 30%), linear-gradient(90deg, #030303 0%, rgba(3,3,3,.16) 20%, transparent 100%); }
  .agency-hero-art img { object-position: center top; }
  .agency-feature-grid, .feature-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .agency-feature:nth-child(2) { border-right: 0; }
  .agency-feature:nth-child(-n+2) { border-bottom: 1px solid rgba(17,17,17,.10); }
}
@media (max-width: 720px) {
  .wrap { width: min(100% - 28px, var(--max)); }
  .topbar-inner { min-height: 34px; }
  .topbar-actions { font-size: .8rem; gap: .75rem; }
  .brand-logo { width: 145px; }
  .agency-copy { padding: 3.4rem 0 1.5rem; }
  .agency-copy h1 { font-size: clamp(2.45rem, 10.5vw, 3.45rem); line-height: 1.02; }
  .agency-copy .lead { font-size: 1rem; }
  .agency-hero-art { width: calc(100% + 28px); margin-left: -14px; height: clamp(320px, 82vw, 420px); }
  .agency-hero-art img { object-position: 57% top; }
  .agency-hero .hero-actions { display: grid; grid-template-columns: 1fr; }
  .agency-feature-grid { grid-template-columns: 1fr; }
  .agency-feature { border-right: 0; border-bottom: 1px solid rgba(17,17,17,.10); }
  .agency-feature:last-child { border-bottom: 0; }
  .page-hero h1 { font-size: clamp(2.65rem, 13vw, 4rem); }
}
@media (max-width: 480px) {
  .agency-hero-art { height: 330px; }
  .agency-hero-art img { object-position: 58% top; }
}

.agency-feature .feature-icon { color: var(--deep-gold); font-size: 0; filter: none; }
.agency-feature .feature-icon svg { width: 40px; height: 40px; display: block; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }

/* V10 final polish: sharp Verralls SVG logo and professional line icons */
.brand-logo{width:clamp(185px,14vw,250px);height:auto;display:block;}
.footer-logo-img{width:210px;}
.feature-icon{font-size:0;filter:none;color:var(--deep-gold);}
.feature-icon svg{width:48px;height:48px;display:block;fill:currentColor;}
@media(max-width:1040px){.brand-logo{width:185px;}}
@media(max-width:720px){.brand-logo{width:155px;}.footer-logo-img{width:180px;}}

/* Exact approved homepage hero artwork with crisp live typography */
.exact-hero {
  position: relative;
  width: 100%;
  min-height: 0;
  aspect-ratio: 2246 / 943;
  overflow: hidden;
  background: #030303 url('../img/home-hero-exact.png') center center / 100% 100% no-repeat;
  border-bottom: 1px solid rgba(216,173,24,.38);
}
.exact-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(3,3,3,.98) 0%, rgba(3,3,3,.98) 31%, rgba(3,3,3,.82) 39%, rgba(3,3,3,.26) 50%, transparent 60%),
    linear-gradient(0deg, rgba(3,3,3,.72) 0%, rgba(3,3,3,.18) 28%, transparent 54%);
  pointer-events: none;
}
.exact-hero::after,
.exact-hero .agency-hero-art {
  display: none;
}
.exact-hero .agency-hero-inner.wrap {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  min-height: 0;
  display: block;
  pointer-events: none;
}
.exact-hero .agency-copy {
  position: absolute;
  left: 3.7%;
  top: 12%;
  z-index: 2;
  width: min(43vw, 760px);
  padding: 0;
  pointer-events: none;
}
.exact-hero .agency-copy > :not(.hero-actions) {
  position: static !important;
  width: auto;
  height: auto;
  padding: 0;
  margin-left: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
  border: 0;
}
.exact-hero .eyebrow {
  margin: 0 0 clamp(.85rem, 1vw, 1.3rem);
  color: #d3a51a;
  font-size: clamp(.82rem, 1.1vw, 1.55rem);
  line-height: 1;
  letter-spacing: .12em;
}
.exact-hero .agency-copy h1 {
  max-width: 100%;
  margin: 0;
  color: #fff;
  font-size: clamp(2.8rem, 3.92vw, 5.25rem);
  line-height: .99;
  letter-spacing: -.02em;
  text-shadow: 0 2px 10px rgba(0,0,0,.42);
}
.exact-hero .gold-rule {
  width: clamp(58px, 6.2vw, 140px);
  height: 2px;
  margin: clamp(1rem, 1.6vw, 2rem) 0 clamp(1.5rem, 2vw, 2.5rem);
  background: linear-gradient(90deg, #d8ad18, rgba(216,173,24,0));
}
.exact-hero .agency-copy .lead {
  max-width: min(38vw, 700px);
  margin: 0;
  color: rgba(255,255,255,.94);
  font-size: clamp(.92rem, 1.14vw, 1.45rem);
  line-height: 1.56;
  text-shadow: 0 2px 8px rgba(0,0,0,.48);
}
.exact-hero .hero-actions {
  position: absolute;
  left: 3.75%;
  top: 76.85%;
  z-index: 3;
  width: 29%;
  height: 7.4%;
  margin: 0;
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 4.5%;
  pointer-events: auto;
}
.exact-hero .hero-actions .button {
  flex: 0 0 42.5%;
  width: auto;
  height: 100%;
  min-height: 0;
  padding: 0;
  border-radius: 2px;
  opacity: 1;
  font-size: clamp(.72rem, 1vw, 1.2rem);
  line-height: 1;
  letter-spacing: .05em;
  background: linear-gradient(135deg, #e3b326, #c99512);
  color: #fff;
  box-shadow: 0 10px 30px rgba(216,173,24,.22);
}
.exact-hero .hero-actions .button.secondary {
  flex-basis: 53%;
  background: rgba(0,0,0,.24);
  color: #d8ad18;
  border: 1px solid rgba(216,173,24,.78);
  box-shadow: none;
}
.exact-hero .hero-actions .button:focus-visible {
  outline: 3px solid var(--gold-2);
  outline-offset: 4px;
}
@media(max-width:720px) {
  .exact-hero {
    min-height: 960px;
    aspect-ratio: auto;
    background:
      radial-gradient(circle at 70% 24%, rgba(216,173,24,.14), transparent 30%),
      linear-gradient(115deg, #030303 0%, #060504 48%, #120d05 100%);
  }
  .exact-hero::before {
    background:
      linear-gradient(0deg, rgba(3,3,3,.95) 0%, rgba(3,3,3,.18) 38%, transparent 68%),
      linear-gradient(90deg, rgba(3,3,3,.96), rgba(3,3,3,.68));
  }
  .exact-hero .agency-hero-art {
    display: block;
    position: absolute;
    z-index: 1;
    left: 0;
    right: 0;
    bottom: 0;
    height: 360px;
    overflow: hidden;
    border-top: 1px solid rgba(216,173,24,.25);
  }
  .exact-hero .agency-hero-art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 58% top;
  }
  .exact-hero .agency-copy {
    left: 24px;
    right: 24px;
    top: 72px;
    width: auto;
  }
  .exact-hero .agency-copy h1 {
    font-size: clamp(2.45rem, 10.5vw, 3.45rem);
    line-height: 1.02;
  }
  .exact-hero .agency-copy .lead {
    max-width: none;
    font-size: 1rem;
  }
  .exact-hero .hero-actions {
    left: 24px;
    right: 24px;
    top: 560px;
    width: auto;
    height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: .8rem;
  }
  .exact-hero .hero-actions .button,
  .exact-hero .hero-actions .button.secondary {
    width: 100%;
    height: 60px;
    flex-basis: auto;
    font-size: .88rem;
  }
}

/* Artwork-only exact hero: keeps the approved composite visible without duplicate text. */
.exact-hero {
  min-height: 0 !important;
  aspect-ratio: 2246 / 943 !important;
  background: #030303 url('../img/home-hero-exact.png') center center / 100% 100% no-repeat !important;
}
.exact-hero::before,
.exact-hero::after,
.exact-hero .agency-hero-art {
  display: none !important;
}
.exact-hero .agency-hero-inner.wrap,
.exact-hero .agency-copy {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  min-height: 0 !important;
  padding: 0 !important;
  pointer-events: none !important;
}
.exact-hero .agency-copy > :not(.hero-actions) {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.exact-hero .hero-actions {
  position: absolute !important;
  left: 3.75% !important;
  top: 76.85% !important;
  z-index: 3 !important;
  width: 29% !important;
  height: 7.4% !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 4.5% !important;
  pointer-events: auto !important;
}
.exact-hero .hero-actions .button,
.exact-hero .hero-actions .button.secondary {
  flex: 0 0 42.5% !important;
  width: auto !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  opacity: 0 !important;
}
.exact-hero .hero-actions .button.secondary {
  flex-basis: 53% !important;
}
.exact-hero .hero-actions .button:focus-visible {
  opacity: .18 !important;
  outline: 3px solid var(--gold-2) !important;
  outline-offset: 4px !important;
}

/* Keep section headings readable on the beige services band. */
.tinted .section-heading h2 {
  color: #121212;
}
.tinted .section-heading p:not(.eyebrow) {
  color: #5b554d;
}

/* Keep dark-band content readable after the light card polish. */
.deep .section-heading h2 {
  color: #fff;
}
.deep .section-heading p:not(.eyebrow) {
  color: rgba(255,255,255,.76);
}
.deep .feature-card,
.deep .testimonial {
  background: rgba(255,255,255,.94);
  border-color: rgba(216,173,24,.22);
}
.deep .feature-card h3 {
  color: #111;
}
.deep .feature-card p,
.deep .testimonial p {
  color: #5b554d;
}
.deep .testimonial strong {
  color: #8d6a0b;
}

/* Legal team CTA sits on a light band, so it needs a filled treatment. */
.people-grid + .center-actions .button.secondary {
  background: #080705;
  color: var(--gold-2);
  border: 1px solid rgba(216,173,24,.72);
  box-shadow: 0 16px 36px rgba(0,0,0,.16);
}
.people-grid + .center-actions .button.secondary:hover {
  background: var(--gold);
  color: #080705;
}

/* Premium testimonial band: restrained motion, readable dark cards. */
.testimonial-section {
  overflow: hidden;
  border-top: 1px solid rgba(216,173,24,.28);
  border-bottom: 1px solid rgba(216,173,24,.28);
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), transparent 22%),
    linear-gradient(135deg, #040302 0%, #121008 58%, #211807 100%);
}
.testimonial-section .section-heading {
  max-width: 980px;
  margin-bottom: clamp(2.2rem, 4vw, 3.5rem);
}
.testimonial-section .section-heading h2 {
  color: #fff;
  text-shadow: 0 18px 42px rgba(0,0,0,.46);
}
.testimonial-section .testimonial-grid {
  gap: clamp(1rem, 2vw, 1.6rem);
}
.testimonial-section .testimonial {
  position: relative;
  overflow: hidden;
  padding: clamp(1.4rem, 2vw, 2rem);
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)),
    #080706;
  border: 1px solid rgba(216,173,24,.28);
  border-radius: 16px;
  box-shadow: 0 24px 70px rgba(0,0,0,.34);
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease, border-color .22s ease, box-shadow .22s ease;
}
.testimonial-section .testimonial::before {
  content: '\201C';
  position: absolute;
  right: 1.1rem;
  top: -.25rem;
  color: rgba(216,173,24,.18);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(4rem, 7vw, 6.8rem);
  line-height: 1;
  pointer-events: none;
}
.testimonial-section .testimonial::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--gold-2), rgba(216,173,24,.08));
}
.testimonial-section .testimonial.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.testimonial-section .testimonial:nth-child(2) { transition-delay: .08s; }
.testimonial-section .testimonial:nth-child(3) { transition-delay: .14s; }
.testimonial-section .testimonial:nth-child(4) { transition-delay: .2s; }
.testimonial-section .testimonial:hover {
  border-color: rgba(216,173,24,.55);
  box-shadow: 0 30px 86px rgba(0,0,0,.42);
  transform: translateY(-4px);
}
.testimonial-section .testimonial p {
  position: relative;
  z-index: 1;
  color: rgba(255,255,255,.82);
}
.testimonial-section .testimonial strong {
  position: relative;
  z-index: 1;
  color: var(--gold-2);
}
@media (prefers-reduced-motion: reduce) {
  .testimonial-section .testimonial {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* About hero: real Gibraltar Law Courts imagery with a blended crest detail. */
.about-court-hero {
  position: relative;
  isolation: isolate;
  min-height: clamp(580px, 60vw, 760px);
  display: flex;
  align-items: center;
  background-image:
    linear-gradient(90deg, rgba(3,3,3,.98) 0%, rgba(3,3,3,.92) 38%, rgba(3,3,3,.58) 62%, rgba(3,3,3,.36) 100%),
    linear-gradient(0deg, rgba(3,3,3,.78), rgba(3,3,3,.12) 45%, rgba(3,3,3,.54)),
    var(--hero-img);
  background-size: cover;
  background-position: center right;
}
.about-court-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 75% 28%, rgba(216,173,24,.22), transparent 28%),
    linear-gradient(90deg, rgba(3,3,3,.78), transparent 66%);
  pointer-events: none;
}
.about-court-hero .page-hero-grid {
  grid-template-columns: minmax(0, .95fr) minmax(320px, 450px);
  align-items: center;
}
.about-court-hero .page-hero-copy {
  max-width: 900px;
}
.about-court-hero .court-visual-card {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(216,173,24,.38);
  background: rgba(3,3,3,.28);
  box-shadow: 0 34px 90px rgba(0,0,0,.42);
  aspect-ratio: 1.12;
}
.about-court-hero .court-visual-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(3,3,3,.08), rgba(3,3,3,.18) 38%, rgba(3,3,3,.86)),
    radial-gradient(circle at 68% 20%, rgba(216,173,24,.22), transparent 34%);
  pointer-events: none;
}
.about-court-hero .court-building-photo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 52%;
  filter: saturate(.78) contrast(1.12) brightness(.72);
  transform: scale(1.02);
}
.about-court-hero .court-crest-photo {
  position: absolute;
  top: 4%;
  right: 4%;
  z-index: 2;
  width: 54%;
  aspect-ratio: 1.5;
  object-fit: cover;
  object-position: center 38%;
  border-radius: 14px;
  opacity: .9;
  filter: saturate(.9) contrast(1.08) brightness(.88);
  box-shadow: 0 20px 58px rgba(0,0,0,.38);
  -webkit-mask-image: radial-gradient(ellipse at 50% 50%, #000 56%, rgba(0,0,0,.72) 70%, transparent 100%);
  mask-image: radial-gradient(ellipse at 50% 50%, #000 56%, rgba(0,0,0,.72) 70%, transparent 100%);
}
.about-court-hero .court-visual-card div {
  position: absolute;
  left: clamp(1rem, 2vw, 1.5rem);
  right: clamp(1rem, 2vw, 1.5rem);
  bottom: clamp(1rem, 2vw, 1.5rem);
  z-index: 3;
}
.about-court-hero .court-visual-card span {
  display: block;
  color: var(--gold-2);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .72rem;
  font-weight: 950;
  margin-bottom: .45rem;
}
.about-court-hero .court-visual-card strong {
  display: block;
  color: #fff;
  font-size: clamp(1.3rem, 2vw, 1.9rem);
  line-height: 1.08;
}
@media (max-width: 1040px) {
  .about-court-hero {
    min-height: auto;
    padding: 70px 0 86px;
    background-position: 63% center;
  }
  .about-court-hero .page-hero-grid {
    grid-template-columns: 1fr;
  }
  .about-court-hero .court-visual-card {
    max-width: 520px;
  }
}
@media (max-width: 720px) {
  .about-court-hero {
    padding: 58px 0 74px;
    background-image:
      linear-gradient(180deg, rgba(3,3,3,.94), rgba(3,3,3,.72)),
      var(--hero-img);
  }
  .about-court-hero .court-visual-card {
    max-width: none;
  }
}

/* Full-bleed About hero artwork supplied for the court/crest composition. */
.about-court-hero {
  height: clamp(580px, 60vw, 760px);
  min-height: 0;
  padding: 0;
  background-image:
    linear-gradient(90deg, rgba(3,3,3,.72) 0%, rgba(3,3,3,.58) 34%, rgba(3,3,3,.18) 56%, rgba(3,3,3,.04) 100%),
    linear-gradient(0deg, rgba(3,3,3,.28), transparent 34%, rgba(3,3,3,.10)),
    var(--hero-img);
  background-size: cover;
  background-position: center center;
}
.about-court-hero::before {
  display: none;
}
.about-court-hero .page-hero-grid {
  height: 100%;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
}
.about-court-hero .page-hero-copy {
  max-width: 900px;
}
.about-court-hero .page-hero-copy h1,
.about-court-hero .page-hero-copy .lead,
.about-court-hero .page-hero-copy .eyebrow {
  text-shadow: 0 3px 18px rgba(0,0,0,.66);
}
.about-court-hero .court-visual-card {
  display: none;
}
@media (max-width: 1040px) {
  .about-court-hero {
    height: clamp(560px, 70vw, 720px);
    padding: 0;
    background-position: 62% center;
  }
}
@media (max-width: 720px) {
  .about-court-hero {
    height: 620px;
    padding: 0;
    background-image:
      linear-gradient(90deg, rgba(3,3,3,.82), rgba(3,3,3,.46)),
      var(--hero-img);
    background-position: 66% center;
  }
}

/* Legal Team hero: supplied Gibraltar monument artwork, full-bleed. */
.legal-team-monument-hero {
  height: clamp(580px, 60vw, 760px);
  min-height: 0;
  padding: 0;
  background-image:
    linear-gradient(90deg, rgba(3,3,3,.78) 0%, rgba(3,3,3,.62) 35%, rgba(3,3,3,.20) 58%, rgba(3,3,3,.04) 100%),
    linear-gradient(0deg, rgba(3,3,3,.30), transparent 36%, rgba(3,3,3,.16)),
    var(--hero-img);
  background-size: 100% 100%;
  background-position: center center;
}
.legal-team-monument-hero .page-hero-grid {
  height: 100%;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
}
.legal-team-monument-hero .page-hero-copy {
  max-width: 910px;
}
.legal-team-monument-hero .page-hero-copy h1,
.legal-team-monument-hero .page-hero-copy .lead,
.legal-team-monument-hero .page-hero-copy .eyebrow {
  text-shadow: 0 3px 18px rgba(0,0,0,.72);
}
@media (max-width: 1040px) {
  .legal-team-monument-hero {
    height: clamp(560px, 70vw, 720px);
    background-size: cover;
    background-position: 62% center;
  }
}
@media (max-width: 720px) {
  .legal-team-monument-hero {
    height: 620px;
    background-image:
      linear-gradient(90deg, rgba(3,3,3,.84), rgba(3,3,3,.46)),
      var(--hero-img);
    background-size: cover;
    background-position: 67% center;
  }
}

/* Individual legal team profile heroes share the approved Gibraltar artwork. */
.team-profile-hero {
  height: clamp(460px, 42vw, 620px);
  min-height: 0;
  padding: 0;
  background-image:
    linear-gradient(90deg, rgba(3,3,3,.84) 0%, rgba(3,3,3,.66) 42%, rgba(3,3,3,.22) 72%, rgba(3,3,3,.08) 100%),
    var(--hero-img);
  background-size: cover;
  background-position: center center;
}
.team-profile-hero .page-hero-grid {
  height: 100%;
  align-items: center;
}
.team-profile-hero .page-hero-copy h1,
.team-profile-hero .page-hero-copy .lead,
.team-profile-hero .page-hero-copy .eyebrow {
  text-shadow: 0 3px 18px rgba(0,0,0,.74);
}
.team-profile-hero .hero-meta-card {
  background: rgba(8,8,8,.72);
  border-color: rgba(216,173,24,.34);
}
@media (max-width: 720px) {
  .team-profile-hero {
    height: 560px;
    background-position: 62% center;
  }
}

/* Legal team pages need stronger labels and more breathing room before CTAs. */
.team-group {
  padding: clamp(76px, 7vw, 112px) 0 clamp(96px, 9vw, 146px);
  background: var(--cream);
}
.team-group .section-heading,
.legal-team-preview .section-heading {
  margin-bottom: clamp(2.4rem, 4vw, 4rem);
}
.team-group .section-heading .eyebrow,
.legal-team-preview .section-heading .eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  margin-bottom: 1rem;
  padding: .36rem 1rem .34rem;
  color: #8d6909;
  background: rgba(216,173,24,.10);
  border: 1px solid rgba(216,173,24,.34);
  border-radius: 999px;
  font-size: clamp(.9rem, 1vw, 1.08rem);
  line-height: 1;
  letter-spacing: .24em;
  text-shadow: 0 1px 0 rgba(255,255,255,.45);
}
.team-group .people-grid {
  row-gap: clamp(1.5rem, 2.4vw, 2.2rem);
}
@media (max-width: 720px) {
  .team-group {
    padding: 58px 0 82px;
  }
  .team-group .section-heading .eyebrow,
  .legal-team-preview .section-heading .eyebrow {
    max-width: 100%;
    font-size: .86rem;
    letter-spacing: .18em;
  }
}

/* Mobile navigation: make Services a contained, tap-open submenu. */
@media (max-width: 1040px) {
  html,
  body {
    overflow-x: hidden;
  }

  .nav-inner {
    position: relative;
  }

  .menu {
    left: 0;
    right: 0;
    top: calc(100% + 10px);
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    z-index: 500;
    gap: .35rem;
    overflow-x: hidden;
  }

  .menu > a,
  .nav-dropdown > a {
    box-sizing: border-box;
    min-width: 0;
  }

  .nav-dropdown {
    display: block;
    width: 100%;
    min-width: 0;
    padding: 0;
    margin: 0;
  }

  .nav-dropdown::after {
    display: none;
  }

  .nav-dropdown > a {
    justify-content: space-between;
  }

  .nav-dropdown > a::after {
    content: '+';
    margin-left: auto;
    transition: transform .18s ease;
  }

  .nav-dropdown.is-open > a::after {
    content: '-';
    transform: none;
  }

  .nav-dropdown:not(.is-open) .mega-menu {
    display: none !important;
  }

  .nav-dropdown.is-open .mega-menu {
    display: grid !important;
  }

  .mega-menu {
    position: static;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    grid-template-columns: 1fr;
    gap: .75rem;
    margin: .15rem 0 .55rem;
    padding: .75rem;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    overflow: hidden;
    box-shadow: none;
    backdrop-filter: none;
  }

  .mega-menu > div:first-child {
    display: none;
  }

  .mega-links {
    grid-template-columns: 1fr;
    gap: .45rem;
    min-width: 0;
  }

  .mega-links a {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    gap: .65rem;
    padding: .62rem .68rem;
    overflow-wrap: anywhere;
  }

  .mega-links a span {
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
    font-size: .95rem;
    line-height: 1;
  }
}

@media (max-width: 420px) {
  .menu {
    border-radius: 18px;
    padding: .62rem;
  }

  .brand-logo {
    width: 142px;
  }

  .nav-toggle {
    width: 44px;
    height: 44px;
  }
}

@media (max-width: 720px) {
  .map-panel.bespoke-map {
    min-height: 360px;
  }

  .bespoke-map-info {
    left: .72rem;
    right: .72rem;
    bottom: .72rem;
    padding: .85rem;
  }
}

/* Live homepage hero copy so text changes are not baked into artwork. */
.exact-hero {
  min-height: clamp(620px, 54vw, 760px) !important;
  aspect-ratio: auto !important;
  background: #030303 !important;
}

.exact-hero::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, #030303 0%, rgba(3,3,3,.98) 34%, rgba(3,3,3,.86) 50%, rgba(3,3,3,.34) 70%, rgba(3,3,3,.08) 100%),
    linear-gradient(0deg, #030303 0%, rgba(3,3,3,.35) 24%, transparent 58%) !important;
}

.exact-hero::after {
  display: none !important;
}

.exact-hero .agency-hero-art {
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  z-index: 1 !important;
  width: auto !important;
  height: 100% !important;
  margin: 0 !important;
  border: 0 !important;
}

.exact-hero .agency-hero-art::before {
  display: none !important;
}

.exact-hero .agency-hero-art::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, #030303 0%, rgba(3,3,3,.86) 10%, rgba(3,3,3,.24) 28%, transparent 52%),
    linear-gradient(0deg, rgba(3,3,3,.66) 0%, transparent 34%) !important;
}

.exact-hero .agency-hero-art img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: right center !important;
}

.exact-hero .agency-hero-inner.wrap {
  position: relative !important;
  inset: auto !important;
  z-index: 3 !important;
  width: min(100% - 48px, var(--max)) !important;
  min-height: clamp(620px, 54vw, 760px) !important;
  display: flex !important;
  align-items: center !important;
  pointer-events: auto !important;
}

.exact-hero .agency-copy {
  position: relative !important;
  inset: auto !important;
  width: min(44vw, 560px) !important;
  padding: clamp(4rem, 7vw, 6.5rem) 0 !important;
  pointer-events: auto !important;
}

.exact-hero .agency-copy > :not(.hero-actions) {
  position: static !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  clip: auto !important;
  overflow: visible !important;
  white-space: normal !important;
}

.exact-hero .eyebrow {
  margin: 0 0 1rem !important;
}

.exact-hero .agency-copy h1 {
  max-width: 560px !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(2.6rem, 4vw, 4.55rem) !important;
  line-height: 1.02 !important;
  text-shadow: 0 3px 18px rgba(0,0,0,.7) !important;
}

.exact-hero .gold-rule {
  width: 88px !important;
  height: 2px !important;
  margin: 1.35rem 0 1.45rem !important;
}

.exact-hero .agency-copy .lead {
  max-width: 520px !important;
  margin: 0 !important;
  color: rgba(255,255,255,.92) !important;
  font-size: clamp(.98rem, 1.08vw, 1.1rem) !important;
  line-height: 1.64 !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.68) !important;
}

.exact-hero .hero-actions {
  position: static !important;
  width: auto !important;
  height: auto !important;
  margin-top: 1.65rem !important;
  display: flex !important;
  gap: .9rem !important;
  pointer-events: auto !important;
}

.exact-hero .hero-actions .button,
.exact-hero .hero-actions .button.secondary {
  flex: 0 0 auto !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  opacity: 1 !important;
  border-radius: 2px !important;
  padding: 1rem 1.55rem !important;
  font-size: .82rem !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: .055em !important;
  background: linear-gradient(135deg, #f1ce55, #c6920a) !important;
  color: #090909 !important;
  border: 1px solid transparent !important;
  box-shadow: 0 22px 50px rgba(216,173,24,.22) !important;
}

.exact-hero .hero-actions .button.secondary {
  background: rgba(0,0,0,.24) !important;
  color: #d8ad18 !important;
  border-color: rgba(216,173,24,.78) !important;
  box-shadow: none !important;
}

@media (max-width: 1040px) {
  .exact-hero .agency-copy {
    width: min(62vw, 650px) !important;
  }
}

@media (max-width: 720px) {
  .exact-hero,
  .exact-hero .agency-hero-inner.wrap {
    min-height: 860px !important;
  }

  .exact-hero::before {
    background:
      linear-gradient(90deg, rgba(3,3,3,.98) 0%, rgba(3,3,3,.78) 58%, rgba(3,3,3,.25) 100%),
      linear-gradient(0deg, #030303 0%, rgba(3,3,3,.55) 38%, transparent 72%) !important;
  }

  .exact-hero .agency-hero-art img {
    object-position: 60% top !important;
  }

  .exact-hero .agency-copy {
    width: 100% !important;
    padding: 4rem 0 2rem !important;
  }

  .exact-hero .agency-copy h1 {
    font-size: clamp(2.5rem, 11vw, 3.65rem) !important;
  }

  .exact-hero .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
}

.video-feature {
  background:
    radial-gradient(circle at 78% 8%, rgba(216,173,24,.16), transparent 32%),
    linear-gradient(180deg, #060606, #101010);
  border-top: 1px solid rgba(216,173,24,.18);
  border-bottom: 1px solid rgba(216,173,24,.20);
}

.video-feature-grid {
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(0, 1.28fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}

.video-feature-copy h2 {
  max-width: 560px;
  margin: 0 0 1rem;
  color: #fff;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(2.25rem, 4vw, 4rem);
  line-height: 1.04;
}

.video-feature-copy p:not(.eyebrow) {
  max-width: 520px;
  margin: 0;
  color: rgba(255,255,255,.76);
  font-size: 1.05rem;
  line-height: 1.75;
}

.video-frame {
  position: relative;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(216,173,24,.36);
  border-radius: 18px;
  background: #000;
  box-shadow: 0 28px 80px rgba(0,0,0,.45);
}

.video-frame video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #000;
  cursor: pointer;
}

.video-sound-toggle {
  position: absolute;
  right: clamp(.75rem, 2vw, 1.1rem);
  bottom: clamp(.75rem, 2vw, 1.1rem);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .78rem 1.05rem;
  border: 1px solid rgba(216,173,24,.62);
  border-radius: 999px;
  background: rgba(5,5,5,.78);
  color: #fff;
  font: inherit;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 16px 38px rgba(0,0,0,.38);
  cursor: pointer;
  backdrop-filter: blur(12px);
}

.video-sound-toggle:hover,
.video-sound-toggle:focus-visible,
.video-sound-toggle.is-sound-on {
  background: var(--gold);
  color: #050505;
  outline: none;
}

.video-sound-track {
  display: none;
}

@media (min-width: 721px) {
  .exact-hero {
    width: 100vw !important;
    max-width: none !important;
    min-height: 0 !important;
    aspect-ratio: 1934 / 813 !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
  }

  .exact-hero .agency-hero-inner.wrap {
    height: 100% !important;
    min-height: 0 !important;
  }

  .exact-hero .agency-hero-art img {
    object-fit: cover !important;
    object-position: center center !important;
  }
}

.practice-showcase {
  position: relative;
  overflow: hidden;
  padding-top: clamp(132px, 8.5vw, 150px);
  background:
    radial-gradient(circle at 82% 8%, rgba(216,173,24,.15), transparent 30%),
    linear-gradient(180deg, #040404 0%, #0a0a08 56%, #030303 100%);
  border-top: 1px solid rgba(216,173,24,.24);
  border-bottom: 1px solid rgba(216,173,24,.26);
}

.practice-showcase::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(216,173,24,.22), transparent 90px) left 34px top 28px / 120px 1px no-repeat,
    radial-gradient(circle at 8% 22%, rgba(216,173,24,.12), transparent 26%),
    linear-gradient(90deg, rgba(255,255,255,.035), transparent 36%);
  opacity: .8;
}

.practice-showcase-layout {
  position: relative;
  display: grid;
  grid-template-columns: minmax(260px, 1.1fr) repeat(4, minmax(138px, .92fr));
  grid-auto-rows: clamp(300px, 20vw, 360px);
  gap: clamp(.85rem, 1.35vw, 1.25rem);
  align-items: stretch;
}

.practice-intro {
  min-height: 0;
  padding: clamp(1rem, 1.4vw, 1.25rem) .25rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.practice-intro h2 {
  max-width: 440px;
  margin: 0 0 1.35rem;
  color: #fff;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(2.25rem, 3.1vw, 3.65rem);
  line-height: 1.04;
}

.practice-intro h2 span {
  color: var(--gold);
}

.practice-intro p:not(.eyebrow) {
  max-width: 390px;
  margin: 0;
  color: rgba(255,255,255,.75);
  font-size: clamp(1rem, 1.15vw, 1.15rem);
  line-height: 1.75;
}

.practice-intro .gold-rule {
  margin-top: clamp(1.8rem, 3vw, 2.6rem);
}

.practice-card-grid {
  display: contents;
}

.practice-card {
  position: relative;
  isolation: isolate;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  padding: clamp(.95rem, 1.25vw, 1.2rem);
  border: 1px solid rgba(216,173,24,.58);
  border-radius: 16px;
  background: #101010;
  color: #fff;
  box-shadow: 0 28px 72px rgba(0,0,0,.34);
  text-decoration: none;
  transform: translateZ(0);
}

.practice-card::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--service-img);
  background-size: cover;
  background-position: center;
  filter: sepia(.26) saturate(.82) contrast(1.14) brightness(.86);
  transform: scale(1.02);
  transition: transform .35s ease, filter .35s ease;
}

.practice-card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(145deg, rgba(216,173,24,.22), transparent 44%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.44) 46%, rgba(0,0,0,.88) 100%),
    linear-gradient(90deg, rgba(0,0,0,.42), transparent 62%);
}

.practice-card:hover,
.practice-card:focus-visible {
  color: #fff;
  border-color: rgba(255,215,106,.92);
  outline: none;
  box-shadow: 0 32px 88px rgba(0,0,0,.48), 0 0 0 1px rgba(216,173,24,.18);
}

.practice-card:hover::before,
.practice-card:focus-visible::before {
  filter: sepia(.16) saturate(.98) contrast(1.18) brightness(.92);
  transform: scale(1.08);
}

.practice-card-icon {
  position: absolute;
  top: clamp(1rem, 1.45vw, 1.35rem);
  left: clamp(1rem, 1.45vw, 1.35rem);
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--gold-2);
  font-size: 1.22rem;
  line-height: 1;
  text-shadow: 0 0 18px rgba(255,215,106,.36);
}

.practice-card-icon::before {
  content: '';
  position: absolute;
  inset: 6px;
  z-index: -1;
  border: 1px solid rgba(255,215,106,.76);
  border-radius: 11px;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,215,106,.22), transparent 38%),
    linear-gradient(135deg, rgba(216,173,24,.14), rgba(12,12,12,.86) 70%);
  box-shadow:
    inset 0 0 18px rgba(255,215,106,.08),
    0 0 22px rgba(216,173,24,.16);
  transform: rotate(45deg);
}

.practice-card-title {
  max-width: 78%;
  color: #fff;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(1.18rem, 1.5vw, 1.65rem);
  font-weight: 800;
  line-height: 1.06;
  text-shadow: 0 3px 18px rgba(0,0,0,.68);
}

.practice-card-title::after {
  content: '';
  display: block;
  width: 48px;
  height: 2px;
  margin-top: .9rem;
  background: linear-gradient(90deg, var(--gold), transparent);
}

.practice-card-arrow {
  position: absolute;
  right: clamp(1rem, 1.45vw, 1.35rem);
  bottom: clamp(1rem, 1.45vw, 1.35rem);
  color: var(--gold);
  font-size: clamp(1.35rem, 1.65vw, 1.85rem);
  line-height: 1;
}

@media (max-width: 1280px) {
  .practice-showcase-layout {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: auto;
  }

  .practice-intro {
    grid-column: 1 / -1;
    min-height: 0;
    padding: 0 0 .75rem;
  }
}

@media (max-width: 820px) {
  .practice-showcase-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .practice-card {
    min-height: 250px;
  }
}

@media (max-width: 560px) {
  .practice-showcase {
    padding-top: clamp(92px, 18vw, 112px);
  }

  .practice-showcase-layout {
    grid-template-columns: 1fr;
  }

  .practice-intro h2 {
    font-size: clamp(2.2rem, 10vw, 3.05rem);
  }

  .practice-card {
    min-height: 224px;
  }
}

@media (max-width: 900px) {
  .video-feature-grid {
    grid-template-columns: 1fr;
  }

  .video-feature-copy h2 {
    font-size: clamp(2rem, 9vw, 3.25rem);
  }
}

/* Services page: reference-style practice area board. */
body[data-section="services"] .practice-showcase {
  min-height: calc(100svh - 145px);
  padding: clamp(24px, 2vw, 34px) 0 clamp(32px, 2.8vw, 48px);
  background:
    radial-gradient(circle at 28% 5%, rgba(216,173,24,.10), transparent 18%),
    radial-gradient(circle at 72% 3%, rgba(255,215,106,.10), transparent 20%),
    linear-gradient(180deg, #050505 0%, #080806 46%, #030303 100%);
  border-top: 1px solid rgba(216,173,24,.30);
}

body[data-section="services"] .practice-showcase::before {
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(216,173,24,.55), transparent 110px) left clamp(24px, 1.9vw, 34px) top clamp(22px, 2vw, 30px) / 135px 1px no-repeat,
    linear-gradient(180deg, transparent 0 52%, rgba(216,173,24,.32) 52% calc(52% + 1px), transparent calc(52% + 1px)) left 0 top 0 / 100% 100% no-repeat,
    radial-gradient(circle at 12% 40%, rgba(216,173,24,.12), transparent 30%),
    linear-gradient(90deg, rgba(255,255,255,.04), transparent 34%);
  opacity: .72;
}

body[data-section="services"] .practice-showcase::after {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: min(42vw, 760px);
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5,5,5,.50), rgba(5,5,5,.86) 54%, transparent),
    url('/assets/img/photos/gibraltar-ridge.jpg') center / cover no-repeat;
  opacity: .23;
  filter: grayscale(.35) contrast(1.1);
}

body[data-section="services"] .practice-showcase .wrap {
  width: min(100% - clamp(32px, 3vw, 58px), 1880px);
}

body[data-section="services"] .practice-showcase-layout {
  --services-card-height: clamp(310px, 20.6vw, 398px);
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: auto;
  gap: clamp(1.35rem, 1.9vw, 2.18rem);
}

body[data-section="services"] .practice-top-row,
body[data-section="services"] .practice-bottom-row {
  display: grid;
  gap: clamp(1.35rem, 1.9vw, 2.18rem);
  align-items: stretch;
}

body[data-section="services"] .practice-top-row {
  grid-template-columns: minmax(420px, 1.68fr) repeat(4, minmax(185px, 1fr));
}

body[data-section="services"] .practice-bottom-row {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-section="services"] .practice-intro {
  justify-content: flex-start;
  padding: clamp(34px, 3.4vw, 52px) 0 0;
}

body[data-section="services"] .practice-intro .eyebrow {
  margin-bottom: clamp(1rem, 1.7vw, 1.65rem);
  color: var(--gold-2);
  font-size: clamp(.86rem, 1vw, 1.05rem);
  letter-spacing: .36em;
}

body[data-section="services"] .practice-intro h2 {
  max-width: 560px;
  margin-bottom: clamp(1.25rem, 1.65vw, 1.75rem);
  font-size: clamp(2.3rem, 2.35vw, 2.95rem);
  line-height: 1.06;
  letter-spacing: 0;
}

body[data-section="services"] .practice-intro p:not(.eyebrow) {
  max-width: 415px;
  font-size: clamp(1.1rem, 1.2vw, 1.42rem);
  line-height: 1.65;
  color: rgba(255,255,255,.76);
}

body[data-section="services"] .practice-intro .gold-rule {
  width: min(170px, 42%);
  height: 2px;
  margin-top: clamp(1.5rem, 2.8vw, 2.35rem);
  background: linear-gradient(90deg, var(--gold), transparent);
}

body[data-section="services"] .practice-card {
  min-height: var(--services-card-height);
  height: var(--services-card-height);
  max-height: var(--services-card-height);
  padding: clamp(1.35rem, 1.75vw, 2rem);
  border-color: rgba(216,173,24,.68);
  border-radius: 16px;
  box-shadow: 0 28px 80px rgba(0,0,0,.52), inset 0 0 0 1px rgba(255,215,106,.045);
}

body[data-section="services"] .practice-card::before {
  filter: sepia(.38) saturate(.82) contrast(1.22) brightness(.82);
  transform: scale(1.035);
}

body[data-section="services"] .practice-card::after {
  background:
    radial-gradient(circle at 24% 12%, rgba(255,215,106,.16), transparent 22%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.22) 28%, rgba(0,0,0,.72) 76%, rgba(0,0,0,.92) 100%),
    linear-gradient(90deg, rgba(0,0,0,.48), transparent 66%);
}

body[data-section="services"] .practice-card-icon {
  top: clamp(1.55rem, 2.1vw, 2.35rem);
  left: clamp(1.55rem, 2.1vw, 2.35rem);
  width: clamp(58px, 4.1vw, 76px);
  height: clamp(58px, 4.1vw, 76px);
  color: var(--gold-2);
  font-size: clamp(1.28rem, 1.55vw, 1.82rem);
}

body[data-section="services"] .practice-card-icon::before {
  inset: 9px;
  border-color: rgba(255,215,106,.78);
  border-radius: 13px;
  background:
    radial-gradient(circle at 30% 24%, rgba(255,215,106,.24), transparent 34%),
    linear-gradient(135deg, rgba(216,173,24,.10), rgba(17,17,16,.82) 72%);
}

body[data-section="services"] .practice-card-title {
  max-width: 82%;
  font-size: clamp(1.6rem, 1.75vw, 2.18rem);
  line-height: 1.07;
  letter-spacing: 0;
}

body[data-section="services"] .practice-card-title::after {
  width: clamp(64px, 4.2vw, 86px);
  margin-top: clamp(1.25rem, 1.7vw, 1.8rem);
  background: linear-gradient(90deg, var(--gold), rgba(216,173,24,.55), transparent);
}

body[data-section="services"] .practice-card-arrow {
  right: clamp(1.55rem, 1.9vw, 2.15rem);
  bottom: clamp(1.55rem, 1.9vw, 2.15rem);
  font-size: clamp(1.65rem, 2vw, 2.35rem);
  color: var(--gold);
}

@media (min-width: 1101px) {
  body[data-section="services"] .practice-top-row {
    grid-template-columns: minmax(420px, 1.68fr) repeat(4, minmax(185px, 1fr));
  }

  body[data-section="services"] .practice-intro {
    grid-column: auto;
  }
}

@media (max-width: 1100px) {
  body[data-section="services"] .practice-showcase {
    padding-top: clamp(22px, 4vw, 42px);
  }

  body[data-section="services"] .practice-showcase-layout {
    --services-card-height: 320px;
  }

  body[data-section="services"] .practice-top-row,
  body[data-section="services"] .practice-bottom-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-section="services"] .practice-intro {
    grid-column: 1 / -1;
    padding: 0 0 .75rem;
  }
}

@media (max-width: 620px) {
  body[data-section="services"] .practice-showcase .wrap {
    width: min(100% - 28px, 1880px);
  }

  body[data-section="services"] .practice-showcase-layout {
    --services-card-height: 286px;
    gap: 1rem;
  }

  body[data-section="services"] .practice-top-row,
  body[data-section="services"] .practice-bottom-row {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  body[data-section="services"] .practice-intro h2 {
    font-size: clamp(2.5rem, 12vw, 3.4rem);
  }
}

/* Exact supplied services board with clickable service hotspots. */
body[data-section="services"] .services-artboard-section {
  min-height: calc(100svh - 145px);
  display: grid;
  place-items: start center;
  padding: clamp(4px, .7vw, 10px) 0 clamp(20px, 2vw, 34px);
  background: #030303;
  border-top: 1px solid rgba(216,173,24,.30);
  overflow: hidden;
}

.services-artboard-wrap {
  position: relative;
  width: min(calc(100vw - 8px), 2180px);
  max-width: 100%;
}

.services-artboard-img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
}

.services-artboard-hotspots {
  position: absolute;
  inset: 0;
}

.services-hotspot {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  border-radius: 18px;
  background: transparent;
}

.services-hotspot:hover,
.services-hotspot:focus-visible {
  outline: 2px solid rgba(255,215,106,.92);
  outline-offset: 3px;
  background: rgba(255,215,106,.035);
}

@media (max-width: 720px) {
  body[data-section="services"] .services-artboard-section {
    min-height: 0;
    padding: 14px 0 24px;
  }

  .services-artboard-wrap {
    width: min(100% - 20px, 1693px);
  }
}

/* Small bespoke service icons for the Services nav popout. */
.mega-links a[href*="civil-litigation"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v18M5 7h14M7 7l-4 7h8L7 7Zm10 0l-4 7h8l-4-7ZM8 21h8'/%3E%3C/svg%3E"); }
.mega-links a[href*="commerce"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7M10 7h7v7'/%3E%3C/svg%3E"); }
.mega-links a[href*="corporate"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='7' width='16' height='12' rx='2'/%3E%3Cpath d='M9 7V5h6v2M4 12h16'/%3E%3C/svg%3E"); }
.mega-links a[href*="employment"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 19v-1a4 4 0 0 1 8 0v1M12 12a3 3 0 1 0 0-6 3 3 0 0 0 0 6ZM4 18v-.7a3.2 3.2 0 0 1 3-3.2M20 18v-.7a3.2 3.2 0 0 0-3-3.2'/%3E%3C/svg%3E"); }
.mega-links a[href*="criminal-litigation"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m14 5 5 5M12 7l5 5M4 20l6-6M9 15l6-6M7 17l2 2M13 3l8 8-3 3-8-8 3-3Z'/%3E%3C/svg%3E"); }
.mega-links a[href*="family-law"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.35' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.8 8.6c0 5.1-8.8 10.2-8.8 10.2S3.2 13.7 3.2 8.6A4.5 4.5 0 0 1 12 7a4.5 4.5 0 0 1 8.8 1.6Z'/%3E%3C/svg%3E"); }
.mega-links a[href*="trusts"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3 19 6v5c0 4.8-3.1 7.9-7 10-3.9-2.1-7-5.2-7-10V6l7-3Z'/%3E%3Cpath d='m9 12 2 2 4-5'/%3E%3C/svg%3E"); }
.mega-links a[href*="residence"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M3 11.5 12 4l9 7.5-1.8 2.1-1.2-1V20h-5v-5h-4v5h-5v-7.4l-1.2 1L3 11.5Z'/%3E%3C/svg%3E"); }
.mega-links a[href*="private-client"] { --mega-service-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M5 21a7 7 0 0 1 14 0H5Z'/%3E%3C/svg%3E"); }

.mega-links a span {
  font-size: 0 !important;
  color: var(--gold-2) !important;
  background: transparent !important;
}

.mega-links a span::after {
  content: '';
  width: 21px;
  height: 21px;
  display: block;
  background: currentColor;
  -webkit-mask: var(--mega-service-icon, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Ccircle cx='12' cy='12' r='5'/%3E%3C/svg%3E")) center / contain no-repeat;
  mask: var(--mega-service-icon, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Ccircle cx='12' cy='12' r='5'/%3E%3C/svg%3E")) center / contain no-repeat;
}

@media (min-width: 721px) {
  .exact-hero {
    width: 100vw !important;
    max-width: none !important;
    min-height: 0 !important;
    aspect-ratio: 1934 / 813 !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    background: #030303 url('../img/home-hero-clean.png') center center / 100% 100% no-repeat !important;
  }

  .exact-hero::before {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 2 !important;
    pointer-events: none !important;
    background:
      linear-gradient(90deg, rgba(3,3,3,.74) 0%, rgba(3,3,3,.50) 24%, rgba(3,3,3,.10) 47%, rgba(3,3,3,0) 76%),
      linear-gradient(0deg, rgba(3,3,3,.25) 0%, rgba(3,3,3,.04) 45%, rgba(3,3,3,0) 100%) !important;
  }

  .exact-hero .agency-hero-inner.wrap {
    width: 100% !important;
    max-width: none !important;
    height: 100% !important;
    min-height: 0 !important;
    padding-left: clamp(28px, 1.55vw, 36px) !important;
    padding-right: clamp(24px, 2vw, 42px) !important;
    box-sizing: border-box !important;
  }

  .exact-hero .agency-copy {
    width: min(38vw, 650px) !important;
    padding: clamp(3.25rem, 5vw, 5.6rem) 0 clamp(2.1rem, 3.4vw, 3.9rem) !important;
  }

  .exact-hero .agency-copy h1 {
    max-width: 680px !important;
    font-size: clamp(4rem, 4.45vw, 5.75rem) !important;
    line-height: .94 !important;
  }

  .exact-hero .agency-hero-art {
    display: none !important;
  }
}
