    /* ═══════════════════════════════════════════
       DESIGN TOKENS
       Teal #004241 · Orange #E8652A · cream bg
    ═══════════════════════════════════════════ */
/* ═══════════════════════════════════════════
   DESIGN TOKENS
   Teal #046967 · Orange #F15B3F · cream bg
═══════════════════════════════════════════ */
	:root {
	  /* Brand teal */
	  --teal:        #046967;
	  --teal-dk:     #03504f;
	  --teal-md:     #058684;
	  --teal-lt:     #06a4a1;
	  --teal-bg:     rgba(4,105,103,.07);
	  --teal-bg2:    rgba(4,105,103,.13);

	  /* Brand orange */
	  --orange:      #F15B3F;
	  --orange-dk:   #ec3411;
	  --orange-lt:   #F15B3F;
	  --orange-bg:   rgba(241,91,63,.09);


      /* Neutrals */
      --ink:         #1A2229;
      --text:        #354047;
      --muted:       #6B7A84;
      --cream:       #FAF8F5;
      --warm:        #F0EBE3;
      --border:      rgba(0,0,0,.08);
      --white:       #FFFFFF;

      /* Shape */
      --r-sm: 8px;
      --r:    14px;
      --r-lg: 22px;

      /* Shadow */
      --sh-sm: 0 2px 12px rgba(0,95,92,.07);
      --sh:    0 6px 32px rgba(0,95,92,.12);
      --sh-lg: 0 16px 56px rgba(0,95,92,.16);

      /* Motion */
      --ease: cubic-bezier(.25,.46,.45,.94);
      --t:    .28s var(--ease);
    }

    /* ── RESET ── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html {
      scroll-behavior: smooth;
      -webkit-tap-highlight-color: transparent;
      font-size: 100%;
    }
    html[data-font-scale="2"] { font-size: 125%; }
    html[data-font-scale="3"] { font-size: 150%; }
    html[data-font-scale="4"] { font-size: 175%; }
    html[data-font-scale="5"] { font-size: 200%; }
    body { font-family: 'Inter', sans-serif; background: var(--cream); color: var(--text); line-height: 1.65; overflow-x: hidden; }
    img  { max-width: 100%; display: block; }
    a    { text-decoration: none; color: inherit; }
    ul   { list-style: none; }
    button { font-family: inherit; }
    .screen-reader-text {
      border: 0;
      clip: rect(1px, 1px, 1px, 1px);
      clip-path: inset(50%);
      height: 1px;
      margin: -1px;
      overflow: hidden;
      padding: 0;
      position: absolute !important;
      width: 1px;
      word-wrap: normal !important;
    }
    .screen-reader-text:focus {
      clip: auto !important;
      clip-path: none;
      display: block;
      height: auto;
      width: auto;
      left: 1rem;
      top: 1rem;
      margin: 0;
      padding: .6rem .9rem;
      background: var(--teal-dk);
      color: var(--white);
      border-radius: var(--r-sm);
      box-shadow: var(--sh);
      z-index: 2000;
    }

    /* ── TYPOGRAPHY ── */
    h1, h2, h3 { font-family: 'Lora', serif; line-height: 1.2; color: var(--ink); }
    h1 { font-size: clamp(2rem, 6.5vw, 3.8rem); font-weight: 700; }
    h2 { font-size: clamp(1.65rem, 4.5vw, 2.8rem); font-weight: 700; }
    h3 { font-size: clamp(1.05rem, 2.5vw, 1.35rem); font-weight: 600; }
    p  { font-size: .97rem; line-height: 1.75; }

    /* ── LAYOUT ── */
    .container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }
    @media (min-width: 640px)  { .container { padding: 0 1.75rem; } }
    @media (min-width: 1024px) { .container { padding: 0 2.5rem; } }

    section { padding: 4rem 0; }
    @media (min-width: 768px)  { section { padding: 6rem 0; } }
    @media (min-width: 1024px) { section { padding: 7.5rem 0; } }

    /* ── DEFAULT POST CONTENT LAYOUT (single post) ── */
    body.single-post .pdn-page-main .pdn-page-article {
      width: min(1200px, calc(100% - 2.5rem));
      margin: 0 auto;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-header,
    body.single-post .pdn-page-main .pdn-page-article .entry-content {
      width: 100%;
      margin: 0 auto;
      max-width: 1200px;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-header {
      padding-top: 2.5rem;
      margin-bottom: 1.25rem;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-header .entry-title {
      margin: 0;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-content {
      padding-bottom: 0rem;
    }
    @media (min-width: 640px) {
      body.single-post .pdn-page-main .pdn-page-article {
        width: min(1200px, calc(100% - 3.5rem));
      }
    }
    @media (min-width: 1024px) {
      body.single-post .pdn-page-main .pdn-page-article {
        width: min(1200px, calc(100% - 5rem));
      }
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-content > * {
      max-width: min(100%, 1200px);
      margin-left: auto;
      margin-right: auto;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-content > * + * {
      margin-top: 1.25rem;
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-content > .alignwide {
      max-width: min(100%, 1320px);
    }
    body.single-post .pdn-page-main .pdn-page-article .entry-content > .alignfull {
      max-width: none;
      width: 100vw;
      margin-left: calc(50% - 50vw);
      margin-right: calc(50% - 50vw);
    }

    /* ── SINGLE POST HERO + LEAD ── */
    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post {
      width: 100%;
      max-width: none;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero {
      width: 100vw;
      margin-left: calc(50% - 50vw);
      margin-right: calc(50% - 50vw);
      background: linear-gradient(135deg, #07514e 0%, #003f3d 100%);
      position: relative;
      overflow: hidden;
      padding: 3.5rem 0 4rem;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(ellipse 55% 80% at 85% 50%, rgba(241,91,63,.15) 0%, transparent 60%),
        radial-gradient(ellipse 45% 60% at 5% 80%, rgba(0,120,115,.3) 0%, transparent 55%);
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero .container {
      position: relative;
      z-index: 1;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: 2.25rem;
      align-items: center;
    }

    @media (min-width: 1024px) {
      body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-grid {
        grid-template-columns: 1fr 1fr;
        gap: 3.5rem;
      }
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .page-hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: .6rem;
      margin-bottom: 1.1rem;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .eyebrow-line {
      width: 28px;
      height: 2px;
      background: var(--orange);
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .eyebrow-text {
      font-size: .72rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--orange-lt);
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-title {
      margin: 0;
      color: #fff;
      font-size: clamp(2rem, 6.2vw, 3.8rem);
      line-height: 1.12;
      font-family: 'Lora', serif;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-title-accent {
      display: block;
      color: var(--orange-lt);
      font-style: italic;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-meta {
      display: inline-flex;
      align-items: center;
      flex-wrap: wrap;
      gap: .5rem;
      margin-top: 1.15rem;
      padding: .45rem .9rem;
      border-radius: 999px;
      background: rgba(255,255,255,.12);
      color: rgba(255,255,255,.88);
      font-size: .88rem;
      line-height: 1.35;
      letter-spacing: .01em;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-author {
      font-weight: 600;
      color: #fff;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-meta-sep {
      opacity: .58;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .page-hero-img-wrap {
      border-radius: var(--r-lg);
      overflow: hidden;
      box-shadow: 0 16px 56px rgba(0,95,92,.28);
      margin: 0;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .page-hero-img-wrap img {
      width: 100%;
      height: auto;
      display: block;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-placeholder {
      width: 100%;
      aspect-ratio: 16 / 10;
      border-radius: var(--r-lg);
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.2);
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-content {
      padding-top: clamp(1.5rem, 3vw, 2.5rem);
      padding-bottom: 0rem;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-content > * + * {
      margin-top: 1rem;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-content > p:empty {
      display: none;
    }

    body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-content > p:empty + * {
      margin-top: 0 !important;
    }

    /* ── SECTION HEADER ── */
    .sec-head { text-align: center; max-width: 640px; margin: 0 auto 3rem; }
    .sec-head h2 { margin-bottom: .75rem; }
    .sec-head p  { color: var(--muted); }

    /* ── BADGES ── */
    .badge {
      display: inline-flex; align-items: center; gap: .4rem;
      font-size: .73rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
      padding: .3rem .9rem; border-radius: 100px; margin-bottom: 1rem;
    }
    .badge--teal   { background: var(--teal-bg2); color: var(--teal-md); }
    .badge--orange { background: var(--orange-bg); color: var(--orange); }
    .badge--ink    { background: rgba(26,34,41,.06); color: var(--ink); }

    /* ── BUTTONS ── */
    .btn {
      display: inline-flex; align-items: center; gap: .5rem;
      font-size: .9rem; font-weight: 600;
      padding: .8rem 1.65rem; border-radius: 100px;
      border: 2px solid transparent; cursor: pointer;
      transition: background var(--t), color var(--t), transform var(--t), box-shadow var(--t);
      white-space: nowrap;
    }
    .btn svg { flex-shrink: 0; }

    .btn-primary {
      background: var(--orange); color: var(--white);
      box-shadow: 0 4px 18px rgba(241,91,63,.32);
    }
    .btn-primary:hover  { background: var(--orange-dk); transform: translateY(-2px); box-shadow: 0 8px 26px rgba(241,91,63,.4); }
    .btn-primary:active { transform: translateY(0); }

    .btn-teal {
      background: var(--teal); color: var(--white);
      box-shadow: 0 4px 18px rgba(0,66,65,.28);
    }
    .btn-teal:hover  { background: var(--teal-dk); transform: translateY(-2px); }

    .btn-outline {
      background: transparent; color: var(--teal);
      border-color: rgba(0,66,65,.25);
    }
    .btn-outline:hover { border-color: var(--teal); background: var(--teal-bg); }

    .btn-outline-white {
      background: transparent; color: var(--white);
      border-color: rgba(255,255,255,.38);
    }
    .btn-outline-white:hover { border-color: var(--white); background: rgba(255,255,255,.1); }


    /* ═══════════════════════════════════════════
       HEADER  —  two rows
       Row 1 (logo bar): white bg, logo + social + hamburger
       Row 2 (nav bar):  light teal bg, nav links + CTA (desktop only)
    ═══════════════════════════════════════════ */
    #header {
      position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 200;
      transition: box-shadow var(--t);
    }
    #header.scrolled { box-shadow: 0 2px 24px rgba(0,95,92,.18); }

    /* Row 1 – logo */
    .header-top {
      background: var(--white);
      border-bottom: 1px solid var(--border);
      padding: .7rem 0;
    }
    .header-top-inner {
      display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    }
    .nav-logo img { height: 42px; width: auto; display: block; }
    @media (min-width: 768px) { .nav-logo img { height: 42px; } }

    .header-top-right {
      display: flex; align-items: center; gap: .6rem;
    }
    /* social icons in top bar – show desktop only */
    .header-social { display: none; align-items: center; gap: .3rem; }
    @media (min-width: 768px) { .header-social { display: flex; } }
    .header-social a,
    .header-social .social-disabled {
      width: 32px; height: 32px; border-radius: var(--r-sm);
      color: var(--muted); display: flex; align-items: center; justify-content: center;
      transition: color var(--t), background var(--t);
    }
    .header-social a:hover { color: var(--teal); background: var(--teal-bg); }
    .header-social .social-disabled { opacity: .65; cursor: default; }
    .pdn-social-icon { display: block; flex-shrink: 0; fill: currentColor; }

    /* hamburger – mobile only */
    .hamburger {
      display: flex; align-items: center; justify-content: center;
      width: 40px; height: 40px; border-radius: var(--r-sm);
      background: var(--warm); border: 1px solid var(--border);
      cursor: pointer; color: var(--teal); flex-shrink: 0;
      transition: background var(--t);
    }
    .hamburger:hover { background: var(--teal-bg2); }
    @media (min-width: 1024px) { .hamburger { display: none; } }

    /* Row 2 – nav */
    .header-nav {
      background: var(--teal);
      padding: 0;
    }
    .header-nav-inner {
      display: flex; align-items: stretch; justify-content: space-between; gap: 0;
    }

    /* Nav links */
    .nav-links {
      display: flex; align-items: stretch; gap: 0; flex-wrap: nowrap;
      overflow-x: auto; -webkit-overflow-scrolling: touch;
      scrollbar-width: none; list-style: none;
      margin: 0; padding: 0;
    }
    .nav-links::-webkit-scrollbar { display: none; }
    .nav-links > li { position: relative; list-style: none; }
    @media (min-width: 1024px) { .nav-links { overflow: visible; } }

    .nav-links > li > a {
      display: flex; align-items: center;
      font-size: .84rem; font-weight: 500; color: rgba(255,255,255,.78);
      padding: .75rem .95rem; white-space: nowrap;
      border-bottom: 2px solid transparent;
      transition: color var(--t), background var(--t), border-color var(--t);
    }
    .nav-links > li > a:hover,
    .nav-links > li > a.active,
    .nav-links > li:hover > a,
    .nav-links > li:focus-within > a {
      color: var(--white); background: rgba(255,255,255,.08);
      border-bottom-color: var(--orange);
    }
    .nav-links > li.has-submenu > a::after {
      content: "";
      width: .36rem; height: .36rem;
      border-right: 1.6px solid currentColor; border-bottom: 1.6px solid currentColor;
      transform: rotate(45deg); margin-left: .45rem;
      transition: transform var(--t);
    }
    .nav-links > li.has-submenu:hover > a::after,
    .nav-links > li.has-submenu:focus-within > a::after {
      transform: rotate(-135deg) translate(-1px, -1px);
    }

    .nav-submenu {
      display: none; position: absolute; inset-inline-start: 0; top: calc(100% - 1px);
      min-width: 220px; z-index: 80; list-style: none;
      margin: 0; padding: .35rem 0;
      background: var(--white); border: 1px solid var(--border); border-top: 0;
      border-radius: 0 0 var(--r-sm) var(--r-sm); box-shadow: var(--sh);
    }
    .nav-links > li.has-submenu:hover > .nav-submenu,
    .nav-links > li.has-submenu:focus-within > .nav-submenu { display: block; }
    .nav-submenu li { list-style: none; }
    .nav-submenu a {
      display: flex; align-items: center;
      font-size: .82rem; font-weight: 500; color: var(--ink);
      padding: .6rem .95rem; white-space: nowrap;
      border-bottom: 0;
      transition: background var(--t), color var(--t);
    }
    .nav-submenu a:hover, .nav-submenu a:focus-visible {
      background: var(--teal-bg); color: var(--teal);
    }
    @media (max-width: 1023.98px) {
      .nav-links > li.has-submenu .nav-submenu { display: none !important; }
      .nav-links > li.has-submenu > a::after { display: none; }
    }

    /* Nav CTA */
    .nav-cta {
      display: none; align-items: center;
      padding: 0rem 0; flex-shrink: 0;
    }
    @media (min-width: 1024px) { .nav-cta { display: flex; gap: .5rem; } }
    .nav-cta .btn { padding: .5rem 1.2rem; font-size: .82rem; border-radius: 100px; }
    .nav-cta .btn-orange-nav {
      background: var(--orange); color: var(--white); border: 2px solid transparent;
      transition: background var(--t), transform var(--t);
    }
    .nav-cta .btn-orange-nav:hover { background: var(--orange-dk); transform: none; }
    .nav-cta .btn-ghost-nav {
      background: transparent; color: rgba(255,255,255,.8); border: 1.5px solid rgba(255,255,255,.3);
    }
    .nav-cta .btn-ghost-nav:hover { background: rgba(255,255,255,.1); color: var(--white); }

    /* offset body so content clears the two-row header */
    .header-spacer { height: 96px; }
    @media (min-width: 768px) { .header-spacer { height: 104px; } }


    /* ═══════════════════════════════════════════
       MOBILE DRAWER
    ═══════════════════════════════════════════ */
    .overlay {
      display: none; position: fixed; inset: 0;
      background: rgba(0,34,33,.5); z-index: 300;
      backdrop-filter: blur(4px);
    }
    .overlay.open { display: block; }

    .drawer {
      position: fixed; inset-block: 0; inset-inline-end: 0;
      width: min(320px, 88vw); background: var(--white);
      z-index: 301; padding: 0;
      transform: translateX(100%); transition: transform .35s var(--ease);
      overflow-y: auto; -webkit-overflow-scrolling: touch;
      box-shadow: -6px 0 40px rgba(0,66,65,.18);
      display: flex; flex-direction: column;
    }
    .drawer.open { transform: translateX(0); }

    .drawer-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1rem 1.25rem; border-bottom: 1px solid var(--border);
      background: var(--white); flex-shrink: 0;
    }
    .drawer-head img { height: 36px; filter: brightness(0); }
    .drawer-close {
      width: 36px; height: 36px; border-radius: var(--r-sm);
      background: var(--warm); border: 1px solid var(--border);
      cursor: pointer; color: var(--teal);
      display: flex; align-items: center; justify-content: center;
      transition: background var(--t);
    }
    .drawer-close:hover { background: var(--teal-bg2); }

    .drawer-nav { flex: 1; padding: .5rem 0; }
    .drawer-nav-link {
      display: flex; align-items: center; gap: .75rem;
      font-size: .95rem; font-weight: 500; color: var(--ink);
      padding: .9rem 1.25rem;
      border-bottom: 1px solid var(--border);
      transition: background var(--t), color var(--t);
    }
    .drawer-nav-link:hover { background: var(--teal-bg); color: var(--teal); }
    .drawer-submenu {
      background: var(--warm);
      padding: .15rem 0 .45rem;
    }
    .drawer-submenu-link {
      display: flex; align-items: center; gap: .65rem;
      font-size: .88rem; font-weight: 500; color: var(--ink);
      padding: .6rem 1.25rem .6rem 2.35rem;
      border-bottom: 1px solid var(--border);
      transition: background var(--t), color var(--t);
    }
    .drawer-submenu-link:last-child { border-bottom: none; }
    .drawer-submenu-link:hover { background: var(--teal-bg); color: var(--teal); }
    .drawer-nav-link svg, .drawer-submenu-link svg { color: var(--teal); opacity: .7; flex-shrink: 0; }
    .drawer-submenu-link svg { opacity: .55; }

    .drawer-footer {
      padding: 1.25rem; border-top: 1px solid var(--border);
      display: flex; flex-direction: column; gap: .65rem; flex-shrink: 0;
    }
    .drawer-footer .btn { justify-content: center; }
    .drawer-access-btn {
      display: flex; align-items: center; justify-content: flex-start; gap: .65rem;
      padding: .75rem 1rem; border-radius: var(--r-sm);
      background: var(--warm); border: 1.5px solid var(--border);
      cursor: pointer; color: var(--ink); font-size: .88rem; font-weight: 600;
      width: 100%; transition: background var(--t), color var(--t), border-color var(--t);
    }
    .drawer-access-btn[aria-pressed="true"] {
      background: var(--teal); border-color: var(--teal); color: var(--white);
    }
    .drawer-access-btn svg,
    .drawer-access-aa {
      flex-shrink: 0;
    }
    .drawer-access-aa {
      font: 700 0.95rem/1 'Inter', sans-serif;
      letter-spacing: .02em;
    }

    .drawer-social {
      display: flex; align-items: center; justify-content: center; gap: .75rem;
      padding-top: .75rem;
    }
    .drawer-social a,
    .drawer-social .social-disabled {
      width: 34px; height: 34px; border-radius: var(--r-sm);
      background: var(--warm); color: var(--teal);
      display: flex; align-items: center; justify-content: center;
      transition: background var(--t);
    }
    .drawer-social a:hover { background: var(--teal-bg2); }
    .drawer-social .social-disabled { opacity: .7; cursor: default; }


    /* ═══════════════════════════════════════════
       HERO
    ═══════════════════════════════════════════ */
    .hero {
      background: var(--teal-dk);
      display: flex; align-items: center;
      position: relative; overflow: hidden;
    }

    .hero-bg { position: absolute; inset: 0; pointer-events: none; }
    .hero-bg::before {
      content: ''; position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 60% 50% at 80% 20%, rgba(241,91,63,.15) 0%, transparent 55%),
        radial-gradient(ellipse 50% 45% at 10% 85%, rgba(0,120,115,.35) 0%, transparent 50%);
    }

    .hero-inner {
      position: relative; z-index: 2;
      padding: 4rem 0 4.5rem;
      display: grid; gap: 2.5rem; align-items: center;
    }
    @media (min-width: 768px)  { .hero-inner { padding: 5rem 0 5.5rem; } }
    @media (min-width: 1024px) { .hero-inner { grid-template-columns: 1fr 1fr; gap: 4rem; padding: 5.5rem 0 6rem; } }

    .hero-eyebrow { display: inline-flex; align-items: center; gap: .6rem; margin-bottom: 1.3rem; }
    .hero-eyebrow-line { width: 32px; height: 2px; background: var(--orange); }
    .hero-eyebrow-text { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--orange); }

    .hero h1 { color: var(--white); margin-bottom: 1.2rem; }
    .hero h1 em { color: var(--orange-lt); font-style: italic; }
    .hero-desc { font-size: 1.03rem; color: rgba(255,255,255,.7); margin-bottom: 1.9rem; max-width: 480px; }
    .hero-actions { display: flex; flex-wrap: wrap; gap: .7rem; }

    /* hero rotator */
    .pdn-areas-rotator {
      --pdn-rotator-surface: rgba(255,255,255,.06);
      --pdn-rotator-surface-2: rgba(255,255,255,.05);
      --pdn-rotator-border: rgba(255,255,255,.12);
      --pdn-rotator-text: rgba(255,255,255,.94);
      --pdn-rotator-muted: rgba(255,255,255,.56);
      --pdn-rotator-active-accent: #F15B3F;
      position: relative;
      width: 100%;
      max-width: 620px;
      margin-inline: auto;
      border-radius: var(--r-lg);
      border: 1px solid var(--pdn-rotator-border);
      background: var(--pdn-rotator-surface);
      backdrop-filter: blur(14px);
      padding: 1.6rem;
      outline: none;
    }
    .pdn-areas-rotator:focus-visible {
      box-shadow: 0 0 0 3px rgba(241,91,63,.45);
    }
    @media (min-width: 1024px) {
      .pdn-areas-rotator { padding: 2rem; }
    }
    .pdn-areas-rotator__accent {
      position: absolute;
      top: 0;
      left: 2rem;
      right: 2rem;
      height: 3px;
      border-radius: 0 0 4px 4px;
      background: linear-gradient(90deg, var(--orange), var(--orange-lt));
    }
    .pdn-areas-rotator__label {
      display: inline-flex;
      align-items: center;
      gap: .65rem;
      margin-bottom: 1.15rem;
      font-size: .72rem;
      font-weight: 700;
      letter-spacing: .09em;
      text-transform: uppercase;
      color: rgba(255,255,255,.42);
    }
    .pdn-areas-rotator__label::before {
      content: '';
      width: 24px;
      height: 1px;
      background: rgba(255,255,255,.28);
    }
    .pdn-areas-rotator__stack {
      display: none;
    }
    .pdn-areas-rotator__ghost {
      position: absolute;
      inset: 0;
      border-radius: var(--r);
      border: 1px solid rgba(255,255,255,.08);
      background: var(--pdn-rotator-surface-2);
      opacity: 0;
      transition: opacity .35s ease, transform .35s ease;
    }
    .pdn-areas-rotator__ghost--1 {
      transform: translateY(8px) scale(.97);
    }
    .pdn-areas-rotator__ghost--2 {
      transform: translateY(12px) scale(.94);
    }
    .pdn-areas-rotator__ghost.visible.pdn-areas-rotator__ghost--1 {
      opacity: .42;
      transform: translateY(7px) scale(.97);
    }
    .pdn-areas-rotator__ghost.visible.pdn-areas-rotator__ghost--2 {
      opacity: .2;
      transform: translateY(11px) scale(.94);
    }
    .pdn-areas-rotator__slides {
      position: relative;
      min-height: 180px;
    }
    .pdn-areas-rotator__slide {
      position: absolute;
      inset: 0;
      z-index: 0;
      border-radius: 0;
      border: 0;
      background: transparent;
      color: inherit;
      text-decoration: none;
      padding: .2rem 0;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      opacity: 0;
      transform: translateY(14px) scale(.98);
      pointer-events: none;
      transition: opacity .45s ease, transform .45s ease, border-color .35s ease, box-shadow .45s ease;
    }
    .pdn-areas-rotator__slide.is-active {
      opacity: 1;
      transform: none;
      pointer-events: auto;
      z-index: 2;
      border-color: transparent;
      box-shadow: none;
    }
    .pdn-areas-rotator__slide.is-exiting {
      opacity: 0;
      transform: translateY(-8px) scale(.98);
      pointer-events: none;
      z-index: 1;
    }
    .pdn-areas-rotator__top {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: .8rem;
      margin-bottom: .8rem;
    }
    .pdn-areas-rotator__content-wrap {
      display: flex;
      align-items: flex-start;
      gap: .75rem;
      flex: 1;
      min-width: 0;
    }
    .pdn-areas-rotator__dot {
      width: 10px;
      height: 10px;
      border-radius: 50%;
      margin-top: .4rem;
      background: var(--pdn-rotator-accent, #F15B3F);
      box-shadow: 0 0 10px var(--pdn-rotator-accent, #F15B3F);
      transition: transform .25s ease;
      flex-shrink: 0;
    }
    .pdn-areas-rotator__slide.is-active .pdn-areas-rotator__dot {
      transform: scale(1.2);
    }
    .pdn-areas-rotator__content {
      min-width: 0;
    }
    .pdn-areas-rotator__title {
      margin: 0 0 .4rem;
      color: var(--pdn-rotator-text);
      font-family: 'Lora', serif;
      font-size: clamp(1.05rem, 2.6vw, 1.45rem);
      line-height: 1.25;
    }
    .pdn-areas-rotator__desc {
      margin: 0;
      color: var(--pdn-rotator-muted);
      font-size: .85rem;
      line-height: 1.6;
      max-width: 36ch;
    }
    .pdn-areas-rotator__number {
      color: rgba(255,255,255,.36);
      font-size: .68rem;
      font-weight: 600;
      letter-spacing: .07em;
      flex-shrink: 0;
    }
    .pdn-areas-rotator__bottom {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: .7rem;
      padding-top: .75rem;
      border-top: 1px solid rgba(255,255,255,.18);
    }
    .pdn-areas-rotator__tag {
      font-size: .68rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--pdn-rotator-accent, #F15B3F);
    }
    .pdn-areas-rotator__arrow {
      width: 30px;
      height: 30px;
      border-radius: 50%;
      border: 1px solid var(--pdn-rotator-accent, #F15B3F);
      color: var(--pdn-rotator-accent, #F15B3F);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      transition: transform var(--t), background var(--t), color var(--t);
    }
    .pdn-areas-rotator__slide:hover .pdn-areas-rotator__arrow {
      background: var(--pdn-rotator-accent, #F15B3F);
      color: #fff;
      transform: translateX(2px);
    }
    .pdn-areas-rotator__progress {
      height: 2px;
      border-radius: 2px;
      margin-top: 1rem;
      overflow: hidden;
      background: rgba(255,255,255,.15);
    }
    .pdn-areas-rotator__progress-bar {
      width: 0;
      height: 100%;
      border-radius: 2px;
      background: var(--pdn-rotator-active-accent);
      transition: width linear, background .3s ease;
    }
    .pdn-areas-rotator__progress-bar.is-running {
      width: 100%;
    }
    .pdn-areas-rotator__nav {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: .75rem;
      margin-top: .95rem;
    }
    .pdn-areas-rotator__dots {
      display: inline-flex;
      align-items: center;
      gap: .4rem;
    }
    .pdn-areas-rotator__dot-btn {
      width: 9px;
      height: 9px;
      border-radius: 50%;
      border: none;
      padding: 0;
      cursor: pointer;
      background: rgba(255,255,255,.24);
      transition: transform .25s ease, background .25s ease;
    }
    .pdn-areas-rotator__dot-btn.is-active {
      background: var(--pdn-rotator-dot-accent, #F15B3F);
      transform: scale(1.3);
    }
    .pdn-areas-rotator__controls {
      display: inline-flex;
      align-items: center;
      gap: .4rem;
    }
    .pdn-areas-rotator__ctrl {
      width: 30px;
      height: 30px;
      border-radius: 50%;
      border: 1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.05);
      color: rgba(255,255,255,.72);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: border-color var(--t), color var(--t), background var(--t);
    }
    .pdn-areas-rotator__ctrl:hover {
      border-color: rgba(255,255,255,.45);
      color: #fff;
      background: rgba(255,255,255,.1);
    }
    .pdn-areas-rotator__dot-btn:focus-visible,
    .pdn-areas-rotator__ctrl:focus-visible {
      outline: 2px solid var(--orange);
      outline-offset: 2px;
    }
    @media (max-width: 479.98px) {
      .pdn-areas-rotator {
        padding: 1.15rem;
      }
      .pdn-areas-rotator__accent {
        left: 1.15rem;
        right: 1.15rem;
      }
      .pdn-areas-rotator__slide {
        padding: .15rem 0;
      }
      .pdn-areas-rotator__desc {
        font-size: .8rem;
      }
    }


    /* ═══════════════════════════════════════════
       MARQUEE
    ═══════════════════════════════════════════ */
    .marquee { background: var(--orange); overflow: hidden; padding: .75rem 0; }
    .marquee-track { display: flex; gap: 2.5rem; animation: scrollx 26s linear infinite; width: max-content; }
    .marquee:hover .marquee-track { animation-play-state: paused; }
    @keyframes scrollx { from { transform: translateX(0); } to { transform: translateX(-50%); } }
    .m-item { display: flex; align-items: center; gap: .55rem; flex-shrink: 0; font-size: .78rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--white); }
    .m-sep  { width: 4px; height: 4px; margin-top: 8px; border-radius: 50%; background: rgba(255,255,255,.4); flex-shrink: 0; }


    /* ═══════════════════════════════════════════
       MISSION
    ═══════════════════════════════════════════ */
    .mission { background: var(--cream); }
    .mission-grid { display: grid; gap: 3rem; align-items: center; }
    .mission-text { width: 100%; }

    .mission-text h2 { margin-bottom: 1rem; }
    .mission-text p  { color: var(--muted); margin-bottom: 1rem; }
    .mission-pills   { display: flex; flex-wrap: wrap; gap: .45rem; margin: 1.5rem 0 2rem; }
    .pill {
      font-size: .78rem; font-weight: 500; color: var(--text);
      padding: .38rem .95rem; border-radius: 100px;
      background: var(--warm); border: 1px solid var(--border);
      transition: background var(--t), color var(--t), border-color var(--t);
    }
    .pill:hover { background: var(--teal-bg2); color: var(--teal); border-color: rgba(0,66,65,.2); }


    /* ═══════════════════════════════════════════
       AREAS
    ═══════════════════════════════════════════ */
    .areas { background: var(--teal-dk); }
    .areas .sec-head h2 { color: var(--white); }
    .areas .sec-head p  { color: rgba(255,255,255,.52); }

    .areas-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
    @media (min-width: 560px)  { .areas-grid { grid-template-columns: 1fr 1fr; } }
    @media (min-width: 1024px) { .areas-grid { grid-template-columns: repeat(3, 1fr); } }

    .area-card {
      background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09);
      border-radius: var(--r); padding: 1.5rem;
      transition: background var(--t), border-color var(--t), transform var(--t);
      position: relative; overflow: hidden;
    }
    .area-card::after {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
      background: linear-gradient(90deg, var(--orange), var(--orange-lt));
      transform: scaleX(0); transform-origin: left; transition: transform var(--t);
    }
    .area-card:hover { background: rgba(255,255,255,.08); border-color: rgba(241,91,63,.22); transform: translateY(-3px); }
    .area-card:hover::after { transform: scaleX(1); }

    .area-icon { width: 44px; height: 44px; border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; flex-shrink: 0; }
    .ico { background: rgba(241,91,63,.15); color: var(--orange-lt); }
    .ico2 { background: rgba(114,200,152,.15); color: #72c898; }
    .ico3 { background: rgba(114,174,212,.15); color: #7ab8e0; }
    .ico4 { background: rgba(232,192,72,.12);  color: #e8c048; }
    .ico5 { background: rgba(98,212,184,.12);  color: #62d4b8; }
    .ico6 { background: rgba(196,154,232,.12); color: #c49ae8; }

    .area-card h3 { color: var(--white); font-size: 1.02rem; margin-bottom: .55rem; }
    .area-card p  { font-size: .85rem; color: rgba(255,255,255,.5); line-height: 1.65; }
    .area-link {
      display: inline-flex; align-items: center; gap: .35rem;
      font-size: .81rem; font-weight: 600; color: var(--orange-lt); margin-top: 1rem;
      transition: gap var(--t);
    }
    .area-card:hover .area-link { gap: .6rem; }


    /* ═══════════════════════════════════════════
       WORKSHOPS
    ═══════════════════════════════════════════ */
    .workshops { background: var(--cream); }
    .workshops-grid { display: grid; gap: 1.2rem; }
    @media (min-width: 640px)  { .workshops-grid { grid-template-columns: 1fr 1fr; } }

    .ws-card {
      background: var(--white); border-radius: var(--r); overflow: hidden;
      box-shadow: var(--sh-sm); display: flex; flex-direction: column;
      transition: transform var(--t), box-shadow var(--t);
    }
    .ws-card:hover { transform: translateY(-4px); box-shadow: var(--sh); }

    /* side-by-side on narrow mobile */
    @media (min-width: 420px) and (max-width: 639px) {
      .ws-card { flex-direction: row; }
      .ws-img  { width: 130px; flex-shrink: 0; }
    }

    .ws-img { overflow: hidden; background: var(--warm); }
    .ws-img img { width: 100%; height: 170px; object-fit: cover; transition: transform .5s ease; display: block; }
    @media (min-width: 420px) and (max-width: 639px) { .ws-img img { height: 100%; min-height: 130px; } }
    .ws-card:hover .ws-img img { transform: scale(1.05); }

    .ws-body { padding: 1.25rem; display: flex; flex-direction: column; flex: 1; }
    .ws-type { font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--orange); margin-bottom: .4rem; }
    .ws-body h3 { font-size: .98rem; color: var(--ink); margin-bottom: .45rem; line-height: 1.35; }
    .ws-body p  { font-size: .83rem; color: var(--muted); flex: 1; line-height: 1.65; }
    .ws-foot {
      display: flex; align-items: center; justify-content: space-between;
      margin-top: .9rem; padding-top: .85rem; border-top: 1px solid var(--border);
    }
    .ws-speaker { display: flex; align-items: center; gap: .45rem; font-size: .78rem; color: var(--muted); }
    .ws-av { width: 26px; height: 26px; border-radius: 50%; background: var(--warm); display: flex; align-items: center; justify-content: center; color: var(--muted); flex-shrink: 0; }
    .ws-arr {
      width: 30px; height: 30px; border-radius: 50%; background: var(--warm);
      color: var(--teal); display: flex; align-items: center; justify-content: center; flex-shrink: 0;
      transition: background var(--t), color var(--t);
    }
    .ws-card:hover .ws-arr { background: var(--orange); color: var(--white); }

    .sec-cta { text-align: center; margin-top: 2.5rem; }

    /* posts loop based on workshops cards */
    .pdn-posts-loop { background: var(--cream); }
    .pdn-posts-loop .sec-head { max-width: 760px; }
    .pdn-posts-loop .sec-head h1 {
      font-size: clamp(1.9rem, 4.8vw, 3rem);
      line-height: 1.2;
      margin-bottom: .75rem;
    }
    .pdn-posts-grid { margin-bottom: 2rem; }
    .ws-img--placeholder {
      min-height: 170px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, rgba(0,95,92,.14) 0%, rgba(241,91,63,.16) 100%);
      color: var(--teal);
      font-family: 'Lora', serif;
      font-size: 1rem;
      font-weight: 600;
      letter-spacing: .02em;
    }
    @media (min-width: 420px) and (max-width: 639px) { .ws-img--placeholder { min-height: 130px; height: 100%; } }

    .pdn-posts-empty {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      box-shadow: var(--sh-sm);
      padding: 2rem 1.4rem;
      text-align: center;
      max-width: 760px;
      margin: 0 auto;
    }
    .pdn-posts-empty h3 { margin-bottom: .55rem; }
    .pdn-posts-empty p { color: var(--muted); }

    .pdn-posts-pagination {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      gap: .45rem;
      margin-top: 2rem;
    }
    .pdn-posts-pagination .page-numbers {
      min-width: 40px;
      height: 40px;
      padding: 0 .9rem;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: var(--white);
      color: var(--teal);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: .86rem;
      font-weight: 600;
      transition: background var(--t), color var(--t), border-color var(--t);
      text-decoration: none;
    }
    .pdn-posts-pagination .page-numbers.current,
    .pdn-posts-pagination .page-numbers:hover {
      background: var(--teal);
      color: var(--white);
      border-color: var(--teal);
    }


    /* ═══════════════════════════════════════════
       NEWS
    ═══════════════════════════════════════════ */
    .news { background: var(--warm); }
    .news-grid { display: grid; gap: 1.2rem; }
    @media (min-width: 640px)  { .news-grid { grid-template-columns: 1fr 1fr; } }
    @media (min-width: 1024px) { .news-grid { grid-template-columns: repeat(3, 1fr); } }

    .nc {
      background: var(--white); border-radius: var(--r); overflow: hidden;
      box-shadow: var(--sh-sm); display: flex; flex-direction: column;
      transition: transform var(--t), box-shadow var(--t);
    }
    .nc:hover { transform: translateY(-4px); box-shadow: var(--sh); }
    .nc-img { height: 185px; overflow: hidden; background: var(--warm); }
    .nc-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
    .nc:hover .nc-img img { transform: scale(1.05); }
    .nc-body { padding: 1.2rem; flex: 1; display: flex; flex-direction: column; }
    .nc-meta { font-size: .71rem; color: var(--muted); margin-bottom: .45rem; display: flex; align-items: center; gap: .35rem; }
    .nc-body h3 { font-size: .97rem; margin-bottom: .55rem; line-height: 1.35; }
    .nc-body p  { font-size: .84rem; color: var(--muted); flex: 1; }
    .nc-read {
      display: inline-flex; align-items: center; gap: .35rem;
      font-size: .8rem; font-weight: 600; color: var(--orange); margin-top: .9rem;
      transition: gap var(--t);
    }
    .nc:hover .nc-read { gap: .6rem; }


    /* ═══════════════════════════════════════════
       CTA BANNER
    ═══════════════════════════════════════════ */
    .cta-band { background: var(--teal); padding: 4rem 0; position: relative; overflow: hidden; }
    .cta-band::before {
      content: ''; position: absolute; top: -120px; left: -120px;
      width: 420px; height: 420px; border-radius: 50%;
      background: radial-gradient(circle, rgba(241,91,63,.18) 0%, transparent 65%);
      pointer-events: none;
    }
    .cta-inner {
      position: relative; z-index: 1;
      display: flex; flex-direction: column; gap: 2rem; align-items: flex-start;
    }
    @media (min-width: 768px) { .cta-inner { flex-direction: row; align-items: center; justify-content: space-between; } }
    .cta-text h2 { color: var(--white); }
    .cta-text h2 em { color: var(--orange-lt); font-style: italic; }
    .cta-text p    { color: rgba(255,255,255,.6); margin-top: .7rem; }
    .cta-actions   { display: flex; flex-wrap: wrap; gap: .7rem; flex-shrink: 0; }


    /* ═══════════════════════════════════════════
       HOME PARTNERS
    ═══════════════════════════════════════════ */
    .home-partners { background: var(--cream); padding: 4.5rem 0; }
    @media (min-width: 768px) { .home-partners { padding: 6rem 0; } }
    @media (min-width: 1024px) { .home-partners { padding: 7.5rem 0; } }
    .home-partners-logos {
      display: grid; gap: 2rem; grid-template-columns: repeat(2, minmax(0, 1fr));
      align-items: center; justify-items: center; margin-top: 2rem;
    }
    @media (min-width: 640px) { .home-partners-logos { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
    @media (min-width: 1024px) { .home-partners-logos { grid-template-columns: repeat(5, minmax(0, 1fr)); } }
    .home-partner-logo {
      display: flex; align-items: center; justify-content: center;
      min-height: 116px; width: 100%; margin: 0;
    }
    .home-partner-logo img {
      max-height: 96px; width: auto; max-width: 100%; object-fit: contain;
      opacity: .75; transition: opacity var(--t), filter var(--t); filter: grayscale(.3);
    }
    .home-partner-logo img:hover { opacity: 1; filter: grayscale(0); }
    @media (min-width: 1024px) {
      .home-partner-logo { min-height: 180px; }
      .home-partner-logo img { max-height: 168px; }
    }


    /* ═══════════════════════════════════════════
       CONTACT
    ═══════════════════════════════════════════ */
    .contact { background: var(--cream); }
    .contact-grid { display: grid; gap: 3rem; }
    .contact-grid { max-width: 760px; margin: 0 auto; }

    .ci-info h2 { margin-bottom: .9rem; }
    .ci-info > p { color: var(--muted); margin-bottom: 1.8rem; }
    .ci-list { display: flex; flex-direction: column; gap: .95rem; }
    .ci-item { display: flex; align-items: flex-start; gap: .85rem; }
    .ci-icon {
      width: 40px; height: 40px; border-radius: var(--r-sm);
      background: var(--teal); color: var(--white);
      display: flex; align-items: center; justify-content: center; flex-shrink: 0;
    }
    .ci-label { font-size: .7rem; color: var(--muted); text-transform: uppercase; letter-spacing: .07em; margin-bottom: .15rem; }
    .ci-val   { font-size: .92rem; font-weight: 500; color: var(--ink); }
    .ci-val a { color: var(--orange); transition: color var(--t); }
    .ci-val a:hover { color: var(--orange-dk); }

    .ci-form {
      background: var(--white); border-radius: var(--r-lg); padding: 1.75rem; box-shadow: var(--sh);
    }
    @media (min-width: 640px) { .ci-form { padding: 2.2rem; } }
    .ci-form h3 { font-size: 1.25rem; color: var(--ink); margin-bottom: 1.35rem; }
    .frow { display: grid; gap: 1rem; grid-template-columns: 1fr; }
    @media (min-width: 480px) { .frow { grid-template-columns: 1fr 1fr; } }
    .fg { margin-bottom: 1rem; }
    .fg label { display: block; font-size: .8rem; font-weight: 600; color: var(--ink); margin-bottom: .4rem; }
    .fg input, .fg textarea, .fg select {
      width: 100%; padding: .78rem 1rem;
      border: 1.5px solid var(--border); border-radius: var(--r-sm);
      font-family: 'Inter', sans-serif; font-size: .92rem; color: var(--text);
      background: var(--cream); outline: none; -webkit-appearance: none;
      transition: border-color var(--t), box-shadow var(--t);
    }
    .fg input:focus, .fg textarea:focus, .fg select:focus {
      border-color: var(--teal); box-shadow: 0 0 0 3px rgba(0,66,65,.12);
    }
    .fg textarea { resize: vertical; min-height: 108px; }
    .form-submit { width: 100%; justify-content: center; margin-top: .5rem; }


    /* ═══════════════════════════════════════════
       FOOTER
    ═══════════════════════════════════════════ */
    footer { background: var(--teal-dk); color: rgba(255,255,255,.58); padding: 3.5rem 0 1.75rem; }

    .ft-main {
      display: grid; gap: 2.5rem; grid-template-columns: 1fr;
      padding-bottom: 2.5rem; border-bottom: 1px solid rgba(255,255,255,.1); margin-bottom: 1.75rem;
    }
    @media (min-width: 560px)  { .ft-main { grid-template-columns: 1fr 1fr; } }
    @media (min-width: 1024px) { .ft-main { grid-template-columns: 2fr 1fr 1.3fr; } }

    .ft-brand img { height: 40px; margin-bottom: .9rem; }
    .ft-brand p   { font-size: .85rem; color: rgba(255,255,255,.4); max-width: 255px; margin-bottom: 1.15rem; }
    .ft-social { display: flex; gap: .55rem; }
    .ft-social a,
    .ft-social .social-disabled {
      width: 34px; height: 34px; border-radius: var(--r-sm);
      background: rgba(255,255,255,.07); color: rgba(255,255,255,.5);
      display: flex; align-items: center; justify-content: center;
      transition: background var(--t), color var(--t);
    }
    .ft-social a:hover { background: var(--orange); color: var(--white); }
    .ft-social .social-disabled { opacity: .7; cursor: default; }

    .ft-col h4 { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.32); margin-bottom: 1rem; }
    .ft-col ul { display: flex; flex-direction: column; gap: .5rem; }
    .ft-col a  { font-size: .86rem; color: rgba(255,255,255,.48); transition: color var(--t); }
    .ft-col a:hover { color: var(--orange-lt); }

    .ft-nl p { font-size: .83rem; color: rgba(255,255,255,.4); margin-bottom: .85rem; }
    .ft-nl-row { display: flex; gap: .45rem; }
    .ft-nl-row input {
      flex: 1; min-width: 0; padding: .62rem .9rem; border-radius: var(--r-sm);
      border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.07);
      color: var(--white); font-size: .84rem; font-family: inherit; outline: none;
      transition: border-color var(--t);
    }
    .ft-nl-row input:focus { border-color: var(--orange); }
    .ft-nl-row input::placeholder { color: rgba(255,255,255,.28); }
    .ft-nl-row button {
      padding: .62rem .95rem; background: var(--orange); color: var(--white);
      border: none; border-radius: var(--r-sm); cursor: pointer; font-weight: 700; font-size: .83rem;
      white-space: nowrap; transition: background var(--t);
    }
    .ft-nl-row button:hover { background: var(--orange-dk); }

    .ft-bottom {
      display: flex; flex-direction: column; gap: .65rem; font-size: .79rem;
    }
    @media (min-width: 640px) { .ft-bottom { flex-direction: row; justify-content: space-between; align-items: center; } }
    .ft-links { display: flex; flex-wrap: wrap; gap: 1.1rem; }
    .ft-links a, .ft-bottom span { color: rgba(255,255,255,.35); }
    .ft-links a:hover { color: var(--orange-lt); transition: color var(--t); }


    /* ═══════════════════════════════════════════
       SCROLL TO TOP
    ═══════════════════════════════════════════ */
    #scrolltop {
      position: fixed; bottom: 1.4rem; right: 1.4rem; z-index: 150;
      width: 42px; height: 42px; border-radius: 50%;
      background: var(--teal); color: var(--white); border: none;
      display: flex; align-items: center; justify-content: center;
      box-shadow: 0 4px 18px rgba(0,95,92,.35); cursor: pointer;
      opacity: 0; pointer-events: none; transition: opacity var(--t), transform var(--t);
    }
    #scrolltop.show { opacity: 1; pointer-events: auto; }
    #scrolltop:hover { transform: translateY(-3px); }


    /* ═══════════════════════════════════════════
       CONTRAST TOGGLE BUTTON
    ═══════════════════════════════════════════ */
    .contrast-btn,
    .text-size-btn {
      display: flex; align-items: center; justify-content: center;
      width: 32px; height: 32px; border-radius: var(--r-sm);
      background: var(--warm); border: 1.5px solid var(--border);
      cursor: pointer; color: var(--muted); flex-shrink: 0;
      transition: color var(--t), background var(--t), border-color var(--t);
      position: relative;
    }
    .text-size-btn {
      font: 700 .78rem/1 'Inter', sans-serif;
      letter-spacing: .02em;
    }
    .contrast-btn:hover,
    .text-size-btn:hover {
      color: var(--teal); background: var(--teal-bg); border-color: rgba(0,95,92,.25);
    }
    .contrast-btn:focus-visible,
    .text-size-btn:focus-visible,
    .drawer-access-btn:focus-visible {
      outline: 3px solid var(--orange);
      outline-offset: 2px;
      border-color: var(--orange);
    }
    /* active (contrast on) state */
    .contrast-btn[aria-pressed="true"],
    .text-size-btn[aria-pressed="true"] {
      background: var(--teal); border-color: var(--teal); color: var(--white);
    }
    /* Tooltip */
    .contrast-btn::after,
    .text-size-btn::after {
      content: attr(data-tooltip);
      position: absolute; top: calc(100% + 6px); right: 0;
      white-space: nowrap; font-size: .72rem; font-weight: 600;
      background: var(--ink); color: var(--white);
      padding: .3rem .7rem; border-radius: 6px;
      opacity: 0; pointer-events: none; transform: translateY(-4px);
      transition: opacity .2s, transform .2s;
    }
    .contrast-btn:hover::after,
    .text-size-btn:hover::after,
    .contrast-btn:focus-visible::after,
    .text-size-btn:focus-visible::after {
      opacity: 1;
      transform: translateY(0);
    }


    /* ═══════════════════════════════════════════
       HIGH CONTRAST MODE  [data-contrast="high"]
       — WCAG AA on dark stone background
    ═══════════════════════════════════════════ */
    [data-contrast="high"] {
      --hc-bg: #211e19;
      --hc-surface: #2c2822;
      --hc-surface-2: #353028;
      --hc-field: #26221d;
      --cream:  #211e19;
      --warm:   #2c2822;
      --white:  #ffffff;
      --ink:    #ffffff;
      --text:   #ffffff;
      --muted:  #ece8df;
      --border: rgba(255,255,255,.36);
      --teal:   #4fe6dd;
      --teal-dk:#35c8c0;
      --teal-bg: rgba(79,230,221,.18);
      --teal-bg2: rgba(79,230,221,.26);
      --orange:  #ffc07a;
      --orange-lt: #ffd9ac;
      --orange-bg: rgba(255,192,122,.2);
      --sh-sm: none; --sh: none; --sh-lg: none;
    }
    [data-contrast="high"] body { background: var(--hc-bg); color: #fff; }

    /* header stays readable */
    [data-contrast="high"] .header-top { background: var(--hc-bg); border-color: rgba(255,255,255,.3); }
    [data-contrast="high"] .header-nav { background: var(--hc-surface-2); border-bottom: 1px solid rgba(255,255,255,.3); }
    [data-contrast="high"] .nav-links a { color: #fff; }
    [data-contrast="high"] .nav-submenu { background: var(--hc-bg); border-color: rgba(255,255,255,.35); }
    [data-contrast="high"] .nav-submenu a { color: #fff; }
    [data-contrast="high"] .nav-submenu a:hover { color: #ffd9ac; }
    [data-contrast="high"] .drawer-submenu { background: var(--hc-surface); }
    [data-contrast="high"] .drawer-submenu-link { color: #fff; border-color: rgba(255,255,255,.25); }
    [data-contrast="high"] .nav-logo img,
    [data-contrast="high"] .drawer-head img { filter: invert(1); }

    /* cards & sections */
    [data-contrast="high"] .ws-card,
    [data-contrast="high"] .nc,
    [data-contrast="high"] .ci-form { background: var(--hc-surface); border: 1px solid rgba(255,255,255,.3); }
    [data-contrast="high"] .ws-card h3,
    [data-contrast="high"] .nc h3 { color: #fff; }
    [data-contrast="high"] .pdn-posts-empty { background: var(--hc-surface); border-color: rgba(255,255,255,.3); }
    [data-contrast="high"] .pdn-posts-pagination .page-numbers {
      background: var(--hc-surface);
      border-color: rgba(255,255,255,.4);
      color: #fff;
      text-decoration: none;
    }
    [data-contrast="high"] .pdn-posts-pagination .page-numbers.current,
    [data-contrast="high"] .pdn-posts-pagination .page-numbers:hover {
      background: #00e8e0;
      border-color: #00e8e0;
      color: #000;
    }
    [data-contrast="high"] .area-card { background: var(--hc-surface); border-color: rgba(255,255,255,.25); }
    [data-contrast="high"] .area-card h3 { color: #fff; }
    [data-contrast="high"] .area-card p  { color: #ccc; }
    [data-contrast="high"] .pill { background: var(--hc-surface); color: #fff; border-color: rgba(255,255,255,.3); }
    [data-contrast="high"] .pill:hover { background: rgba(255,192,122,.22); color: #ffd9ac; }
    [data-contrast="high"] .areas {
      background: var(--hc-bg);
      border-top: 1px solid rgba(255,255,255,.16);
      border-bottom: 1px solid rgba(255,255,255,.16);
    }
    [data-contrast="high"] .areas .sec-head h2 { color: #fff; }
    [data-contrast="high"] .areas .sec-head p { color: #f2ede4; }
    [data-contrast="high"] .areas .sec-head .badge {
      background: rgba(255,192,122,.22);
      color: #ffd9ac;
    }
    [data-contrast="high"] .pdn-areas-rotator {
      --pdn-rotator-surface: var(--hc-surface);
      --pdn-rotator-surface-2: var(--hc-surface-2);
      --pdn-rotator-border: rgba(255,255,255,.36);
      --pdn-rotator-text: #fff;
      --pdn-rotator-muted: #f2ede4;
      background: var(--hc-surface);
      border-color: rgba(255,255,255,.42);
    }
    [data-contrast="high"] .pdn-areas-rotator__accent {
      background: linear-gradient(90deg, #ffb347, #ffd9ac);
    }
    [data-contrast="high"] .pdn-areas-rotator__label,
    [data-contrast="high"] .pdn-areas-rotator__number {
      color: #f2ede4;
    }
    [data-contrast="high"] .pdn-areas-rotator__label::before,
    [data-contrast="high"] .pdn-areas-rotator__bottom {
      border-color: rgba(255,255,255,.35);
    }
    [data-contrast="high"] .pdn-areas-rotator__label::before {
      background: rgba(255,255,255,.55);
    }
    [data-contrast="high"] .pdn-areas-rotator__slide {
      background: transparent;
      border-color: transparent;
    }
    [data-contrast="high"] .pdn-areas-rotator__slide.is-active {
      box-shadow: none;
    }
    [data-contrast="high"] .pdn-areas-rotator__title,
    [data-contrast="high"] .pdn-areas-rotator__desc {
      color: #fff;
    }
    [data-contrast="high"] .pdn-areas-rotator__arrow {
      color: var(--pdn-rotator-accent, #ffb347);
      border-color: var(--pdn-rotator-accent, #ffb347);
    }
    [data-contrast="high"] .pdn-areas-rotator__dot-btn {
      background: rgba(255,255,255,.4);
    }
    [data-contrast="high"] .pdn-areas-rotator__ctrl {
      background: var(--hc-surface);
      border-color: rgba(255,255,255,.45);
      color: #fff;
    }
    [data-contrast="high"] .workshops {
      background: var(--hc-bg);
      border-top: 1px solid rgba(255,255,255,.16);
      border-bottom: 1px solid rgba(255,255,255,.16);
    }
    [data-contrast="high"] .workshops .sec-head h2 { color: #fff; }
    [data-contrast="high"] .workshops .sec-head p { color: #f2ede4; }
    [data-contrast="high"] .workshops .badge {
      background: rgba(255,192,122,.22);
      color: #ffd9ac;
    }
    [data-contrast="high"] .ws-img {
      background: var(--hc-bg);
      border-bottom: 1px solid rgba(255,255,255,.25);
    }
    [data-contrast="high"] .ws-img img {
      filter: invert(1) grayscale(1) contrast(1.18) brightness(.88);
    }
    [data-contrast="high"] .ws-card:hover .ws-img img {
      filter: invert(1) grayscale(1) contrast(1.28) brightness(1);
    }
    [data-contrast="high"] .ws-type,
    [data-contrast="high"] .nc-read {
      color: #ffd9ac;
    }
    [data-contrast="high"] .ws-foot {
      border-color: rgba(255,255,255,.35);
    }
    [data-contrast="high"] .ws-speaker,
    [data-contrast="high"] .ws-body p {
      color: #f2ede4;
    }
    [data-contrast="high"] .ws-av,
    [data-contrast="high"] .ws-arr {
      background: var(--hc-surface-2);
      color: #ffd9ac;
      border: 1px solid rgba(255,255,255,.35);
    }
    [data-contrast="high"] .ws-card:hover .ws-arr {
      background: #ffb347;
      color: #000;
      border-color: #ffb347;
    }
    [data-contrast="high"] footer { background: var(--hc-bg); border-top: 1px solid rgba(255,255,255,.2); }
    [data-contrast="high"] .hero { background: var(--hc-bg); }
    [data-contrast="high"] .marquee { background: #1a1a00; border-top: 1px solid rgba(255,179,71,.4); border-bottom: 1px solid rgba(255,179,71,.4); }
    [data-contrast="high"] .cta-band { background: var(--hc-surface); border: 1px solid rgba(255,192,122,.38); }
    [data-contrast="high"] .news  {
      background: var(--hc-surface);
      border-top: 1px solid rgba(255,255,255,.16);
      border-bottom: 1px solid rgba(255,255,255,.16);
    }
    [data-contrast="high"] .news .sec-head h2 { color: #fff; }
    [data-contrast="high"] .news .sec-head p { color: #f2ede4; }
    [data-contrast="high"] .news .badge {
      background: rgba(79,230,221,.18);
      color: #4fe6dd;
    }
    [data-contrast="high"] .nc-img {
      background: var(--hc-bg);
      border-bottom: 1px solid rgba(255,255,255,.25);
    }
    [data-contrast="high"] .nc-img img {
      filter: invert(1) grayscale(1) contrast(1.18) brightness(.88);
    }
    [data-contrast="high"] .nc:hover .nc-img img {
      filter: invert(1) grayscale(1) contrast(1.28) brightness(1);
    }
    [data-contrast="high"] .nc-meta,
    [data-contrast="high"] .nc-body p {
      color: #f2ede4;
    }
    [data-contrast="high"] .mission { background: var(--hc-bg); }
    [data-contrast="high"] .has-brand-teal-background-color,
    [data-contrast="high"] .has-brand-teal-dark-background-color,
    [data-contrast="high"] .has-brand-teal-light-background-color {
      background-color: var(--hc-surface) !important;
      color: #fff !important;
    }
    [data-contrast="high"] .has-teal-gradient-gradient-background,
    [data-contrast="high"] .has-hero-gradient-gradient-background {
      background: var(--hc-surface) !important;
      color: #fff !important;
    }
    [data-contrast="high"] .ci-icon {
      background: var(--hc-surface-2);
      color: #fff;
      border: 1px solid rgba(255,255,255,.35);
    }
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero {
      background: var(--hc-bg);
    }
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero::before {
      background:
        radial-gradient(ellipse 55% 80% at 85% 50%, rgba(255,192,122,.2) 0%, transparent 60%),
        radial-gradient(ellipse 45% 60% at 5% 80%, rgba(255,255,255,.08) 0%, transparent 55%);
    }
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-title,
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-author,
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-meta time {
      color: #fff;
    }
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-title-accent,
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .eyebrow-text {
      color: #ffd9ac;
    }
    [data-contrast="high"] body.single-post .pdn-page-main .pdn-page-article.pdn-single-post .pdn-single-hero-meta {
      background: var(--hc-surface-2);
      border: 1px solid rgba(255,255,255,.35);
      color: #fff;
    }

    /* links always underlined in high contrast */
    [data-contrast="high"] a { text-decoration: underline; }
    [data-contrast="high"] .btn, [data-contrast="high"] .nav-links a,
    [data-contrast="high"] .area-link, [data-contrast="high"] .nc-read,
    [data-contrast="high"] .news-card-read { text-decoration: none; }
    [data-contrast="high"] .btn-teal  { background: #00e8e0; color: #000; border: 2px solid #00e8e0; }
    [data-contrast="high"] .btn-primary { background: #ffb347; color: #000; border: 2px solid #ffb347; }
    [data-contrast="high"] .btn-outline { color: #00e8e0; border-color: #00e8e0; background: transparent; }
    [data-contrast="high"] .btn-outline-white { color: #fff; border-color: #fff; }
    [data-contrast="high"] .btn-teal,
    [data-contrast="high"] .nav-cta .btn-orange-nav {
      background: #ffb347;
      border-color: #ffb347;
      color: #000;
    }
    [data-contrast="high"] .btn-teal:hover,
    [data-contrast="high"] .nav-cta .btn-orange-nav:hover {
      background: #ffc07a;
      border-color: #ffc07a;
      color: #000;
    }
    [data-contrast="high"] .btn-outline,
    [data-contrast="high"] .btn-outline-white,
    [data-contrast="high"] .nav-cta .btn-ghost-nav {
      background: transparent;
      border-color: rgba(255,255,255,.75);
      color: #fff;
    }
    [data-contrast="high"] .btn-outline:hover,
    [data-contrast="high"] .btn-outline-white:hover,
    [data-contrast="high"] .nav-cta .btn-ghost-nav:hover {
      background: rgba(255,255,255,.12);
      color: #fff;
      border-color: #fff;
    }
    [data-contrast="high"] .ft-brand p,
    [data-contrast="high"] .ft-nl p,
    [data-contrast="high"] .ft-col a,
    [data-contrast="high"] .ft-links a,
    [data-contrast="high"] .ft-bottom span {
      color: #f7f3ec;
    }
    [data-contrast="high"] .ft-col h4 {
      color: #ffd9ac;
    }
    [data-contrast="high"] .ft-col a:hover,
    [data-contrast="high"] .ft-links a:hover {
      color: #fff;
      text-decoration: underline;
      text-underline-offset: .18em;
    }
    [data-contrast="high"] .ft-social a,
    [data-contrast="high"] .ft-social .social-disabled {
      background: var(--hc-surface-2);
      color: #ffd9ac;
      border: 1px solid rgba(255,255,255,.4);
    }
    [data-contrast="high"] .ft-social a:hover {
      background: rgba(255,255,255,.14);
      color: #fff;
    }
    [data-contrast="high"] .ft-nl-row button {
      background: #ffb347;
      color: #000;
      border: 1px solid #ffb347;
    }
    [data-contrast="high"] .ft-nl-row button:hover {
      background: #ffc07a;
      border-color: #ffc07a;
      color: #000;
    }
    [data-contrast="high"] .contrast-btn[aria-pressed="true"],
    [data-contrast="high"] .text-size-btn[aria-pressed="true"],
    [data-contrast="high"] .drawer-access-btn[aria-pressed="true"] {
      background: #ffb347;
      border-color: #ffb347;
      color: #000;
    }
    [data-contrast="high"] .contrast-btn:focus-visible,
    [data-contrast="high"] .text-size-btn:focus-visible,
    [data-contrast="high"] .drawer-access-btn:focus-visible {
      outline-color: #ffb347;
      border-color: #ffb347;
    }
    [data-contrast="high"] .contrast-btn::after,
    [data-contrast="high"] .text-size-btn::after {
      background: var(--hc-bg);
      color: #fff;
      border: 1px solid rgba(255,255,255,.45);
    }

    /* form controls: avoid low-contrast light surfaces in HC mode */
    [data-contrast="high"] input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="reset"]):not([type="file"]):not([type="range"]):not([type="color"]),
    [data-contrast="high"] textarea,
    [data-contrast="high"] select {
      background: var(--hc-field);
      color: #fff;
      border-color: rgba(255,255,255,.55);
    }
    [data-contrast="high"] input::placeholder,
    [data-contrast="high"] textarea::placeholder {
      color: rgba(255,255,255,.72);
    }
    [data-contrast="high"] input:focus,
    [data-contrast="high"] textarea:focus,
    [data-contrast="high"] select:focus {
      border-color: #00e8e0;
      outline: 2px solid #00e8e0;
      outline-offset: 1px;
      box-shadow: none;
    }
    [data-contrast="high"] .ft-nl-row input {
      background: var(--hc-field);
      color: #fff;
      border-color: rgba(255,255,255,.55);
    }
    [data-contrast="high"] .ft-nl-row input::placeholder {
      color: rgba(255,255,255,.72);
    }

    /* image filter: reduce visual noise and color dependence in HC mode */
    [data-contrast="high"] .pdn-page-main :where(
      .hero img,
      .page-hero-img-wrap img,
      .pdn-single-hero .page-hero-img-wrap img,
      .ws-img img,
      .nc-img img,
      .wp-block-image img,
      .wp-block-gallery img,
      .wp-block-cover__image-background,
      .wp-block-post-featured-image img
    ) {
      filter: sepia(.42) saturate(1.2) contrast(1.08) brightness(.99) hue-rotate(-6deg);
    }
    [data-contrast="high"] .pdn-page-main :where(
      .partners-logos img,
      .wspolpracujemy-scroll img,
      .intro-logo-strip img,
      .ft-brand img
    ) {
      filter: none;
    }
