/* =======================================================================
   CARTA Theme — base + components
   Brand: Open Sans (headings), Roboto (body)
   Colors: Brand brown #8d5523 / Mustard #e8b223 / Grey #a6a4a9 / Black
   ======================================================================= */

:root {
    /* Brand */
    --carta-brown:      #8d5523;
    --carta-brown-700:  #6e3f15;
    --carta-brown-100:  #f6efe6;
    --carta-mustard:    #e8b223;
    --carta-mustard-700:#b4870c;
    --carta-mustard-100:#fbf2d4;
    --carta-grey:       #a6a4a9;
    --carta-grey-200:   #e9e8eb;
    --carta-grey-700:   #6b6970;
    --carta-black:      #000000;
    --carta-white:      #ffffff;
    --carta-cream:      #FFFDF8;
    --carta-ink:        #2C2418;
    --carta-muted:      #5C5043;

    /* Fonts: --carta-ff-* is set inline by enqueue.php from Customizer */
    --carta-ff-heading: 'Open Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
    --carta-ff-body:    'Roboto', system-ui, -apple-system, 'Segoe UI', sans-serif;

    /* Layout */
    --carta-container:  1200px;
    --carta-radius:     10px;
    --carta-shadow:     0 10px 30px rgba(15,23,42,.08);
    --carta-shadow-sm:  0 2px 8px rgba(15,23,42,.06);
    --carta-header-h:   80px;
    --carta-topbar-h:   28px;

    /* Type scale */
    --carta-fs-xs:  0.8125rem;
    --carta-fs-sm:  0.9375rem;
    --carta-fs-md:  1.0625rem;
    --carta-fs-lg:  1.25rem;
    --carta-fs-xl:  1.75rem;
    --carta-fs-2xl: 2.5rem;
    --carta-fs-3xl: 3.25rem;
}

/* -------- Reset-ish baseline (does not override Elementor pages) -------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--carta-ff-body);
    font-size: var(--carta-fs-md);
    line-height: 1.65;
    color: var(--carta-ink);
    background: var(--carta-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--carta-ff-heading);
    color: var(--carta-ink);
    line-height: 1.2;
    margin: 0 0 .6em;
    font-weight: 700;
}
h1 { font-size: clamp(2rem, 4vw, var(--carta-fs-3xl)); }
h2 { font-size: clamp(1.5rem, 3vw, var(--carta-fs-2xl)); }
h3 { font-size: clamp(1.25rem, 2vw, var(--carta-fs-xl)); }
h4 { font-size: var(--carta-fs-lg); }

p { margin: 0 0 1em; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--carta-brown); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--carta-mustard-700); }

blockquote {
    border-left: 3px solid var(--carta-mustard);
    padding: .5rem 1.25rem;
    margin: 1.5rem 0;
    color: var(--carta-muted);
    font-style: italic; /* Roboto italic per brand guide — for quotes */
}

/* Italics: used sparingly per brand guidance */
em, i { font-style: italic; }

/* Accessibility helpers */
.screen-reader-text {
    border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%);
    clip-path: inset(50%); height: 1px; width: 1px; margin: -1px; overflow: hidden;
    padding: 0; position: absolute !important; white-space: nowrap; word-wrap: normal !important;
}
.carta-skip-link {
    position: absolute; top: -100px; left: 0; background: var(--carta-ink);
    color: #fff; padding: 12px 18px; z-index: 100000; font-weight: 600;
}
.carta-skip-link:focus { top: 0; outline: 3px solid var(--carta-mustard); }

/* -------- Layout -------- */
.carta-container {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 64px 24px;
}
.carta-main {
    min-height: 40vh;
}
.carta-main--elementor {
    /* Elementor owns this page — don't constrain it. */
    padding: 0;
    max-width: none;
}

/* =======================================================================
   HEADER — top bar + main header
   ======================================================================= */
.carta-site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--carta-white);
    border-bottom: 1px solid transparent;
    transition: box-shadow .25s ease, background-color .25s ease, backdrop-filter .25s ease;
}
.carta-site-header[data-scrolled="true"] {
    box-shadow: 0 1px 16px rgba(15,23,42,.08);
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(180%) blur(10px);
    -webkit-backdrop-filter: saturate(180%) blur(10px);
}

/* Top utility bar — thinner because it's secondary; collapses on scroll. */
.carta-topbar {
    background: var(--carta-ink);
    color: rgba(255,255,255,.78);
    font-size: 12px;
    overflow: hidden;
    transition: max-height .25s ease, opacity .2s ease;
}
.carta-site-header[data-scrolled-down="true"] .carta-topbar {
    max-height: 0;
    opacity: 0;
    pointer-events: none;
}
.carta-topbar__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}
.carta-social {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    align-items: center;
    gap: 4px;
    height: 100%;
}
.carta-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px; height: 22px;
    border-radius: 50%;
    color: rgba(255,255,255,.65);
    background: transparent;
    transition: all .2s ease;
}
.carta-social a:hover {
    color: var(--carta-mustard);
    background: rgba(232,178,35,.12);
}
.carta-social svg { width: 12px; height: 12px; display: block; }
.carta-topbar__menu {
    list-style: none; margin: 0; padding: 0;
    display: flex; gap: 14px; align-items: center;
    height: 100%;
}
.carta-topbar__menu a {
    color: rgba(255,255,255,.78);
    font-weight: 500;
    font-size: 11.5px;
    letter-spacing: .02em;
    line-height: 1;
    transition: color .2s ease;
}
.carta-topbar__menu a:hover { color: var(--carta-mustard); }

