/*
Theme Name: Fintech Passport
Theme URI: https://fintechpassport.eu
Author: Fintech Passport
Author URI: https://fintechpassport.eu
Description: A modern, EU-focused regulatory boutique theme. Clear blue, white & black. Built for Gutenberg, with Regulator and Country taxonomies wired into the Insights system.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fintech-passport
Tags: blog, business, custom-colors, custom-logo, custom-menu, editor-style, featured-images, full-site-editing, full-width-template, theme-options, threaded-comments, translation-ready
*/

/* ===== Tokens ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Instrument+Serif:ital@0;1&display=swap');

:root {
  --fp-ink:        #000000;
  --fp-ink-2:      #111111;
  --fp-cobalt:     #0047FF;
  --fp-cobalt-2:   #1F66FF;
  --fp-cobalt-3:   #E6EEFF;
  --fp-paper:      #F6F7F9;
  --fp-paper-2:    #EEF0F4;
  --fp-line:       #E4E7EC;
  --fp-text:       #000000;
  --fp-text-muted: #5A6072;
  --fp-sans: 'Inter Tight', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --fp-serif: 'Instrument Serif', 'Times New Roman', Georgia, serif;
  --fp-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* ===== Reset & base ===== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--fp-sans);
  font-size: 17px;
  line-height: 1.55;
  color: var(--fp-text);
  background: #fff;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--fp-cobalt); }
img { max-width: 100%; height: auto; display: block; }
em.serif, .fp-italic { font-family: var(--fp-serif); font-style: italic; font-weight: 400; }

h1, h2, h3, h4 { font-weight: 600; letter-spacing: -.02em; line-height: 1.05; margin: 0 0 16px; }
h1 { font-size: clamp(48px, 6vw, 84px); letter-spacing: -.03em; }
h2 { font-size: clamp(36px, 4vw, 56px); letter-spacing: -.025em; }
h3 { font-size: 26px; }
h4 { font-size: 20px; }
p  { margin: 0 0 16px; }

.wrap { max-width: 1320px; margin: 0 auto; padding: 0 32px; }

/* ===== Buttons ===== */
.fp-btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 20px; border-radius: 999px; font-size: 14px; font-weight: 500; border: 1px solid transparent; cursor: pointer; transition: all .15s; }
.fp-btn--primary { background: #000; color: #fff; }
.fp-btn--primary:hover { background: var(--fp-cobalt); color: #fff; }
.fp-btn--cobalt { background: var(--fp-cobalt); color: #fff; }
.fp-btn--ghost { background: #fff; border-color: var(--fp-line); color: #000; }
.fp-btn--ghost:hover { border-color: #000; color: #000; }

/* ===== Header / nav ===== */
.fp-header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid var(--fp-line); }
.fp-header__inner { display: flex; align-items: center; justify-content: space-between; padding: 18px 32px; max-width: 1480px; margin: 0 auto; gap: 32px; }
.fp-logo { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 16px; letter-spacing: -.3px; }
.fp-logo svg { width: 26px; height: 26px; }
.fp-nav { display: flex; gap: 28px; font-size: 14px; }
.fp-nav a.current-menu-item, .fp-nav a[aria-current="page"] { color: var(--fp-cobalt); font-weight: 600; }
.fp-header__cta { display: flex; gap: 10px; align-items: center; }

/* Mobile nav toggle */
.fp-nav-toggle { display: none; background: none; border: 1px solid var(--fp-line); border-radius: 999px; width: 44px; height: 44px; align-items: center; justify-content: center; cursor: pointer; padding: 0;}
.fp-nav-toggle svg { width: 20px; height: 20px; }
.fp-mobile-nav { display: none; position: fixed; inset: 64px 0 0; background: #fff; z-index: 60; padding: 32px; flex-direction: column; gap: 8px; overflow-y: auto;}
.fp-mobile-nav.is-open { display: flex; }
.fp-mobile-nav a { font-size: 24px; padding: 16px 0; border-bottom: 1px solid var(--fp-line); letter-spacing: -.5px;}
.fp-mobile-nav .fp-btn { margin-top: 16px; justify-content: center; padding: 16px;}

@media (max-width: 1024px) {
  .fp-nav { display: none; }
  .fp-nav-toggle { display: inline-flex; }
  .fp-header__cta .fp-btn--ghost { display: none; }
  .fp-header__cta .fp-btn--primary { padding: 10px 14px; font-size: 13px;}
}
@media (max-width: 600px) {
  .fp-header__cta .fp-btn--primary span { display: none; }
}

/* ===== Footer ===== */
.fp-footer { padding: 64px 32px 40px; max-width: 1480px; margin: 0 auto; }
.fp-footer__cols { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
.fp-footer h4 { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fp-text-muted); margin: 0 0 16px; font-weight: 500; }
.fp-footer a { display: block; padding: 4px 0; font-size: 14px; }
.fp-footer__sign { margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--fp-line); display: flex; justify-content: space-between; font-size: 12px; color: var(--fp-text-muted); }
@media (max-width: 800px) { .fp-footer__cols { grid-template-columns: 1fr 1fr; } }

/* ===== Hero ===== */
.fp-hero { padding: 24px 32px 0; max-width: 1480px; margin: 0 auto; }
.fp-hero__card { background: var(--fp-paper); border-radius: 32px; padding: clamp(40px, 6vw, 72px); display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: center; }
.fp-hero__badges { display: flex; gap: 8px; margin-bottom: 24px; flex-wrap: wrap; }
.fp-badge { padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 500; background: #fff; border: 1px solid var(--fp-line); display: inline-flex; align-items: center; gap: 6px; }
.fp-badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--fp-cobalt); }
.fp-hero__lead { font-size: 18px; color: var(--fp-text-muted); margin: 24px 0 32px; max-width: 46ch; line-height: 1.55; }
.fp-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 900px) { .fp-hero__card { grid-template-columns: 1fr; padding: 32px 24px;} .fp-hero { padding: 16px 16px 0;} }
@media (max-width: 600px) { .fp-hero__ctas .fp-btn { flex: 1; justify-content: center;} }

/* ===== Service grid ===== */
.fp-section { padding: 80px 32px; max-width: 1480px; margin: 0 auto; }
.fp-section__head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 40px; gap: 32px; flex-wrap: wrap; }
.fp-eyebrow { font-size: 13px; color: var(--fp-text-muted); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }
.fp-svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.fp-svc { border-radius: 24px; padding: 28px; min-height: 260px; display: flex; flex-direction: column; justify-content: space-between; transition: transform .2s; cursor: pointer; }
.fp-svc:hover { transform: translateY(-2px); }
.fp-svc--a { background: var(--fp-cobalt-3); }
.fp-svc--b { background: var(--fp-paper); }
.fp-svc--c { background: #fff; border: 1px solid var(--fp-line); }
.fp-svc--d { background: #000; color: #fff; }
.fp-svc--e { background: var(--fp-cobalt); color: #fff; }
.fp-svc--f { background: var(--fp-paper-2); }
.fp-svc__num { font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; opacity: .65; }
.fp-svc h3 { margin: 16px 0 8px; }
.fp-svc p  { font-size: 14px; opacity: .8; line-height: 1.5; margin: 0; }
.fp-svc__more { display: inline-flex; align-items: center; gap: 6px; margin-top: 20px; font-size: 14px; font-weight: 500; }
@media (max-width: 1024px) { .fp-svc-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .fp-svc-grid { grid-template-columns: 1fr; } .fp-section { padding: 48px 16px;} }

/* ===== Insights / posts ===== */
.fp-cat { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; background: var(--fp-cobalt-3); color: var(--fp-cobalt); align-self: flex-start; }
.fp-cat--eba   { background: var(--fp-cobalt-3); color: var(--fp-cobalt); }
.fp-cat--bde   { background: #FFF4D9; color: #8A6500; }
.fp-cat--acpr  { background: #FCE6F4; color: #9C2A78; }
.fp-cat--bdi   { background: #E6F4EA; color: #1F7A4D; }
.fp-cat--bafin { background: #F4ECE6; color: #6B3A1A; }
.fp-cat--dnb   { background: #FFE6E6; color: #B23A2E; }
.fp-cat--cssf  { background: #EDE6FF; color: #4527A0; }
.fp-cat--sepblac { background: #FFE6E6; color: #B23A2E; }

.fp-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.fp-post { border: 1px solid var(--fp-line); border-radius: 24px; padding: 28px; min-height: 260px; display: flex; flex-direction: column; justify-content: space-between; background: #fff; transition: transform .2s; }
.fp-post:hover { transform: translateY(-2px); border-color: var(--fp-cobalt); }
.fp-post h3 { font-size: 22px; line-height: 1.18; margin: 16px 0 8px; }
.fp-post p  { font-size: 14px; color: var(--fp-text-muted); margin: 0; }
.fp-post__meta { display: flex; justify-content: space-between; margin-top: 20px; font-size: 12px; color: var(--fp-text-muted); }
@media (max-width: 1024px) { .fp-posts { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .fp-posts { grid-template-columns: 1fr; } }

/* ===== Filter bar ===== */
.fp-filters { padding: 24px 0; }
.fp-filter-row { display: grid; grid-template-columns: 180px 1fr; gap: 32px; padding: 16px 0; align-items: center; }
.fp-filter-row + .fp-filter-row { border-top: 1px solid var(--fp-line); }
.fp-filter__label { font-size: 11px; letter-spacing: 0.1em; color: var(--fp-text-muted); text-transform: uppercase; font-weight: 600; }
.fp-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.fp-chip { padding: 8px 14px; border-radius: 999px; font-size: 13px; border: 1px solid var(--fp-line); background: #fff; cursor: pointer; }
.fp-chip:hover { border-color: #000; }
.fp-chip.is-active { background: #000; color: #fff; border-color: #000; }
@media (max-width: 700px) { .fp-filter-row { grid-template-columns: 1fr; } }

/* ===== How it works ===== */
.fp-how { background: #000; color: #fff; border-radius: 32px; padding: clamp(40px, 6vw, 72px); }
.fp-how h2 { color: #fff; }
.fp-how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px; }
.fp-step { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 20px; padding: 24px; }
.fp-step__n { width: 36px; height: 36px; border-radius: 50%; background: var(--fp-cobalt); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 14px; }
.fp-step h4 { margin: 16px 0 8px; }
.fp-step p { font-size: 13px; opacity: .7; line-height: 1.5; margin: 0; }
@media (max-width: 1024px) { .fp-how-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .fp-how-grid { grid-template-columns: 1fr; } .fp-how { padding: 32px 24px;} }

/* ===== CTA ===== */
.fp-cta { background: var(--fp-cobalt); color: #fff; border-radius: 32px; padding: clamp(48px, 6vw, 80px); display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: center; }
.fp-cta h2 { color: #fff; }
.fp-cta p { color: rgba(255,255,255,.85); margin: 0 0 24px; }
@media (max-width: 900px) { .fp-cta { grid-template-columns: 1fr; } }

/* ===== Article ===== */
.fp-article { max-width: 760px; margin: 0 auto; padding: 64px 32px; }
.fp-article h1 { font-size: clamp(36px, 5vw, 64px); }
.fp-article h2 { font-size: clamp(28px, 3vw, 36px); margin-top: 48px; }
.fp-article h3 { font-size: 22px; margin-top: 32px; }
.fp-article p, .fp-article li { font-size: 17px; line-height: 1.7; }
.fp-article .lede { font-family: var(--fp-serif); font-style: italic; font-size: 26px; line-height: 1.35; margin: 32px 0 24px; }
.fp-article table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 14px; }
.fp-article th, .fp-article td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--fp-line); }
.fp-article th { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fp-text-muted); font-weight: 600; background: var(--fp-paper); }
.fp-callout { background: var(--fp-cobalt-3); border-radius: 16px; padding: 24px; margin: 32px 0; border-left: 4px solid var(--fp-cobalt); }
.fp-callout__label { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fp-cobalt); font-weight: 600; }

/* Article tables scroll horizontally on mobile */
@media (max-width: 700px) {
  .fp-article { padding: 32px 20px; }
  .fp-article table { display: block; overflow-x: auto; white-space: nowrap; }
  .fp-article .lede { font-size: 22px; }
}

/* ===== WP-specific ===== */
.alignwide { max-width: 1200px; margin-left: auto; margin-right: auto; }
.alignfull { max-width: 100vw; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }
.wp-block-image img { border-radius: 16px; }
.wp-caption-text, .wp-block-image figcaption { font-size: 13px; color: var(--fp-text-muted); text-align: center; margin-top: 8px; }
blockquote, .wp-block-quote { font-family: var(--fp-serif); font-style: italic; font-size: 24px; line-height: 1.3; border-left: 4px solid var(--fp-cobalt); padding-left: 24px; margin: 32px 0; }

/* Pagination */
.fp-pagination { display: flex; justify-content: center; gap: 8px; padding: 48px 0; }
.fp-pagination a, .fp-pagination span { padding: 10px 16px; border-radius: 999px; border: 1px solid var(--fp-line); font-size: 14px; }
.fp-pagination .current { background: #000; color: #fff; border-color: #000; }
/* ============================================================
   v1.1 — additions for missing patterns + polish
   ============================================================ */

/* Skip link */
.fp-skip { position: absolute; left: -9999px; top: 0; background: #000; color: #fff; padding: 12px 16px; z-index: 100; }
.fp-skip:focus { left: 16px; top: 16px; }

/* Header logo image sizing */
.fp-logo img { height: 28px; width: auto; display: block; }

/* Lead utility */
.fp-lead { font-size: 18px; color: var(--fp-text-muted); max-width: 64ch; line-height: 1.55; margin: 16px 0 0; }
.fp-mono { font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; }
.fp-muted { color: var(--fp-text-muted); }

/* Filter chips (services-detail + insights) */
.fp-filters, .fp-insights-filters { padding: 24px 0; border-top: 1px solid var(--fp-line); border-bottom: 1px solid var(--fp-line); margin: 32px 0; }
.fp-filter-row { display: grid; grid-template-columns: 200px 1fr; gap: 32px; padding: 14px 0; align-items: center; }
.fp-filter-row + .fp-filter-row { border-top: 1px dashed var(--fp-line); }
.fp-filter-label { font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--fp-text-muted); text-transform: uppercase; }
.fp-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.fp-chip { padding: 8px 14px; border: 1px solid var(--fp-line); border-radius: 999px; font-size: 13px; cursor: pointer; background: #fff; color: #000; text-decoration: none; font: inherit; line-height: 1; }
.fp-chip.is-active, a.fp-chip.is-active { background: #000; color: #fff; border-color: #000; }
.fp-chip:hover { border-color: #000; }
@media (max-width: 700px) {
  .fp-filter-row { grid-template-columns: 1fr; gap: 12px; }
}

/* Engagement grid (services-detail) */
.fp-results__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 24px; }
.fp-results__head h3 { font-family: var(--fp-serif); font-size: 28px; font-weight: 400; margin: 0; }
.fp-engagement-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--fp-line); border: 1px solid var(--fp-line); border-radius: 16px; overflow: hidden; }
.fp-engagement { background: #fff; padding: 32px; display: flex; flex-direction: column; gap: 12px; }
.fp-engagement header { display: flex; justify-content: space-between; align-items: flex-start; }
.fp-stamp { display: inline-block; padding: 4px 10px; border: 1px solid var(--fp-cobalt); border-radius: 999px; color: var(--fp-cobalt); font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }
.fp-stamp--new { color: #000; border-color: #000; }
.fp-engagement h3 { font-size: 26px; letter-spacing: -.5px; margin: 8px 0 4px; }
.fp-engagement p { color: var(--fp-text-muted); font-size: 15px; }
.fp-engagement ul { font-size: 13px; color: var(--fp-text-muted); list-style: none; padding: 0; margin: 8px 0 0; display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.fp-engagement ul li::before { content: "·"; color: var(--fp-cobalt); font-weight: bold; margin-right: 6px; }
.fp-engagement footer { margin-top: auto; display: flex; justify-content: space-between; align-items: center; padding-top: 20px; border-top: 1px solid var(--fp-line); }
.fp-engagement footer a { color: var(--fp-cobalt); font-weight: 500; font-size: 14px; }
.fp-bespoke { margin-top: 32px; padding: 28px 32px; background: var(--fp-paper); border-radius: 16px; display: grid; grid-template-columns: 2fr 1fr; gap: 24px; align-items: center; }
.fp-bespoke h3 { font-family: var(--fp-serif); font-size: 30px; font-weight: 400; margin: 4px 0 8px; letter-spacing: -.4px; }
.fp-bespoke p { color: var(--fp-text-muted); margin: 0; font-size: 15px; max-width: 50ch; }
.fp-bespoke .fp-btn { justify-self: end; }
@media (max-width: 800px) {
  .fp-engagement-grid { grid-template-columns: 1fr; }
  .fp-engagement ul { grid-template-columns: 1fr; }
  .fp-bespoke { grid-template-columns: 1fr; }
  .fp-bespoke .fp-btn { justify-self: start; }
}

/* Country grid */
.fp-country-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.fp-country { background: #fff; border: 1px solid var(--fp-line); border-radius: 16px; padding: 24px; display: flex; flex-direction: column; gap: 8px; min-height: 180px; position: relative; transition: border-color .15s, transform .15s; }
.fp-country:hover { border-color: var(--fp-cobalt); transform: translateY(-2px); color: inherit; }
.fp-country__iso { font-family: var(--fp-mono); font-size: 13px; letter-spacing: 0.1em; color: var(--fp-text-muted); }
.fp-country__name { font-size: 24px; font-weight: 600; letter-spacing: -.5px; }
.fp-country__regs { font-size: 13px; color: var(--fp-text-muted); margin-top: auto; }
.fp-country__pill { position: absolute; top: 16px; right: 16px; font-family: var(--fp-mono); font-size: 10px; letter-spacing: 0.1em; padding: 4px 10px; border-radius: 999px; text-transform: uppercase; }
.fp-country--core .fp-country__pill { background: #000; color: #fff; }
.fp-country--onboarding .fp-country__pill { background: #fff; color: var(--fp-cobalt); border: 1px solid var(--fp-cobalt); }
.fp-country--referral { background: var(--fp-paper); border-style: dashed; }
.fp-country--referral .fp-country__pill { background: var(--fp-paper-2); color: var(--fp-text-muted); }
.fp-country--cta { border-style: dashed; border-color: var(--fp-cobalt); color: var(--fp-cobalt); }
@media (max-width: 1024px) { .fp-country-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px)  { .fp-country-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px)  { .fp-country-grid { grid-template-columns: 1fr; } }

/* About — partners, story, values */
.fp-about-hero h1 { max-width: 18ch; }
.fp-partner-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px; }
.fp-partner { background: var(--fp-paper); border-radius: 16px; padding: 28px; }
.fp-partner__photo { width: 64px; height: 64px; border-radius: 50%; background: #000; color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--fp-serif); font-style: italic; font-size: 24px; margin-bottom: 16px; }
.fp-partner h3 { font-size: 22px; margin: 0 0 4px; }
.fp-partner p { font-size: 14px; color: var(--fp-text-muted); margin: 8px 0 0; }
.fp-story__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; }
.fp-story__body p { font-size: 17px; color: var(--fp-text-muted); }
.fp-values__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 24px; }
.fp-values__grid > div { padding: 24px; border: 1px solid var(--fp-line); border-radius: 16px; }
.fp-values__grid h3 { font-size: 18px; margin: 0 0 8px; }
.fp-values__grid p { font-size: 14px; color: var(--fp-text-muted); margin: 0; }
@media (max-width: 1024px) { .fp-partner-grid { grid-template-columns: 1fr 1fr; } .fp-values__grid { grid-template-columns: 1fr 1fr; } .fp-story__grid { grid-template-columns: 1fr; gap: 24px; } }
@media (max-width: 600px)  { .fp-partner-grid { grid-template-columns: 1fr; } .fp-values__grid { grid-template-columns: 1fr; } }

/* Contact form */
.fp-contact h1 { max-width: 22ch; }
.fp-contact__grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 48px; margin-top: 40px; align-items: start; }
.fp-contact__form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; background: var(--fp-paper); padding: 32px; border-radius: 20px; }
.fp-field { display: flex; flex-direction: column; gap: 6px; }
.fp-field--full { grid-column: 1 / -1; }
.fp-field label { font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--fp-text-muted); text-transform: uppercase; }
.fp-field input, .fp-field select, .fp-field textarea { font: inherit; padding: 12px 14px; border: 1px solid var(--fp-line); border-radius: 10px; background: #fff; color: #000; }
.fp-field input:focus, .fp-field select:focus, .fp-field textarea:focus { outline: 2px solid var(--fp-cobalt); outline-offset: -1px; border-color: var(--fp-cobalt); }
.fp-field textarea { resize: vertical; }
.fp-field--full button { margin-right: 16px; }
.fp-offices { display: grid; gap: 24px; }
.fp-offices p { margin: 4px 0 0; font-size: 15px; }
.fp-offices a { color: var(--fp-cobalt); }
.fp-offices__direct { padding-top: 16px; border-top: 1px solid var(--fp-line); display: flex; flex-direction: column; gap: 4px; }
@media (max-width: 900px) { .fp-contact__grid { grid-template-columns: 1fr; } .fp-contact__form { grid-template-columns: 1fr; } }

/* Proof — testimonial + stats */
.fp-proof__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 24px; }
.fp-proof__quote { margin: 0; padding: 32px; background: var(--fp-paper); border-radius: 20px; }
.fp-proof__quote blockquote { font-size: 28px; line-height: 1.25; border: none; padding: 0; margin: 16px 0; }
.fp-proof__quote figcaption { font-size: 14px; color: var(--fp-text-muted); }
.fp-stat { padding: 32px; background: #fff; border: 1px solid var(--fp-line); border-radius: 20px; display: flex; flex-direction: column; gap: 8px; }
.fp-stat__num { font-family: var(--fp-serif); font-size: 72px; line-height: 1; letter-spacing: -.04em; }
.fp-stat__label { font-size: 16px; font-weight: 600; }
.fp-stat--cobalt { background: var(--fp-cobalt); color: #fff; border-color: var(--fp-cobalt); }
.fp-stat--cobalt .fp-mono { color: rgba(255,255,255,.85); }
@media (max-width: 1024px) { .fp-proof__grid { grid-template-columns: 1fr 1fr; } .fp-proof__quote { grid-column: 1 / -1; } }
@media (max-width: 600px)  { .fp-proof__grid { grid-template-columns: 1fr; } }

/* Mobile sticky "Book a call" CTA */
.fp-sticky-cta { position: fixed; right: 16px; bottom: 16px; z-index: 70; background: var(--fp-cobalt); color: #fff !important; padding: 14px 20px; border-radius: 999px; font-weight: 600; font-size: 14px; box-shadow: 0 8px 24px rgba(0,71,255,.3); opacity: 0; transform: translateY(8px); transition: opacity .2s, transform .2s; pointer-events: none; }
.fp-sticky-cta.is-on { opacity: 1; transform: none; pointer-events: auto; }
@media (min-width: 901px) { .fp-sticky-cta { display: none; } }

/* iPad-landscape polish */
@media (min-width: 901px) and (max-width: 1180px) {
  .fp-section { padding: 64px 24px; }
  .fp-svc-grid { grid-template-columns: repeat(2, 1fr); }
  .fp-engagement-grid { grid-template-columns: repeat(2, 1fr); }
  .fp-country-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ============================================================
   v1.2 — clickable service cards, book-a-call form, form messages
   ============================================================ */

/* Make whole service card clickable */
a.fp-svc { text-decoration: none; color: inherit; cursor: pointer; }
a.fp-svc:hover { color: inherit; }
a.fp-svc:hover .fp-svc__more { color: var(--fp-cobalt); transform: translateX(4px); }
.fp-svc__more { transition: transform .15s, color .15s; }

/* Smooth scroll + offset for sticky header anchors */
html { scroll-behavior: smooth; }
.fp-engagement[id] { scroll-margin-top: 96px; }

/* Book-a-call inline form */
.fp-book-call__inner { background: var(--fp-paper); border-radius: 24px; padding: 40px; display: grid; grid-template-columns: 1fr 1.1fr; gap: 40px; align-items: center; }
.fp-book-call__copy h2 { margin: 8px 0 12px; font-size: clamp(32px, 4vw, 48px); }
.fp-book-call__copy p { color: var(--fp-text-muted); margin: 0; max-width: 42ch; }
.fp-book-call__form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; background: #fff; border: 1px solid var(--fp-line); border-radius: 16px; padding: 24px; }
.fp-book-call__form .fp-field--full { grid-column: 1 / -1; }
@media (max-width: 900px) {
  .fp-book-call__inner { grid-template-columns: 1fr; padding: 28px; }
  .fp-book-call__form { grid-template-columns: 1fr; }
}

/* Form status message */
.fp-form-msg { grid-column: 1 / -1; padding: 0; font-size: 14px; min-height: 0; transition: padding .15s; }
.fp-form-msg.is-ok, .fp-form-msg.is-err { padding: 12px 14px; border-radius: 10px; }
.fp-form-msg.is-ok { background: var(--fp-cobalt-3); color: var(--fp-cobalt); border: 1px solid var(--fp-cobalt); }
.fp-form-msg.is-err { background: #FFF0F0; color: #B00020; border: 1px solid #B00020; }

/* v1.3 — about-page expertise grid (no photos) + footer legal links */
.fp-expertise__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px; }
.fp-expertise__grid .fp-partner { display: flex; flex-direction: column; gap: 8px; }
.fp-expertise__grid .fp-partner h3 { margin: 8px 0 4px; }
.fp-expertise__grid .fp-partner p { font-size: 15px; }
@media (max-width: 1024px) { .fp-expertise__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .fp-expertise__grid { grid-template-columns: 1fr; } }

.fp-footer__legal { display: inline-flex; gap: 16px; }
.fp-footer__legal a { display: inline; padding: 0; }
@media (max-width: 700px) { .fp-footer__sign { flex-direction: column; gap: 8px; align-items: flex-start; } }

/* v1.4 — article CTA, figure sizing, callout styling */
.fp-article .fp-figure { margin: 32px 0; padding: 24px; background: var(--fp-paper); border-radius: 16px; }
.fp-article .fp-figure svg { width: 100%; height: auto; max-width: 100%; display: block; }
.fp-article .fp-figure figcaption { margin-top: 16px; font-size: 14px; color: var(--fp-text-muted); text-align: center; }

.fp-article aside.fp-callout { margin: 28px 0; padding: 20px 24px; background: var(--fp-cobalt-3); border-left: 4px solid var(--fp-cobalt); border-radius: 12px; font-size: 16px; line-height: 1.55; }
.fp-article aside.fp-callout strong { color: var(--fp-cobalt); }

.fp-article-cta { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; align-items: center; margin: 56px 0 16px; padding: 32px; background: #000; color: #fff; border-radius: 24px; }
.fp-article-cta h3 { color: #fff; font-size: 32px; margin: 8px 0 12px; }
.fp-article-cta p { color: rgba(255,255,255,.78); margin: 0; max-width: 56ch; font-size: 16px; }
.fp-article-cta .fp-eyebrow { color: rgba(255,255,255,.7); }
.fp-article-cta .fp-btn--primary { background: var(--fp-cobalt); color: #fff; justify-self: end; }
.fp-article-cta .fp-btn--primary:hover { background: #fff; color: var(--fp-cobalt); }
@media (max-width: 800px) {
  .fp-article-cta { grid-template-columns: 1fr; padding: 28px; }
  .fp-article-cta .fp-btn--primary { justify-self: start; }
}

/* v1.5 — article hero header */
.fp-article-hero { max-width: 1320px; margin: 0 auto; padding: 48px 32px 16px; }
.fp-article-hero__inner { max-width: 880px; margin: 0 auto; }
.fp-article-hero__meta { font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--fp-text-muted); text-transform: uppercase; margin-bottom: 24px; }
.fp-article-hero__meta a { color: var(--fp-text-muted); }
.fp-article-hero__meta a:hover { color: var(--fp-cobalt); }
.fp-article-hero__title { font-size: clamp(40px, 5vw, 72px); letter-spacing: -.025em; margin: 0 0 24px; max-width: 22ch; }
.fp-article-hero__byline { font-size: 14px; color: var(--fp-text-muted); padding-bottom: 32px; border-bottom: 1px solid var(--fp-line); }
.fp-article-hero__byline strong { color: #000; font-weight: 600; }

.fp-article-hero__image { margin: 32px 0 8px; padding: 0; }
.fp-article-hero__image img,
.fp-article-hero__image svg { width: 100%; height: auto; display: block; border-radius: 24px; aspect-ratio: 1200 / 360; object-fit: cover; }
.fp-article-hero__image--default svg { aspect-ratio: 1200 / 360; }
@media (max-width: 700px) {
  .fp-article-hero { padding: 32px 16px 8px; }
  .fp-article-hero__image img, .fp-article-hero__image svg { border-radius: 16px; }
}

/* v1.6 — post-card thumbnails + latest-on-home section */
.fp-post { display: flex; flex-direction: column; gap: 0; padding: 0; overflow: hidden; }
.fp-post__thumb { width: 100%; aspect-ratio: 16 / 9; overflow: hidden; background: #000; }
.fp-post__thumb img,
.fp-post__thumb svg { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .25s; }
.fp-post:hover .fp-post__thumb img,
.fp-post:hover .fp-post__thumb svg { transform: scale(1.04); }
.fp-post__body { padding: 24px 24px 8px; flex: 1; }
.fp-post__body h3 { margin: 12px 0 8px; }
.fp-post__body p { font-size: 14px; color: var(--fp-text-muted); margin: 0; }
.fp-post__meta { padding: 16px 24px; border-top: 1px solid var(--fp-line); display: flex; justify-content: space-between; font-family: var(--fp-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--fp-text-muted); text-transform: uppercase; }

/* v1.7 — services 5+1 grid (incl. CTA card) */
.fp-engagement-grid--five { grid-template-columns: repeat(3, 1fr); }
.fp-engagement--cta { background: #000; color: #fff; }
.fp-engagement--cta header span,
.fp-engagement--cta h3,
.fp-engagement--cta p { color: #fff; }
.fp-engagement--cta p { color: rgba(255,255,255,.78); }
.fp-engagement--cta .fp-btn--primary { background: var(--fp-cobalt); color: #fff; align-self: flex-start; }
.fp-engagement--cta .fp-btn--primary:hover { background: #fff; color: var(--fp-cobalt); }
@media (max-width: 1024px) { .fp-engagement-grid--five { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px)  { .fp-engagement-grid--five { grid-template-columns: 1fr; } }

/* v1.8 — privacy consent on forms */
.fp-form-consent { grid-column: 1 / -1; margin: 4px 0 0; font-size: 12px; color: var(--fp-text-muted); line-height: 1.5; }
.fp-form-consent a { color: var(--fp-cobalt); text-decoration: underline; }
.fp-form-consent em { font-family: var(--fp-serif); font-style: italic; color: #000; }

/* v1.9 — FAQ disclosure list */
.fp-faq { display: flex; flex-direction: column; gap: 12px; margin: 24px 0; }
.fp-faq details { background: var(--fp-paper); border: 1px solid var(--fp-line); border-radius: 12px; padding: 16px 20px; transition: border-color .15s; }
.fp-faq details[open] { border-color: var(--fp-cobalt); background: #fff; }
.fp-faq summary { cursor: pointer; font-weight: 600; font-size: 17px; list-style: none; position: relative; padding-right: 32px; line-height: 1.4; }
.fp-faq summary::-webkit-details-marker { display: none; }
.fp-faq summary::after { content: "+"; position: absolute; right: 0; top: 0; font-size: 22px; color: var(--fp-cobalt); transition: transform .15s; }
.fp-faq details[open] summary::after { content: "−"; }
.fp-faq details p { margin: 12px 0 0; color: var(--fp-text-muted); font-size: 16px; }

/* v2.0 — header search + insights filters */
.fp-search-toggle { width: 40px; height: 40px; border-radius: 999px; background: #fff; border: 1px solid var(--fp-line); color: #000; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.fp-search-toggle:hover { border-color: var(--fp-cobalt); color: var(--fp-cobalt); }
.fp-search { display: none; padding: 16px 32px; border-bottom: 1px solid var(--fp-line); background: #fff; max-width: 1480px; margin: 0 auto; gap: 10px; align-items: center; }
.fp-search.is-open { display: flex; }
.fp-search input[type=search] { flex: 1; font: inherit; padding: 12px 16px; border: 1px solid var(--fp-line); border-radius: 999px; outline: none; }
.fp-search input[type=search]:focus { border-color: var(--fp-cobalt); outline: 2px solid var(--fp-cobalt); outline-offset: -1px; }
.fp-search button { white-space: nowrap; padding: 12px 20px; }
@media (max-width: 600px) {
  .fp-search { padding: 12px 16px; }
  .fp-search button { padding: 10px 14px; font-size: 13px; }
}

/* v2.1 — article top hero */
.fp-article > .fp-article-hero { margin: 0 0 32px; padding: 0; border-radius: 24px; overflow: hidden; background: var(--fp-paper); }
.fp-article > .fp-article-hero img,
.fp-article > .fp-article-hero svg { width: 100%; height: auto; display: block; aspect-ratio: 1200 / 540; object-fit: cover; }
@media (max-width: 700px) {
  .fp-article > .fp-article-hero { border-radius: 16px; margin-bottom: 20px; }
}