.carta-topbar__search {
    display: flex;
    align-items: center;
    height: 24px;
    background: rgba(255,255,255,.06);
    border-radius: 999px;
    overflow: hidden;
    transition: background .2s ease;
}
.carta-topbar__search:focus-within {
    background: rgba(255,255,255,.14);
    box-shadow: 0 0 0 2px var(--carta-mustard);
}
.carta-topbar__search input {
    background: transparent; border: 0;
    color: #fff;
    padding: 0 10px;
    width: 140px;
    height: 100%;
    font: inherit;
    font-size: 12px;
    line-height: 1;
    outline: none;
    margin: 0;
}
.carta-topbar__search input::placeholder { color: rgba(255,255,255,.5); }
.carta-topbar__search button {
    background: transparent; border: 0;
    color: rgba(255,255,255,.65);
    padding: 0 10px;
    height: 100%;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.carta-topbar__search button svg { width: 12px; height: 12px; display: block; }
.carta-topbar__search button:hover { color: var(--carta-mustard); }

/* Main header bar */
.carta-headerbar { background: var(--carta-white); }
.carta-headerbar__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
    min-height: var(--carta-header-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

/* Logo — high specificity to beat plugin CSS (HFE, Elementor) that may
   try to size .custom-logo to 0 or hide it. */
.carta-site-header .carta-brand { flex: 0 0 auto; min-width: 0; display: flex; align-items: center; }
.carta-site-header .carta-brand a.custom-logo-link,
.carta-site-header .carta-brand a.carta-brand__logo,
.carta-site-header .carta-brand a {
    display: inline-flex !important;
    align-items: center;
    line-height: 0;
    padding: 0;
}
/* Use EXPLICIT height — not max-height — because the CARTA SVG ships with
   only a viewBox (no width/height attributes), and Chrome can render an SVG
   with both "auto" dimensions at 0×0 in that case. Aspect ratio is then
   driven from the viewBox by width:auto. */
.carta-site-header .carta-brand a img,
.carta-site-header .carta-brand .custom-logo,
.carta-site-header .carta-brand img.custom-logo {
    display: block !important;
    height: 50px !important;
    width: auto !important;
    max-width: 240px !important;
    aspect-ratio: 139.4 / 62.2;
    visibility: visible !important;
    opacity: 1 !important;
    object-fit: contain;
}
@media (max-width: 1024px) {
    .carta-site-header .carta-brand a img,
    .carta-site-header .carta-brand .custom-logo {
        height: 40px !important;
    }
}
.carta-brand__text {
    font-family: var(--carta-ff-heading);
    font-weight: 800;
    font-size: 1.25rem;
    color: var(--carta-brown);
    letter-spacing: .02em;
}

/* Primary nav */
.carta-nav-primary { display: flex; }
.carta-menu {
    list-style: none; margin: 0; padding: 0;
    display: flex;
    align-items: center;
    gap: 4px;
}
.carta-menu > li { position: relative; }
.carta-menu > li > a {
    display: inline-block;
    padding: 28px 14px;
    font-family: var(--carta-ff-body);
    font-size: var(--carta-fs-sm);
    font-weight: 500;
    color: var(--carta-ink);
    letter-spacing: .01em;
    position: relative;
    transition: color .2s ease;
}
.carta-menu > li > a::after {
    content: '';
    position: absolute;
    left: 14px; right: 14px;
    bottom: 18px;
    height: 2px;
    background: var(--carta-mustard);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .25s ease;
}
.carta-menu > li > a:hover,
.carta-menu > li.current-menu-item > a,
.carta-menu > li.current-menu-parent > a,
.carta-menu > li.current-menu-ancestor > a {
    color: var(--carta-brown);
}
.carta-menu > li > a:hover::after,
.carta-menu > li.current-menu-item > a::after,
.carta-menu > li.current-menu-parent > a::after,
.carta-menu > li.current-menu-ancestor > a::after {
    transform: scaleX(1);
}

/* Caret indicator on items that have submenus.
   ::after is taken by the hover underline, so we use ::before and position
   it on the right of the link text. */
.carta-menu > li.menu-item-has-children > a { padding-right: 28px; }
.carta-menu > li.menu-item-has-children > a::before {
    content: '';
    position: absolute;
    right: 14px;
    top: 50%;
    width: 7px;
    height: 7px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translate(0, -70%) rotate(45deg);
    transition: transform .25s ease, opacity .2s ease;
    opacity: .55;
}
.carta-menu > li.menu-item-has-children:hover > a::before,
.carta-menu > li.menu-item-has-children:focus-within > a::before {
    opacity: 1;
    transform: translate(0, -30%) rotate(225deg);
    color: var(--carta-brown);
}

/* Nested submenu items that have further children — right-pointing chevron */
.carta-menu .sub-menu li.menu-item-has-children > a {
    padding-right: 28px;
    position: relative;
}
.carta-menu .sub-menu li.menu-item-has-children > a::after {
    content: '';
    position: absolute;
    right: 12px;
    top: 50%;
    width: 7px;
    height: 7px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translateY(-70%) rotate(-45deg);
    opacity: .55;
    transition: opacity .2s ease, color .2s ease;
}
.carta-menu .sub-menu li.menu-item-has-children:hover > a::after,
.carta-menu .sub-menu li.menu-item-has-children:focus-within > a::after {
    opacity: 1;
    color: var(--carta-brown);
}

/* Mobile drawer — small chevron on parents to hint at the nested items
   listed below (which we render indented rather than collapsible). */
.carta-drawer__menu li.menu-item-has-children > a {
    position: relative;
    padding-right: 36px;
}
.carta-drawer__menu li.menu-item-has-children > a::after {
    content: '';
    position: absolute;
    right: 18px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translateY(-70%) rotate(45deg);
    opacity: .45;
}
.carta-drawer__menu li.menu-item-has-children > a:hover::after,
.carta-drawer__menu li.menu-item-has-children.current-menu-parent > a::after {
    opacity: 1;
    color: var(--carta-brown);
}

/* Submenus */
.carta-menu .sub-menu {
    list-style: none;
    margin: 0; padding: 6px;
    position: absolute;
    top: 100%; left: 0;
    min-width: 240px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.05);
    border-radius: var(--carta-radius);
    box-shadow: var(--carta-shadow);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 999;
}
.carta-menu li:hover > .sub-menu,
.carta-menu li:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.carta-menu .sub-menu a {
    display: block;
    padding: 10px 14px;
    border-radius: 6px;
    color: var(--carta-ink);
    font-size: var(--carta-fs-sm);
}
.carta-menu .sub-menu a:hover,
.carta-menu .sub-menu .current-menu-item > a {
    background: var(--carta-brown-100);
    color: var(--carta-brown);
}
.carta-menu .sub-menu .sub-menu {
    top: -6px; left: 100%;
}

/* Burger */
.carta-burger {
    display: none;
    width: 44px; height: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 10px;
    border-radius: 8px;
}
.carta-burger:hover { background: var(--carta-brown-100); }
.carta-burger span {
    display: block;
    height: 2px;
    background: var(--carta-ink);
    margin: 4px 0;
    border-radius: 1px;
    transition: transform .25s ease, opacity .2s ease;
}

/* Mobile drawer */
.carta-scrim {
    position: fixed; inset: 0;
    background: rgba(15,23,42,.45);
    backdrop-filter: blur(2px);
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s ease, visibility .25s ease;
    z-index: 1100;
}
.carta-drawer {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(86vw, 380px);
    background: #fff;
    box-shadow: -20px 0 40px rgba(15,23,42,.18);
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.22,.61,.36,1);
    z-index: 1200;
    display: flex;
    flex-direction: column;
}
.carta-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--carta-grey-200);
}
.carta-drawer__brand {
    font-family: var(--carta-ff-heading);
    font-weight: 800;
    color: var(--carta-brown);
}
.carta-drawer__close {
    border: 0; background: transparent;
    cursor: pointer;
    color: var(--carta-ink);
    padding: 8px;
    border-radius: 8px;
}
.carta-drawer__close:hover { background: var(--carta-brown-100); }
.carta-drawer__nav { flex: 1; overflow-y: auto; padding: 16px 12px; }
.carta-drawer__menu, .carta-drawer__menu .sub-menu {
    list-style: none; margin: 0; padding: 0;
}
.carta-drawer__menu li > a {
    display: block;
    padding: 14px 16px;
    border-radius: 8px;
    color: var(--carta-ink);
    font-size: var(--carta-fs-md);
    font-weight: 500;
    transition: background .2s ease, color .2s ease;
}
.carta-drawer__menu li > a:hover,
.carta-drawer__menu .current-menu-item > a {
    background: var(--carta-brown-100);
    color: var(--carta-brown);
}
.carta-drawer__menu .sub-menu li > a {
    padding-left: 32px;
    font-size: var(--carta-fs-sm);
    color: var(--carta-muted);
}
.carta-drawer__search {
    padding: 16px 20px;
    border-top: 1px solid var(--carta-grey-200);
    display: flex; gap: 8px;
}
.carta-drawer__search input {
    flex: 1; padding: 10px 12px;
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    font: inherit;
}
.carta-drawer__search button {
    padding: 10px 16px;
    background: var(--carta-brown);
    color: #fff;
    border: 0;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 600;
}

/* Open state */
body.carta-drawer-open { overflow: hidden; }
body.carta-drawer-open .carta-scrim { opacity: 1; visibility: visible; }
body.carta-drawer-open .carta-drawer { transform: translateX(0); }
body.carta-drawer-open .carta-burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
body.carta-drawer-open .carta-burger span:nth-child(2) { opacity: 0; }
body.carta-drawer-open .carta-burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 1024px) {
    .carta-topbar { display: none; }
    .carta-nav-primary { display: none; }
    .carta-burger { display: inline-flex; align-items: center; justify-content: center; flex-direction: column; }
}

/* =======================================================================
   HERO — toned-down cream background + abstract network pattern
   Title is dark ink (no contrast clash with backgrounds). Same look whether
   the page has a featured image or not.
   ======================================================================= */
.carta-hero {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    color: var(--carta-ink);
    background:
        radial-gradient(ellipse at 18% 82%, rgba(232,178,35,0.10) 0%, transparent 52%),
        radial-gradient(ellipse at 82% 18%, rgba(141,85,35,0.07)  0%, transparent 55%),
        radial-gradient(circle  at 60% 50%, rgba(232,178,35,0.03) 0%, transparent 40%),
        var(--carta-cream);
}
/* Top brand accent line */
.carta-hero::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--carta-brown), var(--carta-mustard), var(--carta-brown));
    z-index: 3;
}
/* Abstract network pattern — dots connected by thin lines, very faint */
.carta-hero::after {
    content: '';
    position: absolute; inset: 0;
    z-index: 0;
    opacity: 0.045;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='400' viewBox='0 0 800 400'%3E%3Cdefs%3E%3Cstyle%3Ecircle%7Bfill:%238d5523%7Dline%7Bstroke:%238d5523;stroke-width:1.2%7D%3C/style%3E%3C/defs%3E%3Ccircle cx='80' cy='60' r='8'/%3E%3Ccircle cx='200' cy='120' r='5'/%3E%3Ccircle cx='340' cy='50' r='10'/%3E%3Ccircle cx='500' cy='100' r='6'/%3E%3Ccircle cx='650' cy='55' r='9'/%3E%3Ccircle cx='750' cy='130' r='5'/%3E%3Ccircle cx='130' cy='200' r='6'/%3E%3Ccircle cx='280' cy='230' r='8'/%3E%3Ccircle cx='420' cy='190' r='5'/%3E%3Ccircle cx='580' cy='240' r='7'/%3E%3Ccircle cx='700' cy='210' r='6'/%3E%3Ccircle cx='60' cy='330' r='7'/%3E%3Ccircle cx='180' cy='350' r='5'/%3E%3Ccircle cx='350' cy='320' r='9'/%3E%3Ccircle cx='520' cy='360' r='6'/%3E%3Ccircle cx='680' cy='330' r='8'/%3E%3Ccircle cx='770' cy='300' r='5'/%3E%3Cline x1='80' y1='60' x2='200' y2='120'/%3E%3Cline x1='200' y1='120' x2='340' y2='50'/%3E%3Cline x1='340' y1='50' x2='500' y2='100'/%3E%3Cline x1='500' y1='100' x2='650' y2='55'/%3E%3Cline x1='650' y1='55' x2='750' y2='130'/%3E%3Cline x1='80' y1='60' x2='130' y2='200'/%3E%3Cline x1='200' y1='120' x2='280' y2='230'/%3E%3Cline x1='340' y1='50' x2='420' y2='190'/%3E%3Cline x1='500' y1='100' x2='580' y2='240'/%3E%3Cline x1='650' y1='55' x2='700' y2='210'/%3E%3Cline x1='130' y1='200' x2='280' y2='230'/%3E%3Cline x1='280' y1='230' x2='420' y2='190'/%3E%3Cline x1='420' y1='190' x2='580' y2='240'/%3E%3Cline x1='580' y1='240' x2='700' y2='210'/%3E%3Cline x1='130' y1='200' x2='60' y2='330'/%3E%3Cline x1='280' y1='230' x2='180' y2='350'/%3E%3Cline x1='280' y1='230' x2='350' y2='320'/%3E%3Cline x1='580' y1='240' x2='520' y2='360'/%3E%3Cline x1='700' y1='210' x2='680' y2='330'/%3E%3Cline x1='700' y1='210' x2='770' y2='300'/%3E%3Cline x1='60' y1='330' x2='180' y2='350'/%3E%3Cline x1='180' y1='350' x2='350' y2='320'/%3E%3Cline x1='350' y1='320' x2='520' y2='360'/%3E%3Cline x1='520' y1='360' x2='680' y2='330'/%3E%3Cline x1='680' y1='330' x2='770' y2='300'/%3E%3Cline x1='750' y1='130' x2='700' y2='210'/%3E%3C/svg%3E");
    background-size: 800px 400px;
    background-repeat: repeat;
    pointer-events: none;
}
/* When a page has a featured image, fade it into the cream backdrop instead
   of using a heavy dark overlay. The image URL comes through as
   --carta-hero-bg-image (set inline by template-parts/hero.php). */
.carta-hero--has-image {
    background:
        linear-gradient(rgba(255,253,248,0.88), rgba(255,253,248,0.82)),
        var(--carta-hero-bg-image, none) center/cover no-repeat,
        radial-gradient(ellipse at 82% 18%, rgba(141,85,35,0.07) 0%, transparent 55%),
        var(--carta-cream);
}
.carta-hero__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 88px 24px 64px;
    text-align: center;
    position: relative;
    z-index: 1;
}
.carta-hero__eyebrow {
    display: inline-block;
    font-family: var(--carta-ff-body);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .3em;
    text-transform: uppercase;
    padding: 6px 20px;
    border: 1.5px solid rgba(141,85,35,0.18);
    border-radius: 100px;
    background: rgba(232,178,35,0.06);
    margin-bottom: 18px;
    color: var(--carta-brown);
}
.carta-hero__title {
    color: var(--carta-ink);
    font-size: clamp(2rem, 4.8vw, 3.25rem);
    font-weight: 700;
    line-height: 1.15;
    margin: 0 auto 16px;
    max-width: 880px;
    letter-spacing: -0.01em;
}
.carta-hero__subtitle {
    color: var(--carta-muted);
    font-size: clamp(1rem, 1.3vw, 1.2rem);
    line-height: 1.6;
    max-width: 720px;
    margin: 0 auto 22px;
}
.carta-hero__bar {
    display: block;
    width: 56px; height: 3px;
    margin: 0 auto;
    background: linear-gradient(90deg, var(--carta-mustard), var(--carta-brown));
    border-radius: 2px;
}

/* =======================================================================
   BUTTONS
   ======================================================================= */
.carta-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--carta-brown);
    color: #fff !important;
    border-radius: 8px;
    font-family: var(--carta-ff-body);
    font-weight: 600;
    font-size: var(--carta-fs-sm);
    border: 0;
    cursor: pointer;
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
    text-decoration: none;
}
.carta-btn:hover {
    background: var(--carta-brown-700);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(141,85,35,.25);
}
.carta-btn--ghost {
    background: transparent;
    color: var(--carta-brown) !important;
    border: 1.5px solid var(--carta-brown);
}
.carta-btn--ghost:hover {
    background: var(--carta-brown);
    color: #fff !important;
}
.carta-btn--mustard {
    background: var(--carta-mustard);
    color: var(--carta-ink) !important;
}
.carta-btn--mustard:hover {
    background: var(--carta-mustard-700);
    color: #fff !important;
}

/* =======================================================================
   CARDS / GRID
   ======================================================================= */
.carta-grid {
    display: grid;
    gap: 28px;
}
.carta-grid--2 { grid-template-columns: repeat(2, 1fr); }
.carta-grid--3 { grid-template-columns: repeat(3, 1fr); }
.carta-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) {
    .carta-grid--3, .carta-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .carta-grid--2, .carta-grid--3, .carta-grid--4 { grid-template-columns: 1fr; }
}

.carta-card {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: var(--carta-radius);
    overflow: hidden;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    display: flex;
    flex-direction: column;
}
.carta-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--carta-shadow);
    border-color: rgba(141,85,35,.2);
}
.carta-card__media img {
    width: 100%; aspect-ratio: 16/10; object-fit: cover;
}
.carta-card__body { padding: 20px 22px 22px; flex: 1; display: flex; flex-direction: column; }
.carta-card__meta {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    margin: 0 0 8px;
    font-weight: 600;
}
.carta-card__title {
    font-size: 1.15rem;
    line-height: 1.35;
    margin: 0 0 10px;
}
.carta-card__title a { color: var(--carta-ink); }
.carta-card__title a:hover { color: var(--carta-brown); }
.carta-card__excerpt {
    color: var(--carta-muted);
    font-size: var(--carta-fs-sm);
    margin: 0 0 16px;
    flex: 1;
}

/* =======================================================================
   FOOTER
   ======================================================================= */
.carta-site-footer {
    background: var(--carta-ink);
    color: rgba(255,255,255,.78);
    padding: 64px 0 24px;
    margin-top: 80px;
    border-top: 4px solid var(--carta-brown);
}
.carta-site-footer__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
}
.carta-site-footer__tagline {
    font-family: var(--carta-ff-heading);
    font-size: 1.25rem;
    color: #fff;
    max-width: 720px;
    margin: 0 0 40px;
    line-height: 1.4;
}
.carta-site-footer__cols {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 32px;
    margin-bottom: 40px;
}
.carta-site-footer__col h3,
.carta-site-footer__col .widget-title {
    color: #fff;
    font-size: var(--carta-fs-md);
    margin-bottom: 16px;
    font-weight: 600;
    letter-spacing: .02em;
}
.carta-site-footer__col a {
    color: rgba(255,255,255,.78);
    transition: color .2s ease;
}
.carta-site-footer__col a:hover { color: var(--carta-mustard); }
.carta-site-footer__col ul {
    list-style: none; padding: 0; margin: 0;
}
.carta-site-footer__col li { padding: 6px 0; font-size: var(--carta-fs-sm); }

.carta-site-footer__nav { margin: 20px 0; }
.carta-footer-menu {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap;
    gap: 8px 22px;
}
.carta-footer-menu a { font-size: var(--carta-fs-sm); }

.carta-site-footer__bar {
    border-top: 1px solid rgba(255,255,255,.08);
    padding-top: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    font-size: var(--carta-fs-xs);
    color: rgba(255,255,255,.55);
}

/* =======================================================================
   PAGINATION + UTILS
   ======================================================================= */
.carta-page-pagination, .pagination {
    display: flex; gap: 6px;
    flex-wrap: wrap;
    margin-top: 40px;
    justify-content: center;
}
.carta-page-pagination a, .pagination a,
.pagination .page-numbers {
    display: inline-flex;
    align-items: center; justify-content: center;
    min-width: 38px; height: 38px;
    padding: 0 12px;
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    color: var(--carta-ink);
    font-weight: 500;
}
.pagination .page-numbers.current {
    background: var(--carta-brown);
    color: #fff;
    border-color: var(--carta-brown);
}
.pagination a:hover {
    background: var(--carta-brown-100);
    border-color: var(--carta-brown);
    color: var(--carta-brown);
}

.carta-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--carta-muted);
    font-size: var(--carta-fs-lg);
}

/* Search form */
.carta-searchform {
    display: flex; gap: 8px;
    max-width: 480px;
}
.carta-searchform input {
    flex: 1;
    padding: 12px 14px;
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    font: inherit;
}
.carta-searchform input:focus {
    outline: none;
    border-color: var(--carta-brown);
    box-shadow: 0 0 0 3px var(--carta-brown-100);
}
.carta-searchform button {
    padding: 12px 22px;
    background: var(--carta-brown);
    color: #fff;
    border: 0; border-radius: 8px;
    cursor: pointer;
    font-weight: 600;
}

/* Comments */
.carta-comments { margin: 60px 0 0; }
.carta-comments__list { list-style: none; padding: 0; }
.carta-comments__list .comment-body {
    padding: 16px 0;
    border-top: 1px solid var(--carta-grey-200);
}

/* Sidebar */
.carta-sidebar { padding: 20px; background: var(--carta-cream); border-radius: var(--carta-radius); }
.carta-sidebar .widget + .widget { margin-top: 24px; }
.carta-sidebar .widget-title { font-size: var(--carta-fs-md); margin: 0 0 12px; }

/* WP core alignments */
.alignwide  { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull  { width: 100%; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }

/* WP block button override to use brand colors */
.wp-block-button__link {
    background-color: var(--carta-brown);
    border-radius: 8px;
}

/* Elementor-page guard: when Elementor renders its own header, do not stack ours */
body.elementor-page .carta-site-header[data-elementor-suppressed="true"] { display: none; }

/* =======================================================================
   FILTER CHIPS — used by archives + the relations block
   ======================================================================= */
.carta-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border: 1.5px solid var(--carta-grey-200);
    border-radius: 100px;
    background: #fff;
    color: var(--carta-muted);
    font-family: var(--carta-ff-body);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.3;
    text-decoration: none !important;
    transition: all .2s ease;
}
.carta-chip:hover {
    border-color: var(--carta-brown);
    color: var(--carta-brown);
    background: var(--carta-brown-100);
}
.carta-chip.is-on,
.carta-chip[aria-pressed="true"] {
    background: var(--carta-brown);
    color: #fff !important;
    border-color: var(--carta-brown);
}
.carta-chip__count {
    opacity: .55;
    font-size: 11px;
    font-weight: 400;
}
.carta-chip.is-on .carta-chip__count { opacity: .9; color: rgba(255,255,255,.85); }
.carta-chip__x {
    font-size: 14px;
    line-height: 1;
    margin-left: 4px;
    font-weight: 700;
}
.carta-chip--mini {
    padding: 3px 10px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    background: var(--carta-mustard-100);
    color: var(--carta-brown);
    border-color: transparent;
}
.carta-btn--small {
    padding: 8px 14px;
    font-size: 13px;
}

/* =======================================================================
   FELLOWS & GRADUATES — archive
   ======================================================================= */
.carta-fg-archive { padding: 0 0 96px; }
.carta-fg-archive__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
}

.carta-fg-filters {
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 14px;
    padding: 22px 24px;
    margin: -40px 0 32px;
    position: relative;
    z-index: 2;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-fg-filters__group {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid var(--carta-grey-200);
}
.carta-fg-filters__group:last-of-type { border-bottom: 0; }
.carta-fg-filters__label {
    flex: 0 0 110px;
    font-family: var(--carta-ff-heading);
    font-weight: 600;
    color: var(--carta-ink);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding-top: 6px;
}
.carta-fg-filters__chips {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 6px 8px;
}
.carta-fg-filters__clear { margin: 16px 0 0; }

@media (max-width: 720px) {
    .carta-fg-filters { padding: 16px 16px; }
    .carta-fg-filters__group { flex-direction: column; gap: 8px; }
    .carta-fg-filters__label { flex: none; padding-top: 0; }
}

.carta-fg-archive__count {
    color: var(--carta-muted);
    font-size: 14px;
    margin: 0 0 20px;
}
.carta-fg-archive__count strong { color: var(--carta-ink); }

/* Grid: stacked-info cards. 5 across on desktop gives the name + meta
   enough horizontal room without truncation. */
.carta-fg-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 18px;
}
@media (max-width: 1180px) { .carta-fg-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 880px)  { .carta-fg-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px)  { .carta-fg-grid { grid-template-columns: repeat(2, 1fr); } }

/* ─── Fellow / Graduate card ──────────────────────────────────────
   Restrained, photo-led. Single clickable area (the whole card).
   Hierarchy: photo → cohort eyebrow → name → institution.
   Graduates carry a small ribbon in the top-right corner of the photo. */
.carta-fg-card {
    position: relative;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 1px 1px rgba(15,23,42,.03);
    transition: transform .35s cubic-bezier(.22,.61,.36,1),
                box-shadow .35s ease;
    isolation: isolate;
}
.carta-fg-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 36px -12px rgba(141,85,35,.22),
                0 4px 12px rgba(15,23,42,.05);
}
.carta-fg-card__main {
    display: block;
    color: inherit;
    text-decoration: none !important;
}

/* Photo wrapper: positioning context for the grad ribbon. Does NOT clip,
   so the ribbon can hang outside the circle. */
.carta-fg-card__photo {
    position: relative;
    width: 108px;
    height: 108px;
    margin: 18px auto 4px;
    transition: transform .35s cubic-bezier(.22,.61,.36,1);
}
.carta-fg-card:hover .carta-fg-card__photo { transform: scale(1.04); }

/* The circular frame clips only the image — the grad ribbon stays outside it. */
.carta-fg-card__photo-frame {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, var(--carta-cream), var(--carta-mustard-100));
    box-shadow: 0 0 0 3px var(--carta-mustard),
                0 0 0 4px rgba(255,255,255,.95),
                0 4px 12px rgba(141,85,35,.12);
    position: relative;
}
.carta-fg-card__photo-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
    display: block;
}
.carta-fg-card__initial {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--carta-ff-heading);
    font-size: 38px;
    font-weight: 700;
    color: var(--carta-brown);
    opacity: .35;
}

/* Graduate ribbon — sits in the top-right of the photo wrapper, outside
   the clipped circle so it stays visible. */
.carta-fg-card__grad {
    position: absolute;
    top: -2px;
    right: -2px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--carta-brown);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    box-shadow: 0 2px 6px rgba(0,0,0,.22),
                0 0 0 2px #fff;
    transition: transform .25s ease;
    pointer-events: none;
}
.carta-fg-card:hover .carta-fg-card__grad { transform: scale(1.1); }

/* Body */
.carta-fg-card__body {
    padding: 8px 14px 18px;
    text-align: center;
}

.carta-fg-card__cohort {
    display: inline-block;
    margin: 0 0 8px;
    padding: 3px 9px;
    background: var(--carta-mustard-100);
    color: var(--carta-brown);
    font-family: var(--carta-ff-body);
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    border-radius: 100px;
    line-height: 1;
}

.carta-fg-card__name,
.carta-fg-card .carta-fg-card__name,
.carta-fg-card h3.carta-fg-card__name {
    margin: 0 !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    color: var(--carta-ink);
    letter-spacing: -.005em;
    transition: color .2s ease;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.carta-fg-card:hover .carta-fg-card__name { color: var(--carta-brown); }

.carta-fg-card__inst {
    display: block !important;
    margin: 6px 0 0 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    color: var(--carta-muted);
    transition: color .2s ease;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.carta-fg-card:hover .carta-fg-card__inst { color: var(--carta-brown); }

/* ─── Focal persons block inside .carta-related ──────────────────── */
.carta-related__focal {
    list-style: none;
    margin: 0 0 12px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
}
.carta-related__focal a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 10px;
    text-decoration: none !important;
    color: inherit;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.carta-related__focal a:hover {
    border-color: var(--carta-brown);
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(141,85,35,.10);
}
.carta-related__focal-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
}
.carta-related__focal-name {
    font-family: var(--carta-ff-heading);
    font-size: 13.5px;
    font-weight: 600;
    color: var(--carta-ink);
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.carta-related__focal-role {
    font-size: 11.5px;
    color: var(--carta-muted);
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.carta-related__avatar--initial {
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: var(--carta-mustard-100) !important;
    color: var(--carta-brown);
    font-family: var(--carta-ff-heading);
    font-weight: 700;
    font-size: 13px;
}

/* =======================================================================
   FELLOWS & GRADUATES — compact filter bar (dropdowns + alphabet)
   ======================================================================= */
.carta-fg-filters {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 14px 18px;
    margin: -36px 0 28px;
    position: relative;
    z-index: 3;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-fg-filters__row {
    display: flex;
    gap: 10px;
    align-items: flex-end;
    flex-wrap: wrap;
}
.carta-fg-select {
    position: relative;
    flex: 1 1 0;
    min-width: 150px;
    display: block;
}
.carta-fg-select__label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    margin-bottom: 4px;
}
.carta-fg-select select {
    width: 100%;
    appearance: none;
    -webkit-appearance: none;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    padding: 9px 32px 9px 12px;
    font-family: inherit;
    font-size: 13.5px;
    color: var(--carta-ink);
    cursor: pointer;
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
    text-overflow: ellipsis;
}
.carta-fg-select select:hover {
    border-color: var(--carta-brown);
    background: #fff;
}
.carta-fg-select select:focus {
    outline: none;
    border-color: var(--carta-brown);
    box-shadow: 0 0 0 3px rgba(141,85,35,.15);
}
.carta-fg-select__caret {
    position: absolute;
    right: 10px; bottom: 11px;
    color: var(--carta-brown);
    pointer-events: none;
}

/* Sort dropdown — same visual as filters but with a subtle accent border
   to signal "this changes ordering, not the result set". */
.carta-fg-select--sort {
    flex: 0 1 200px;
    min-width: 170px;
    position: relative;
}
.carta-fg-select--sort::before {
    content: '';
    position: absolute;
    left: -8px;
    top: 18px;
    bottom: 1px;
    width: 1px;
    background: var(--carta-grey-200);
}
.carta-fg-select--sort select {
    background: #fff;
    border-color: var(--carta-mustard-100);
}
.carta-fg-select--sort select:hover { border-color: var(--carta-mustard); }
.carta-fg-select--sort select:focus { border-color: var(--carta-mustard); box-shadow: 0 0 0 3px rgba(232,178,35,.18); }
.carta-fg-select--sort .carta-fg-select__caret { color: var(--carta-mustard-700); }
@media (max-width: 640px) {
    .carta-fg-select--sort { flex: 1 1 100%; min-width: 0; }
    .carta-fg-select--sort::before { display: none; }
}

.carta-fg-clear {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 9px 14px;
    border-radius: 8px;
    background: transparent;
    color: var(--carta-muted);
    font-size: 13px;
    text-decoration: none;
    border: 1px dashed var(--carta-grey-200);
    transition: all .15s ease;
    margin-bottom: 0;
    align-self: flex-end;
    flex: 0 0 auto;
}
.carta-fg-clear:hover {
    color: var(--carta-brown);
    border-color: var(--carta-brown);
    border-style: solid;
    background: var(--carta-brown-100);
}

/* Alphabet bar */
.carta-fg-alpha {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--carta-grey-200);
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    align-items: center;
}
.carta-fg-alpha__btn {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 28px; height: 28px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--carta-muted);
    text-decoration: none;
    transition: all .15s ease;
}
.carta-fg-alpha__btn:hover {
    background: var(--carta-brown-100);
    color: var(--carta-brown);
}
.carta-fg-alpha__btn.is-on {
    background: var(--carta-brown);
    color: #fff;
}
.carta-fg-alpha__btn.is-disabled {
    color: var(--carta-grey-200);
    cursor: not-allowed;
    pointer-events: none;
}
.carta-fg-alpha__btn:first-child {
    /* "All" pill */
    padding: 0 12px;
    width: auto;
    background: var(--carta-cream);
    color: var(--carta-brown);
    margin-right: 6px;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 10.5px;
    letter-spacing: .08em;
}
.carta-fg-alpha__btn:first-child.is-on {
    background: var(--carta-brown);
    color: #fff;
}

@media (max-width: 640px) {
    .carta-fg-filters { padding: 14px; }
    .carta-fg-select { flex: 1 1 calc(50% - 5px); min-width: 0; }
    .carta-fg-clear { flex: 1 1 100%; justify-content: center; margin-top: 4px; }
    .carta-fg-alpha { gap: 1px; }
    .carta-fg-alpha__btn { width: 24px; height: 24px; font-size: 11px; }
    .carta-fg-alpha__btn:first-child { padding: 0 10px; font-size: 10px; }
}

.carta-fg-empty {
    text-align: center;
    padding: 60px 20px;
    background: var(--carta-cream);
    border-radius: 14px;
}
.carta-fg-empty h3 { font-family: var(--carta-ff-heading); margin-bottom: 8px; }

/* =======================================================================
   FELLOWS & GRADUATES — single profile (main + right-sidebar layout)
   ======================================================================= */
.carta-fg-single { padding: 0 0 80px; }
.carta-fg-single__inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}
.carta-fg-single__inner--with-sidebar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 28px;
    align-items: start;
}
.carta-fg-single__main { min-width: 0; }
.carta-fg-single__sidebar {
    position: sticky;
    top: calc(var(--carta-header-h) + 18px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-height: calc(100vh - var(--carta-header-h) - 36px);
    overflow-y: auto;
    padding-right: 4px;
    /* hide scrollbar except on hover for a cleaner look */
    scrollbar-width: thin;
    scrollbar-color: var(--carta-grey-200) transparent;
}
.carta-fg-single__sidebar::-webkit-scrollbar { width: 6px; }
.carta-fg-single__sidebar::-webkit-scrollbar-thumb {
    background: var(--carta-grey-200);
    border-radius: 6px;
}

@media (max-width: 980px) {
    .carta-fg-single__inner--with-sidebar { grid-template-columns: 1fr; }
    .carta-fg-single__sidebar {
        position: static;
        max-height: none;
        overflow-y: visible;
        padding-right: 0;
    }
}

/* Head card: avatar + 3 facts (institution / nationality / cohort) + socials
   + achievement banner (graduates only). Grid is forgiving — facts wrap to
   one column inside the narrower main area. */
.carta-fg-single__head {
    display: grid;
    grid-template-columns: 160px 1fr;
    grid-template-areas:
        "avatar facts"
        "avatar socials"
        "ach    ach";
    gap: 22px 26px;
    align-items: start;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 16px;
    padding: 24px;
    margin: -40px 0 24px;
    position: relative;
    z-index: 2;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-fg-single__avatar {
    grid-area: avatar;
    width: 160px; height: 160px;
    border-radius: 12px;
    overflow: hidden;
    background: var(--carta-cream);
    border: 3px solid var(--carta-mustard);
}
.carta-fg-single__avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center 18%; }

.carta-fg-single__facts {
    grid-area: facts;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
.carta-fg-single__facts > div { min-width: 0; }
.carta-fg-single__facts dt {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    margin: 0 0 2px;
}
.carta-fg-single__facts dd {
    margin: 0;
    color: var(--carta-ink);
    font-size: 14px;
    line-height: 1.4;
}
.carta-fg-single__facts a { color: var(--carta-brown); font-weight: 500; }
.carta-fg-single__facts a:hover { text-decoration: underline; }

.carta-fg-single__socials {
    grid-area: socials;
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 8px;
}
.carta-fg-single__socials a {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--carta-cream);
    color: var(--carta-brown);
    border: 1px solid var(--carta-grey-200);
    transition: all .2s ease;
}
.carta-fg-single__socials a:hover {
    background: var(--carta-brown);
    color: #fff;
    border-color: var(--carta-brown);
}

/* Achievement banner: inside the head card, spans full width below the avatar+facts */
.carta-fg-single__achievement {
    grid-area: ach;
    display: flex;
    align-items: center;
    gap: 14px;
    background: linear-gradient(135deg, var(--carta-mustard-100) 0%, #fff 100%);
    border: 1px solid rgba(232,178,35,.35);
    border-left: 4px solid var(--carta-mustard);
    border-radius: 10px;
    padding: 12px 16px;
}
.carta-fg-single__achievement-icon {
    font-size: 26px;
    line-height: 1;
    filter: drop-shadow(0 2px 4px rgba(141,85,35,.18));
}
.carta-fg-single__achievement-text { display: flex; flex-direction: column; }
.carta-fg-single__achievement-text strong {
    font-family: var(--carta-ff-heading);
    font-size: 13.5px;
    font-weight: 700;
    color: var(--carta-brown);
}
.carta-fg-single__achievement-text span {
    font-size: 12.5px;
    color: var(--carta-muted);
    margin-top: 1px;
}

@media (max-width: 600px) {
    .carta-fg-single__head {
        grid-template-columns: 1fr;
        grid-template-areas: "avatar" "facts" "socials" "ach";
        text-align: center;
        padding: 20px;
    }
    .carta-fg-single__avatar { width: 140px; height: 140px; margin: 0 auto; }
    .carta-fg-single__socials { justify-content: center; }
    .carta-fg-single__achievement { text-align: left; }
}

.carta-fg-single__bio {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 14px;
    padding: 26px;
    margin-bottom: 24px;
}
.carta-fg-single__bio h2 {
    font-size: 1.3rem;
    margin: 0 0 12px;
}
.carta-fg-single__bio p { color: var(--carta-ink); font-size: 14.5px; line-height: 1.75; }

.carta-fg-single__back { margin-top: 24px; }

/* ─── Sidebar section cards ────────────────────────────────────── */
.carta-fp-section {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}
.carta-fp-section__head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--carta-grey-200);
    background: linear-gradient(180deg, var(--carta-cream) 0%, #fff 100%);
}
.carta-fp-section__icon { font-size: 13px; line-height: 1; opacity: .85; }
/* Quiet eyebrow style — small, muted, restrained. Locks size with !important
   to win over the global h2 clamp(1.5rem, 3vw, …) rule. */
.carta-fp-section__title,
.carta-fp-section h2.carta-fp-section__title {
    margin: 0 !important;
    font-family: var(--carta-ff-body) !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: var(--carta-muted) !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
}
.carta-fp-section__body { padding: 14px 16px 16px; }

/* Fact rows (sidebar context — always single column) */
.carta-fp-facts {
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
.carta-fp-facts--single { grid-template-columns: 1fr; }
.carta-fp-fact {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    min-width: 0;
}
.carta-fp-fact__icon {
    flex: 0 0 18px;
    font-size: 14px;
    line-height: 1.3;
    color: var(--carta-brown);
}
.carta-fp-fact__text { min-width: 0; flex: 1; }
.carta-fp-fact dt {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    margin: 0 0 2px;
}
.carta-fp-fact dd {
    margin: 0;
    font-size: 13px;
    line-height: 1.4;
    color: var(--carta-ink);
}
.carta-fp-fact a { color: var(--carta-brown); font-weight: 500; text-decoration: none; }
.carta-fp-fact a:hover { text-decoration: underline; }

/* Quick action buttons */
.carta-fp-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.carta-fp-action {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    text-decoration: none;
    color: var(--carta-ink);
    font-weight: 500;
    font-size: 12.5px;
    transition: all .18s ease;
}
.carta-fp-action:hover {
    background: #fff;
    border-color: var(--carta-brown);
    color: var(--carta-brown);
    transform: translateX(2px);
}
.carta-fp-action__icon { font-size: 15px; line-height: 1; }

/* =======================================================================
   RELATED CONTENT BLOCK (cross-CPT relations)
   ======================================================================= */
.carta-related {
    background: linear-gradient(135deg, var(--carta-cream) 0%, var(--carta-mustard-100) 100%);
    border: 1px solid rgba(232,178,35,.3);
    border-radius: 16px;
    padding: 32px;
    margin: 32px 0;
    position: relative;
    overflow: hidden;
}
.carta-related::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 4px; height: 100%;
    background: linear-gradient(180deg, var(--carta-mustard), var(--carta-brown));
}
.carta-related__inner { position: relative; }
.carta-related__eyebrow {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .25em;
    color: var(--carta-brown);
    margin: 0 0 18px;
}

.carta-related__partner {
    display: flex;
    align-items: stretch;
    gap: 18px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    overflow: hidden;
    padding: 0;
    margin-bottom: 24px;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    text-decoration: none !important;
    color: inherit;
}
.carta-related__partner:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(141,85,35,.12);
    border-color: var(--carta-mustard);
}
.carta-related__partner-media {
    flex: 0 0 110px;
    background-size: cover;
    background-position: center;
    background-color: var(--carta-cream);
}
.carta-related__partner-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 16px 20px;
    position: relative;
}
.carta-related__kicker {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-brown);
    margin-bottom: 4px;
}
.carta-related__partner-title {
    font-family: var(--carta-ff-heading);
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--carta-ink);
}
.carta-related__arrow {
    position: absolute;
    top: 50%; right: 18px;
    transform: translateY(-50%);
    color: var(--carta-brown);
    font-size: 22px;
    transition: transform .25s ease;
}
.carta-related__partner:hover .carta-related__arrow { transform: translate(4px, -50%); }

.carta-related__h {
    font-family: var(--carta-ff-heading);
    font-size: 1.05rem;
    font-weight: 700;
    margin: 18px 0 12px;
    color: var(--carta-ink);
}
.carta-related__list {
    list-style: none;
    margin: 0; padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}
.carta-related__list a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 100px;
    text-decoration: none !important;
    color: var(--carta-ink);
    font-size: 13.5px;
    transition: all .2s ease;
}
.carta-related__list a:hover {
    border-color: var(--carta-brown);
    color: var(--carta-brown);
}
.carta-related__avatar {
    flex: 0 0 28px;
    width: 28px; height: 28px;
    border-radius: 50%;
    background-size: cover;
    background-position: center;
    background-color: var(--carta-cream);
}
.carta-related__pubs {
    list-style: none;
    margin: 0; padding: 0;
}
.carta-related__pubs li {
    border-bottom: 1px solid rgba(141,85,35,.1);
    padding: 12px 0;
}
.carta-related__pubs li:last-child { border-bottom: 0; }
.carta-related__pubs a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    color: var(--carta-ink);
    text-decoration: none;
    font-weight: 500;
}
.carta-related__pubs a:hover { color: var(--carta-brown); }
.carta-related__pubs a span { color: var(--carta-brown); font-size: 18px; transition: transform .2s ease; }
.carta-related__pubs a:hover span { transform: translateX(4px); }

.carta-related__tags {
    margin: 18px 0 0;
    padding-top: 16px;
    border-top: 1px solid rgba(141,85,35,.15);
    color: var(--carta-muted);
    font-size: 13px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

@media (max-width: 600px) {
    .carta-related { padding: 22px; }
    .carta-related__partner { flex-direction: column; }
    .carta-related__partner-media { flex: 0 0 120px; min-height: 120px; }
    .carta-related__arrow { right: 14px; top: 14px; transform: none; }
    .carta-related__partner:hover .carta-related__arrow { transform: translateX(4px); }
}

/* =======================================================================
   PARTNER / INSTITUTION single profile
   ======================================================================= */
.carta-partner-single { padding: 0 0 80px; }
.carta-partner-single__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
}
.carta-partner-single__body {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 16px;
    padding: 32px;
    margin: -40px 0 32px;
    position: relative;
    z-index: 2;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 32px;
    align-items: start;
}
.carta-partner-single__media img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 12px;
}
.carta-partner-single__content p { color: var(--carta-muted); line-height: 1.7; }
.carta-partner-single__cta { margin-top: 20px; }
@media (max-width: 760px) {
    .carta-partner-single__body { grid-template-columns: 1fr; padding: 22px; }
}
.carta-partner-single__fellows,
.carta-partner-single__pubs {
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 16px;
    padding: 32px;
    margin-bottom: 28px;
}
.carta-partner-single__fellows h2,
.carta-partner-single__pubs h2,
.carta-partner-single__focals h2 {
    font-size: 1.4rem;
    margin: 0 0 8px;
}
.carta-muted { color: var(--carta-muted); margin-bottom: 24px; font-size: 14px; }

/* =======================================================================
   FOCAL PERSONS DIRECTORY PAGE (page-templates/focal-persons.php)
   ======================================================================= */
.carta-focal-page { padding: 0 0 80px; }
.carta-focal-page__inner {
    max-width: var(--carta-container);
    margin: 0 auto;
    padding: 0 24px;
}

/* Region filter bar */
.carta-focal-filter {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 14px 18px;
    margin: -36px 0 28px;
    position: relative;
    z-index: 3;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-focal-filter__btn {
    padding: 7px 14px;
    border-radius: 100px;
    border: 1.5px solid var(--carta-grey-200);
    background: #fff;
    color: var(--carta-muted);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all .15s ease;
}
.carta-focal-filter__btn:hover {
    border-color: var(--carta-brown);
    color: var(--carta-brown);
}
.carta-focal-filter__btn.is-on {
    background: var(--carta-brown);
    color: #fff;
    border-color: var(--carta-brown);
}
.carta-focal-filter__count {
    margin-left: auto;
    color: var(--carta-muted);
    font-size: 13px;
}

/* Two-column body */
.carta-focal-page__body {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 28px;
    align-items: start;
}
@media (max-width: 880px) {
    .carta-focal-page__body { grid-template-columns: 1fr; }
}

/* Sidebar with anchor jumps */
.carta-focal-page__sidebar {
    position: sticky;
    top: calc(var(--carta-header-h) + 18px);
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 16px 0 12px;
    max-height: calc(100vh - var(--carta-header-h) - 36px);
    overflow-y: auto;
}
.carta-focal-page__sidebar-title,
.carta-focal-page__sidebar h2.carta-focal-page__sidebar-title {
    margin: 0 16px 10px !important;
    font-family: var(--carta-ff-body) !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: var(--carta-muted) !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
}
.carta-focal-page__nav {
    list-style: none;
    margin: 0;
    padding: 0;
}
.carta-focal-page__nav li { margin: 0; }
.carta-focal-page__nav a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 16px;
    color: var(--carta-ink);
    font-size: 12.5px;
    text-decoration: none;
    border-left: 3px solid transparent;
    transition: all .15s ease;
}
.carta-focal-page__nav a:hover {
    background: var(--carta-cream);
    border-left-color: var(--carta-mustard);
    color: var(--carta-brown);
}
.carta-focal-page__nav-name {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.carta-focal-page__nav-count {
    font-size: 11px;
    color: var(--carta-muted);
    background: var(--carta-cream);
    padding: 2px 7px;
    border-radius: 100px;
    flex: 0 0 auto;
}
@media (max-width: 880px) {
    .carta-focal-page__sidebar { position: static; max-height: none; overflow: visible; }
}

/* Institution groups */
.carta-focal-page__groups {
    display: flex;
    flex-direction: column;
    gap: 22px;
    min-width: 0;
}
.carta-focal-group {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 14px;
    padding: 22px;
    scroll-margin-top: calc(var(--carta-header-h) + 18px);
}
.carta-focal-group__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--carta-grey-200);
}
.carta-focal-group__title,
.carta-focal-group h2.carta-focal-group__title {
    margin: 0 !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: var(--carta-ink) !important;
}
.carta-focal-group__count {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    background: var(--carta-mustard-100);
    padding: 3px 10px;
    border-radius: 100px;
    flex: 0 0 auto;
}
.carta-focal-group__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 14px;
}

/* Focal person tile */
.carta-focal-tile {
    display: flex;
    gap: 12px;
    padding: 12px;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 10px;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease, background .2s ease;
    align-items: flex-start;
}
.carta-focal-tile:hover {
    background: #fff;
    border-color: var(--carta-mustard);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(141,85,35,.10);
}
.carta-focal-tile__photo {
    flex: 0 0 56px;
    width: 56px;
    height: 56px;
    display: block;
}
.carta-focal-tile__photo-frame {
    display: block;
    width: 100%; height: 100%;
    border-radius: 50%;
    overflow: hidden;
    background: var(--carta-mustard-100);
    box-shadow: 0 0 0 2px var(--carta-mustard),
                0 0 0 3px #fff;
    position: relative;
}
.carta-focal-tile__photo-frame img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center 18%;
    display: block;
}
.carta-focal-tile__initial {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--carta-ff-heading);
    font-weight: 700;
    font-size: 20px;
    color: var(--carta-brown);
}
.carta-focal-tile__body { flex: 1; min-width: 0; }
.carta-focal-tile__name,
.carta-focal-tile h3.carta-focal-tile__name {
    margin: 0 0 2px !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
}
.carta-focal-tile__name a {
    color: var(--carta-ink);
    text-decoration: none;
}
.carta-focal-tile__name a:hover { color: var(--carta-brown); }
.carta-focal-tile__role {
    margin: 0 0 8px;
    font-size: 11.5px;
    color: var(--carta-muted);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.carta-focal-tile__contacts {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.carta-focal-tile__contacts a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 100px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    color: var(--carta-muted);
    font-size: 10.5px;
    font-weight: 600;
    text-decoration: none;
    transition: all .15s ease;
}
.carta-focal-tile__contacts a:hover {
    color: var(--carta-brown);
    border-color: var(--carta-brown);
    background: var(--carta-brown-100);
}

/* =======================================================================
   PUBLICATIONS ABOUT CARTA page
   ======================================================================= */
.carta-pubs { padding: 0 0 80px; }
.carta-pubs__inner {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Filter bar */
.carta-pubs__filters {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 14px 16px;
    margin: -36px 0 22px;
    position: relative;
    z-index: 3;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-pubs__search {
    flex: 1 1 240px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 8px;
    height: 38px;
    transition: border-color .15s ease, box-shadow .15s ease;
    color: var(--carta-muted);
}
.carta-pubs__search:focus-within {
    border-color: var(--carta-brown);
    box-shadow: 0 0 0 3px var(--carta-brown-100);
    color: var(--carta-brown);
}
.carta-pubs__search input {
    border: 0;
    background: transparent;
    flex: 1;
    height: 100%;
    outline: none;
    font: inherit;
    font-size: 13.5px;
    color: var(--carta-ink);
}
.carta-pubs__go { align-self: flex-end; }

/* Meta strip */
.carta-pubs__meta {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin: 0 0 18px;
    color: var(--carta-muted);
    font-size: 13px;
}
.carta-pubs__count { margin: 0; }
.carta-pubs__count strong { color: var(--carta-ink); }
.carta-pubs__sync {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
}

/* Admin-only notice */
.carta-pubs__admin-note {
    display: flex;
    align-items: center;
    gap: 16px;
    background: linear-gradient(135deg, var(--carta-mustard-100), #fff);
    border: 1px solid rgba(232,178,35,.4);
    border-left: 4px solid var(--carta-mustard);
    border-radius: 12px;
    padding: 16px 20px;
    margin: -22px 0 16px;
    position: relative;
    z-index: 4;
}
.carta-pubs__admin-note-icon {
    font-size: 22px;
    color: var(--carta-brown);
    flex: 0 0 auto;
}
.carta-pubs__admin-note > div {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.carta-pubs__admin-note strong {
    color: var(--carta-ink);
    font-size: 14px;
}
.carta-pubs__admin-note span {
    color: var(--carta-muted);
    font-size: 13px;
}
.carta-pubs__admin-note .carta-btn { flex: 0 0 auto; }
.carta-pubs__admin-hint {
    margin: 4px 0 16px;
    font-size: 11px;
    color: var(--carta-muted);
    text-align: right;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* Publication list */
.carta-pubs__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
    counter-reset: pub;
}
.carta-pub {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 20px 22px;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
    position: relative;
}
.carta-pub:hover {
    border-color: var(--carta-mustard);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(141,85,35,.10);
}

.carta-pub__head {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 8px;
}
.carta-pub__year {
    flex: 0 0 auto;
    background: var(--carta-mustard-100);
    color: var(--carta-brown);
    font-family: var(--carta-ff-body);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    padding: 3px 10px;
    border-radius: 100px;
}
.carta-pub__title,
.carta-pub h2.carta-pub__title {
    margin: 0 !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    color: var(--carta-ink) !important;
}
.carta-pub__title a {
    color: var(--carta-ink);
    text-decoration: none;
}
.carta-pub__title a:hover { color: var(--carta-brown); text-decoration: underline; }

.carta-pub__attr {
    margin: 0 0 10px;
    font-size: 12.5px;
    color: var(--carta-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 4px 10px;
}
.carta-pub__authors { font-weight: 500; color: var(--carta-ink); }
.carta-pub__journal { font-style: italic; }

.carta-pub__abstract {
    margin: 0 0 14px;
    color: var(--carta-muted);
    font-size: 13.5px;
    line-height: 1.6;
}

.carta-pub__foot {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px 16px;
    padding-top: 12px;
    border-top: 1px solid var(--carta-grey-200);
    font-size: 12px;
}
.carta-pub__doi {
    color: var(--carta-brown);
    text-decoration: none;
    word-break: break-all;
}
.carta-pub__doi:hover { text-decoration: underline; }
.carta-pub__doi strong { font-weight: 700; }
.carta-pub__source {
    margin-left: auto;
    color: var(--carta-muted);
    font-size: 10.5px;
    text-transform: uppercase;
    letter-spacing: .12em;
    background: var(--carta-cream);
    padding: 3px 8px;
    border-radius: 100px;
}

@media (max-width: 600px) {
    .carta-pub__head { flex-direction: column; gap: 8px; align-items: flex-start; }
    .carta-pub__foot .carta-pub__source { margin-left: 0; }
}

/* =======================================================================
   BOARD OF MANAGEMENT page (page-templates/board-of-management.php)
   ======================================================================= */
.carta-bom { padding: 0 0 80px; }
.carta-bom__inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}
.carta-bom__intro {
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 14px;
    padding: 28px;
    margin: -32px 0 24px;
    position: relative;
    z-index: 2;
    color: var(--carta-ink);
    line-height: 1.65;
    box-shadow: 0 6px 24px rgba(15,23,42,.05);
}
.carta-bom__intro p { margin: 0 0 12px; font-size: 15px; }
.carta-bom__intro p:last-child { margin-bottom: 0; }

/* Group nav (anchor jumps) */
.carta-bom__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 100px;
    padding: 6px;
    margin-bottom: 28px;
    position: sticky;
    top: calc(var(--carta-header-h) + 12px);
    z-index: 5;
    backdrop-filter: blur(6px);
    background: rgba(255,253,248,.92);
}
.carta-bom__nav-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    border-radius: 100px;
    color: var(--carta-muted);
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .02em;
    transition: all .15s ease;
}
.carta-bom__nav-link:hover {
    background: #fff;
    color: var(--carta-brown);
}
.carta-bom__nav-count {
    background: #fff;
    color: var(--carta-brown);
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 100px;
}
.carta-bom__nav-link:hover .carta-bom__nav-count {
    background: var(--carta-brown);
    color: #fff;
}

/* Group sections */
.carta-bom__group {
    margin-bottom: 40px;
    scroll-margin-top: calc(var(--carta-header-h) + 80px);
}
.carta-bom__group-head {
    margin-bottom: 22px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--carta-mustard);
    position: relative;
}
.carta-bom__group-title,
.carta-bom__group h2.carta-bom__group-title {
    margin: 0 0 6px !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: var(--carta-ink) !important;
}
.carta-bom__group-lede {
    margin: 0;
    font-size: 13.5px;
    color: var(--carta-muted);
    line-height: 1.5;
    max-width: 640px;
}
.carta-bom__group-count {
    position: absolute;
    top: 0;
    right: 0;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--carta-muted);
    background: var(--carta-mustard-100);
    padding: 3px 12px;
    border-radius: 100px;
}

/* Member grid */
.carta-bom__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
}

/* Member card — horizontal compact layout (photo + body side-by-side) */
.carta-bom-card {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    padding: 18px;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.carta-bom-card:hover {
    border-color: var(--carta-mustard);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(141,85,35,.10);
}
.carta-bom-card__photo {
    flex: 0 0 72px;
    width: 72px;
    height: 72px;
    display: block;
}
.carta-bom-card__photo-frame {
    display: block;
    width: 100%; height: 100%;
    border-radius: 50%;
    overflow: hidden;
    background: var(--carta-mustard-100);
    box-shadow: 0 0 0 2px var(--carta-mustard),
                0 0 0 3px #fff,
                0 4px 10px rgba(141,85,35,.12);
    position: relative;
}
.carta-bom-card__photo-frame img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center 18%;
    display: block;
}
.carta-bom-card__initial {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--carta-ff-heading);
    font-weight: 700;
    font-size: 26px;
    color: var(--carta-brown);
}
.carta-bom-card__body { flex: 1; min-width: 0; }
.carta-bom-card__name,
.carta-bom-card h3.carta-bom-card__name {
    margin: 0 0 2px !important;
    font-family: var(--carta-ff-heading) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
}
.carta-bom-card__name a {
    color: var(--carta-ink);
    text-decoration: none;
}
.carta-bom-card__name a:hover { color: var(--carta-brown); }
.carta-bom-card__role {
    margin: 0 0 8px;
    font-size: 11.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--carta-brown);
}
.carta-bom-card__bio {
    margin: 0 0 10px;
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--carta-muted);
}
.carta-bom-card__socials {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    gap: 6px;
}
.carta-bom-card__socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--carta-cream);
    color: var(--carta-brown);
    border: 1px solid var(--carta-grey-200);
    transition: all .15s ease;
}
.carta-bom-card__socials svg { width: 11px; height: 11px; }
.carta-bom-card__socials a:hover {
    background: var(--carta-brown);
    color: #fff;
    border-color: var(--carta-brown);
}

/* ─── Focal-persons grid on partner profiles ──────────────────────── */
.carta-partner-single__focals {
    background: #fff;
    border: 1px solid rgba(232,178,35,.3);
    border-radius: 16px;
    padding: 32px;
    margin-bottom: 28px;
    position: relative;
}
.carta-partner-single__focals::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 4px; height: 100%;
    background: linear-gradient(180deg, var(--carta-mustard), var(--carta-brown));
    border-radius: 16px 0 0 16px;
}
.carta-focal-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.carta-focal-card {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 14px;
    background: var(--carta-cream);
    border: 1px solid var(--carta-grey-200);
    border-radius: 12px;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.carta-focal-card:hover {
    background: #fff;
    border-color: var(--carta-mustard);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(141,85,35,.12);
}
.carta-focal-card__photo {
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--carta-mustard-100);
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px var(--carta-grey-200);
    position: relative;
    display: block;
}
.carta-focal-card__photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center 18%;
    display: block;
}
.carta-focal-card__initial {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--carta-ff-heading);
    font-weight: 700;
    color: var(--carta-brown);
    font-size: 22px;
}
.carta-focal-card__body { min-width: 0; flex: 1; }
.carta-focal-card__name {
    margin: 0 0 2px;
    font-family: var(--carta-ff-heading);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.25;
}
.carta-focal-card__name a {
    color: var(--carta-ink);
    text-decoration: none;
}
.carta-focal-card__name a:hover { color: var(--carta-brown); }
.carta-focal-card__role {
    margin: 0 0 8px;
    font-size: 11.5px;
    color: var(--carta-muted);
    line-height: 1.35;
}
.carta-focal-card__contacts {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.carta-focal-card__contacts a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 100px;
    background: #fff;
    border: 1px solid var(--carta-grey-200);
    color: var(--carta-muted);
    font-size: 10.5px;
    font-weight: 600;
    text-decoration: none;
    transition: all .15s ease;
}
.carta-focal-card__contacts a:hover {
    color: var(--carta-brown);
    border-color: var(--carta-brown);
    background: var(--carta-brown-100);
}

