/* =====================================================================
   DMG — Deutsch-Mosambikanische Gesellschaft e.V.
   Modern / futuristic redesign — design system  (v2)
   Brand: A #5F231E maroon · B #D45620 orange · C #BDAE78 tan · D #F2EFE4 cream
   ===================================================================== */

/* ---------- Fonts: futuristic display online, Roboto offline fallback ---------- */
@font-face{
  font-family:"Roboto";font-style:normal;font-weight:300 600;font-display:swap;
  src:url("../fonts/roboto/v51/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMW36eA1Ef.woff2") format("woff2");
}
@font-face{
  font-family:"Merriweather";font-style:normal;font-weight:400 700;font-display:swap;
  src:url("../fonts/merriweather/v33/u-4D0qyriQwlOrhSvowK_l5UcA6zuSYEqOzpPe3HOZJ5eX1WtLaQwmYiScCmDxhtNOKl8yDrOSAqEFf0KvTCYQ.woff") format("woff");
}

:root{
  --maroon:#5F231E;
  --maroon-2:#732c25;
  --maroon-dark:#41160f;
  --orange:#D45620;
  --orange-2:#e96a2c;
  --orange-dark:#b1430f;
  --tan:#BDAE78;
  --tan-2:#d4c79a;
  --cream:#F2EFE4;
  --cream-2:#FBF9F3;
  --green:#6f9c76;
  --ink:#241a18;
  --muted:#766a64;
  --line:#e9e2d4;
  --white:#fff;

  /* display = futuristic when available, graceful fallbacks */
  --display:"Space Grotesk","Sora",-apple-system,"Segoe UI",Roboto,system-ui,sans-serif;
  --sans:"Inter","Roboto",system-ui,-apple-system,"Segoe UI",sans-serif;

  --maxw:1240px;
  --radius:20px;
  --radius-sm:12px;
  --radius-lg:30px;
  --shadow-sm:0 2px 12px rgba(65,22,15,.06);
  --shadow:0 14px 40px rgba(65,22,15,.12);
  --shadow-lg:0 30px 70px rgba(65,22,15,.20);
  --ease:cubic-bezier(.22,.61,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --header-h:88px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);font-weight:400;color:var(--ink);
  background:var(--white);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;position:relative;
}
img{max-width:100%;display:block}
a{color:var(--orange);text-decoration:none;transition:color .25s var(--ease)}
a:hover{color:var(--orange-dark)}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;color:var(--maroon);margin:0 0 .5em;letter-spacing:-.02em}
p{margin:0 0 1.1em}
ul{margin:0 0 1.1em;padding-left:1.2em}
small{font-size:.82rem}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0}
::selection{background:var(--orange);color:#fff}
:focus-visible{outline:3px solid var(--orange);outline-offset:2px;border-radius:4px}

/* ---------- Drifting background shapes ---------- */
.bg-shapes{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.bg-shapes span{position:absolute;border-radius:50%;filter:blur(8px);opacity:.07;
  background:radial-gradient(circle at 30% 30%,var(--c1),transparent 70%);will-change:transform}
.bg-shapes span:nth-child(1){--c1:var(--orange);width:520px;height:520px;left:-6%;top:8%;animation:drift1 26s var(--ease) infinite alternate}
.bg-shapes span:nth-child(2){--c1:var(--maroon);width:620px;height:620px;right:-10%;top:32%;opacity:.06;animation:drift2 32s var(--ease) infinite alternate}
.bg-shapes span:nth-child(3){--c1:var(--tan);width:440px;height:440px;left:18%;top:68%;opacity:.10;animation:drift3 24s var(--ease) infinite alternate}
.bg-shapes span:nth-child(4){--c1:var(--green);width:360px;height:360px;right:14%;top:82%;opacity:.07;animation:drift1 30s var(--ease) infinite alternate-reverse}
.bg-shapes span:nth-child(5){--c1:var(--orange);width:300px;height:300px;left:46%;top:46%;opacity:.05;animation:drift2 28s var(--ease) infinite alternate}
@keyframes drift1{to{transform:translate(80px,60px) scale(1.15)}}
@keyframes drift2{to{transform:translate(-70px,90px) scale(1.1)}}
@keyframes drift3{to{transform:translate(60px,-70px) scale(1.2)}}

/* ---------- Typography helpers ---------- */
.ff-serif{font-family:var(--display)}            /* legacy serif -> clean display */
.ff-base{font-family:var(--sans)}
.ff-cursive{font-family:var(--display)!important;font-weight:700!important;letter-spacing:-.02em} /* kill handwriting everywhere */

.fs-1{font-size:clamp(2.3rem,1.4rem + 3.6vw,4rem);margin:0 0 .25em;letter-spacing:-.03em}
.fs-2{font-size:clamp(1.55rem,1.05rem + 2vw,2.5rem)}
.fs-3{font-size:clamp(1.12rem,.95rem + .7vw,1.45rem);line-height:1.3}

.eyebrow,.kicker{display:inline-block;font-family:var(--sans);font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.18em;color:var(--orange);margin:0 0 .6rem}
.eyebrow.on-dark,.kicker.on-dark{color:var(--tan-2)}

/* ---------- Brand color helpers ---------- */
.text-brand-color-A{color:var(--maroon)!important}
.text-brand-color-B{color:var(--orange)!important}
.text-brand-color-C{color:var(--tan)!important}
.text-brand-color-D{color:var(--cream)!important}
.bg-brand-color-A{background-color:var(--maroon)}
.bg-brand-color-B{background-color:var(--orange)}
.bg-brand-color-C{background-color:var(--tan)}
.bg-brand-color-D{background-color:var(--cream)}
.text-white{color:#fff!important}.text-dark{color:var(--ink)!important}.text-muted{color:var(--muted)!important}
.fw-bold{font-weight:700!important}
.text-uppercase{text-transform:uppercase;letter-spacing:.08em}
.text-center{text-align:center}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(22px,5vw,40px)}
.container-wide{max-width:1420px}
.section{padding:clamp(56px,7vw,104px) 0;position:relative}
.section-sm{padding:54px 0;position:relative}
.bg-cream{background:var(--cream)}
.bg-cream-soft{background:var(--cream-2)}
.bg-maroon{background:linear-gradient(150deg,var(--maroon),var(--maroon-dark));color:#fff}
.bg-maroon h1,.bg-maroon h2,.bg-maroon h3{color:#fff}

/* spacing utilities (legacy) */
.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}
.mb-3{margin-bottom:1rem!important}.mb-4{margin-bottom:1.75rem!important}
.mb-5{margin-bottom:3rem!important}.mt-4{margin-top:1.75rem!important}
.pb-2{padding-bottom:.5rem!important}.pb-5{padding-bottom:3rem!important}
.py-5{padding-top:3rem!important;padding-bottom:3rem!important}
.mt-auto{margin-top:auto!important}.ms-auto{margin-left:auto!important}
.me-2{margin-right:.5rem!important}.me-3{margin-right:1rem!important}.mb-sm-0{margin-bottom:0!important}
.d-flex{display:flex}.flex-column{flex-direction:column}.h-100{height:100%}

/* ---------- Grid (legacy bootstrap-ish, modernised) ---------- */
.row{display:flex;flex-wrap:wrap;margin-inline:-16px}
.row>[class*="col"]{padding-inline:16px;width:100%;min-width:0}
.col{flex:1 0 0%}
.row-cols-1>*{flex:0 0 100%;max-width:100%}
@media(min-width:576px){.flex-sm-row{flex-direction:row}
  .col-sm-4{flex:0 0 33.333%;max-width:33.333%}.col-sm-5{flex:0 0 41.666%;max-width:41.666%}.col-sm-7{flex:0 0 58.333%;max-width:58.333%}}
@media(min-width:768px){.col-md-4{flex:0 0 33.333%;max-width:33.333%}.col-md-8{flex:0 0 66.667%;max-width:66.667%}
  .row-cols-md-2>*{flex:0 0 50%;max-width:50%}.flex-sm-row{flex-direction:row}.mt-md-auto{margin-top:auto!important}}
@media(min-width:992px){.col-lg-2{flex:0 0 16.666%;max-width:16.666%}.col-lg-6{flex:0 0 50%;max-width:50%}
  .row-cols-lg-3>*{flex:0 0 33.333%;max-width:33.333%}}
.img-fluid{width:100%;height:auto;border-radius:var(--radius-sm)}

/* ---------- Buttons ---------- */
.btn,.btn-brand-color-A,.btn-brand-color-B,.btn-brand-color-C,.btn-brand-color-D{
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:var(--sans);font-weight:600;font-size:1rem;line-height:1;
  padding:.9em 1.6em;border:0;border-radius:999px;cursor:pointer;text-decoration:none;
  transition:transform .35s var(--spring),box-shadow .35s var(--ease),background-color .3s var(--ease);white-space:nowrap;
}
.btn::after,.btn-brand-color-A::after,.btn-brand-color-B::after,.btn-brand-color-C::after{content:"\2192";transition:transform .3s var(--ease)}
.btn:hover::after,.btn-brand-color-A:hover::after,.btn-brand-color-B:hover::after,.btn-brand-color-C:hover::after{transform:translateX(4px)}
.btn-brand-color-A,.btn-primary{background:var(--maroon);color:#fff}
.btn-brand-color-A:hover,.btn-primary:hover{background:var(--maroon-2);color:#fff;box-shadow:var(--shadow);transform:translateY(-3px)}
.btn-brand-color-B,.btn-cta{background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;box-shadow:0 6px 18px rgba(212,86,32,.3)}
.btn-brand-color-B:hover,.btn-cta:hover{color:#fff;box-shadow:0 14px 30px rgba(212,86,32,.45);transform:translateY(-3px)}
.btn-brand-color-C{background:var(--tan);color:var(--maroon-dark)}
.btn-brand-color-C:hover{background:var(--tan-2);color:var(--maroon-dark);transform:translateY(-3px)}
.btn-outline{background:transparent;color:var(--maroon);box-shadow:inset 0 0 0 2px var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:#fff;transform:translateY(-3px)}
.btn-ghost-light{background:rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(8px);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55)}
.btn-ghost-light:hover{background:#fff;color:var(--maroon)}
.btn-lg{font-size:1.08rem;padding:1.05em 2em}

/* ---------- Cards ---------- */
.card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .45s var(--ease),box-shadow .45s var(--ease);height:100%}
.card.border-0{border:0}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card>img,.card .card-img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:0}
.card-body{padding:1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.card h2,.card h3{color:var(--maroon)}
.content-block{color:var(--ink)}
.content-block p:last-child{margin-bottom:0}

/* dashed-border list rows (section landing items) -> elevated cards */
.dashed-border{display:flex;flex-direction:column;gap:.4rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:1.6rem 1.7rem;margin-bottom:1.25rem!important;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);position:relative;overflow:hidden}
.dashed-border::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(var(--orange),var(--orange-2));transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.dashed-border:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.dashed-border:hover::before{transform:scaleY(1)}
.dashed-border h2{margin:0}
.dashed-border h2 .fs-2{display:block;margin-top:.15rem;color:var(--maroon)}
.dashed-border small{color:var(--orange);font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;font-weight:600}
@media(min-width:576px){.dashed-border{flex-direction:row;align-items:center;gap:1.5rem}.dashed-border>div:last-child{flex-shrink:0}}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--maroon-dark);color:#fff;font-size:.85rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:42px}
.topbar .tb-left,.topbar .tb-right{display:flex;align-items:center;gap:1.4rem}
.topbar a{color:#fff;display:inline-flex;align-items:center;gap:.4rem;opacity:.88}
.topbar a:hover{opacity:1;color:var(--tan-2)}

/* ---------- Language switcher ---------- */
.langswitch{display:inline-flex;gap:2px;background:rgba(255,255,255,.12);border-radius:999px;padding:3px}
.langswitch a{padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:700;letter-spacing:.06em;color:rgba(255,255,255,.8);opacity:1}
.langswitch a:hover{color:#fff;background:rgba(255,255,255,.12)}
.langswitch a.active{background:var(--orange);color:#fff}
.lang-mini{display:none}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.9);backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid var(--line);transition:box-shadow .3s var(--ease),background .3s var(--ease)}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(255,255,255,.96)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:1.5rem}
.brand img{height:50px;width:auto;border-radius:0}
.main-nav{display:flex;align-items:center;gap:.2rem;list-style:none;margin:0;padding:0}
.main-nav>li{position:relative}
.main-nav>li>a{display:flex;align-items:center;gap:.3rem;padding:.6rem .8rem;border-radius:999px;font-weight:500;color:var(--maroon);font-size:.95rem}
.main-nav>li>a:hover,.main-nav>li.active>a{background:var(--cream);color:var(--maroon)}
.main-nav>li.has-children>a::after{content:"";width:.42em;height:.42em;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .25s var(--ease)}
.main-nav>li.has-children:hover>a::after{transform:rotate(-135deg)}
.dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:270px;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(12px);
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;z-index:50}
.main-nav>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:.6rem .85rem;border-radius:10px;color:var(--ink);font-size:.92rem;font-weight:500}
.dropdown a:hover{background:var(--cream);color:var(--orange);padding-left:1.05rem}
.dropdown .dd-head{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--orange);padding:.5rem .85rem .2rem;font-weight:700}
.nav-cta{display:flex;align-items:center;gap:.7rem}
.menu-toggle{display:none;flex-direction:column;gap:5px;width:46px;height:46px;border:0;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle span{width:26px;height:2.5px;background:var(--maroon);border-radius:2px;transition:.3s var(--ease)}
body.nav-open .menu-toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.nav-open .menu-toggle span:nth-child(2){opacity:0}
body.nav-open .menu-toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Mobile nav ---------- */
.mobile-panel{position:fixed;inset:0 0 0 auto;width:min(440px,88vw);background:#fff;z-index:1200;transform:translateX(100%);
  transition:transform .42s var(--ease);overflow-y:auto;box-shadow:var(--shadow-lg);padding:96px 24px 40px}
body.nav-open .mobile-panel{transform:translateX(0)}
.nav-overlay{position:fixed;inset:0;background:rgba(36,26,24,.55);opacity:0;visibility:hidden;transition:.4s var(--ease);z-index:1100}
body.nav-open .nav-overlay{opacity:1;visibility:visible}
.mobile-panel .m-group{border-bottom:1px solid var(--line)}
.mobile-panel .m-top{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:0;
  font-family:var(--display);font-size:1.05rem;font-weight:600;color:var(--maroon);padding:.95rem 0;cursor:pointer;text-align:left}
.mobile-panel .m-top.solo{display:block}
.mobile-panel .m-top .chev{width:.5em;height:.5em;border-right:2px solid var(--orange);border-bottom:2px solid var(--orange);transform:rotate(45deg);transition:.3s var(--ease)}
.mobile-panel .m-group.open .m-top .chev{transform:rotate(-135deg)}
.mobile-panel .m-sub{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.mobile-panel .m-sub a{display:block;padding:.55rem 0 .55rem 1rem;color:var(--ink);font-weight:500;border-left:2px solid var(--cream)}
.mobile-panel .m-sub a:hover{color:var(--orange);border-color:var(--orange)}
.mobile-panel .btn-cta{width:100%;margin-top:1.5rem}
.mobile-panel .lang-mini{display:flex;justify-content:center;margin-top:1.4rem}
.mobile-panel .langswitch{background:var(--cream)}
.mobile-panel .langswitch a{color:var(--maroon)}
.mobile-panel .langswitch a.active{color:#fff}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:min(88vh,760px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%;border-radius:0;transform:scale(1.12);animation:heroZoom 22s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(65,22,15,.92) 0%,rgba(95,35,30,.68) 42%,rgba(95,35,30,.2) 100%)}
.hero .container{position:relative;z-index:2}
.hero .eyebrow{color:var(--tan-2)}
.hero h1{color:#fff;font-size:clamp(2.3rem,1.2rem + 4.4vw,4.4rem);max-width:16ch;margin:.1em 0 .5em;letter-spacing:-.03em}
.hero p{max-width:55ch;font-size:clamp(1.05rem,1rem + .4vw,1.25rem);color:rgba(255,255,255,.92)}
.hero .hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.hero .border-strip{position:absolute;left:0;right:0;bottom:0;height:42px;z-index:3;background:url("../img/site/border-pattern.svg") repeat-x center/contain}
.hero .scroll-hint{position:absolute;left:50%;bottom:60px;z-index:3;width:26px;height:42px;border:2px solid rgba(255,255,255,.5);border-radius:14px;transform:translateX(-50%)}
.hero .scroll-hint::before{content:"";position:absolute;left:50%;top:8px;width:4px;height:8px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:scrollDot 1.8s var(--ease) infinite}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,14px)}}

/* ---------- Section head ---------- */
.sec-head{max-width:780px;margin:0 auto 3rem;text-align:center}
.sec-head h2{font-size:clamp(1.9rem,1.2rem + 2.4vw,2.9rem)}
.sec-head p{color:var(--muted);font-size:1.08rem;margin-bottom:0}
.sec-head.left{margin-left:0;margin-right:auto;text-align:left}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;color:#fff;overflow:hidden}
.page-hero .ph-bg{position:absolute;inset:0;z-index:0}
.page-hero .ph-bg img{width:100%;height:100%;object-fit:cover;border-radius:0;transform:scale(1.06);animation:heroZoom 14s var(--ease) forwards}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(65,22,15,.93),rgba(95,35,30,.55));z-index:1}
.page-hero .container{position:relative;z-index:2;padding-top:clamp(58px,8vw,96px);padding-bottom:clamp(58px,8vw,96px)}
.page-hero .crumbs{font-size:.82rem;color:rgba(255,255,255,.78);margin-bottom:1rem;letter-spacing:.02em}
.page-hero .crumbs a{color:rgba(255,255,255,.78)}.page-hero .crumbs a:hover{color:#fff}
.page-hero .eyebrow{color:var(--tan-2)}
.page-hero h1{color:#fff;margin:.1em 0 .3em;font-size:clamp(2.1rem,1.3rem + 3.4vw,3.4rem)}
.page-hero .lead{color:rgba(255,255,255,.92);font-size:clamp(1.05rem,1rem + .4vw,1.25rem);max-width:62ch;margin:0}

/* ---------- Sub navigation pills ---------- */
.subnav{position:sticky;top:var(--header-h);z-index:900;background:rgba(251,249,243,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.subnav .container{display:flex;gap:.5rem;flex-wrap:wrap;padding-block:.7rem}
.subnav a{padding:.5rem 1.1rem;border-radius:999px;font-size:.9rem;font-weight:600;color:var(--maroon);border:1px solid var(--line);background:#fff;transition:.25s var(--ease)}
.subnav a:hover{border-color:var(--orange);color:var(--orange)}
.subnav a.active{background:var(--maroon);color:#fff;border-color:var(--maroon)}

/* ---------- Stats / counters ---------- */
.stats{background:linear-gradient(140deg,var(--maroon),var(--maroon-dark));color:#fff;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background:url("../img/site/border-pattern.svg") repeat-x bottom/contain;opacity:.08}
.stats .stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center;position:relative}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,1.5rem + 3vw,4rem);color:var(--tan-2);line-height:1;letter-spacing:-.03em}
.stat .num .suffix{color:var(--orange-2)}
.stat .lbl{font-size:1rem;color:rgba(255,255,255,.85);margin-top:.5rem}
@media(max-width:768px){.stats .stat-grid{grid-template-columns:repeat(2,1fr);gap:2.2rem}}

/* ---------- Feature cards grid ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.6rem}
.feature{position:relative;border-radius:var(--radius);overflow:hidden;min-height:360px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);z-index:0;border-radius:0}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(36,18,15,.94),rgba(36,18,15,.1) 72%);z-index:1}
.feature .feature-body{position:relative;z-index:2;padding:1.7rem}
.feature h3{color:#fff;margin:0 0 .3rem;font-size:1.4rem}
.feature p{margin:0;color:rgba(255,255,255,.85);font-size:.95rem}
.feature .tag{color:var(--tan-2);font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;font-weight:700;display:block;margin-bottom:.5rem}
.feature:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.feature:hover img{transform:scale(1.09)}
.feature .arrow{position:absolute;top:1.4rem;right:1.4rem;z-index:2;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);display:grid;place-items:center;transition:.4s var(--spring)}
.feature:hover .arrow{background:var(--orange);transform:rotate(-45deg) scale(1.1)}

/* ---------- Map ---------- */
.map-section{background:var(--cream);position:relative;overflow:hidden}
.map-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.map-figure{position:relative}
.map-figure svg{width:100%;height:auto;max-height:640px;display:block;filter:drop-shadow(0 16px 36px rgba(65,22,15,.16))}
.map-figure svg path{transition:fill .3s var(--ease);cursor:default}
.map-figure svg path[data-active="1"]{cursor:pointer}
.map-info h3{margin:.2rem 0 .7rem;color:var(--orange)}
.map-info .prov-name{font-family:var(--display);color:var(--maroon);font-size:clamp(1.8rem,1.2rem + 1.8vw,2.6rem);line-height:1.05;display:block;min-height:1em;font-weight:700;letter-spacing:-.02em}
.map-legend{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.4rem;font-size:.9rem;color:var(--muted)}
.map-legend span{display:inline-flex;align-items:center;gap:.5rem}
.map-legend i{width:16px;height:16px;border-radius:5px;display:inline-block}
.prov-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.prov-chip{font-size:.82rem;padding:.4rem .9rem;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--maroon);cursor:pointer;transition:.25s var(--ease);font-weight:600}
.prov-chip:hover,.prov-chip.active{background:var(--orange);color:#fff;border-color:var(--orange)}
@media(max-width:900px){.map-layout{grid-template-columns:1fr;gap:1.8rem}.map-figure svg{max-height:460px}}

/* ---------- News cards (collapsible) ---------- */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.7rem}
.news-card{cursor:default}
.news-card .meta{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--orange);font-weight:700}
.news-card h3{font-size:1.22rem;margin:.45rem 0 .55rem;color:var(--maroon)}
.news-card .news-teaser{color:var(--ink)}
.news-card .news-full{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);color:var(--ink)}
.news-card.open .news-full{max-height:600px}
.news-toggle{margin-top:.9rem;align-self:flex-start;background:none;border:0;color:var(--orange);font-weight:700;font-family:var(--sans);cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem}
.news-toggle .ico{width:.5em;height:.5em;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .3s var(--ease)}
.news-card.open .news-toggle .ico{transform:rotate(-135deg)}
.news-card .news-link{margin-top:.9rem;font-weight:700;color:var(--orange);align-self:flex-start}

/* ---------- Partners ---------- */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.4rem;align-items:stretch}
.partner-grid .p-cell{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);display:grid;place-items:center;
  padding:1.4rem;min-height:120px;transition:.35s var(--ease)}
.partner-grid .p-cell:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.partner-grid img{max-height:66px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.6;transition:.35s var(--ease)}
.partner-grid .p-cell:hover img{filter:grayscale(0);opacity:1}

/* ---------- Donation form ---------- */
.donate-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.donate-pitch .eyebrow{color:var(--orange)}
.donate-pitch h2{font-size:clamp(1.9rem,1.3rem + 2vw,2.9rem)}
.donate-pitch blockquote{border-left:4px solid var(--orange);margin:1.5rem 0;padding:.4rem 0 .4rem 1.3rem;font-family:var(--display);font-size:1.2rem;color:var(--maroon);font-style:normal}
.donate-points{list-style:none;padding:0;margin:1.4rem 0 0}
.donate-points li{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:.9rem}
.donate-points li::before{content:"\2713";flex:none;width:26px;height:26px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700;margin-top:2px}
.donate-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:clamp(1.6rem,3vw,2.6rem);position:relative;overflow:hidden}
.donate-card::before{content:"";position:absolute;right:-50px;top:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(212,86,32,.12),transparent 70%)}
.donate-steps{display:flex;gap:.5rem;margin-bottom:1.8rem;position:relative}
.donate-steps .dot{flex:1;height:5px;border-radius:3px;background:var(--line);transition:.4s var(--ease)}
.donate-steps .dot.active{background:var(--orange)}
.donate-step{display:none;animation:fadeStep .4s var(--ease)}
.donate-step.active{display:block}
@keyframes fadeStep{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.donate-card label.fld{display:block;font-weight:600;color:var(--maroon);margin:0 0 .5rem;font-size:.92rem}
.donate-card .step-title{font-family:var(--display);font-weight:700;color:var(--maroon);font-size:1.25rem;margin-bottom:1.1rem}
.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-bottom:1rem}
.amount-opt{position:relative}
.amount-opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.amount-opt span{display:block;text-align:center;padding:.9rem .4rem;border:2px solid var(--line);border-radius:14px;font-weight:700;color:var(--maroon);font-family:var(--display);font-size:1.15rem;transition:.25s var(--ease);cursor:pointer}
.amount-opt input:checked + span{border-color:var(--orange);background:rgba(212,86,32,.08);color:var(--orange)}
.toggle-row{display:flex;gap:.7rem;margin-bottom:1.2rem}
.toggle-row .seg{flex:1}
.toggle-row .seg input{position:absolute;opacity:0}
.toggle-row .seg label{display:block;text-align:center;padding:.8rem;border:2px solid var(--line);border-radius:14px;font-weight:600;color:var(--maroon);cursor:pointer;transition:.25s var(--ease)}
.toggle-row .seg input:checked + label{border-color:var(--orange);background:rgba(212,86,32,.08);color:var(--orange)}
.field{width:100%;padding:.9rem 1.1rem;border:2px solid var(--line);border-radius:14px;font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--cream-2);transition:.25s var(--ease);margin-bottom:1.1rem}
.field:focus{outline:none;border-color:var(--orange);background:#fff}
.input-prefix{position:relative}
.input-prefix span{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:700}
.input-prefix .field{padding-left:2.2rem}
.purpose-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:1rem}
.purpose-opt input{position:absolute;opacity:0}
.purpose-opt{position:relative;display:block}
.purpose-opt span{display:block;padding:.85rem 1rem;border:2px solid var(--line);border-radius:14px;font-weight:600;color:var(--maroon);cursor:pointer;font-size:.92rem;transition:.25s var(--ease)}
.purpose-opt input:checked + span{border-color:var(--orange);background:rgba(212,86,32,.08);color:var(--orange)}
.donate-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:.6rem}
.purpose-fixed{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.1rem;border:2px solid var(--orange);background:rgba(212,86,32,.07);border-radius:14px;margin-bottom:1rem}
.purpose-fixed[hidden]{display:none}
.purpose-fixed .pf-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--orange);font-weight:700}
.purpose-fixed strong{color:var(--maroon);font-family:var(--display);font-size:1.05rem}
.anon-check{display:flex;align-items:center;gap:.6rem;margin:.85rem 0 .2rem;cursor:pointer;font-size:.92rem;color:var(--maroon);font-weight:600}
.anon-check input{width:18px;height:18px;accent-color:var(--orange);cursor:pointer;flex:0 0 auto}
.field.is-disabled{opacity:.5;background:rgba(0,0,0,.03);cursor:not-allowed}
.fld-hint{color:#777;font-size:.82rem;margin:.4rem 0 .2rem}
.fld-err{color:#b3261e;font-size:.86rem;font-weight:600;margin:.45rem 0 .2rem}
.field.is-invalid,input.is-invalid{border-color:#b3261e!important;background:rgba(179,38,30,.05)}
.donate-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.2rem;background:rgba(41,22,15,.55);backdrop-filter:blur(3px);animation:fadeIn .25s var(--ease)}
.donate-modal[hidden]{display:none}
.donate-modal-card{background:#fff;border-radius:20px;max-width:440px;width:100%;padding:2rem 1.8rem;box-shadow:var(--shadow);text-align:center;animation:pop .35s var(--spring)}
.donate-modal-card .dm-icon{font-size:2.4rem;margin-bottom:.4rem}
.donate-modal-card h3{color:var(--maroon);font-family:var(--display);margin:.2rem 0 .6rem;font-size:1.35rem}
.donate-modal-card p{color:#555;font-size:.96rem;line-height:1.55;margin:0 0 1.1rem}
.donate-modal-card .dm-field{margin-bottom:1.1rem;text-align:left}
.donate-modal-card .dm-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.donate-thanks{text-align:center;padding:1rem 0}
.donate-thanks .check{width:74px;height:74px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-size:2rem;margin:0 auto 1.2rem;animation:pop .5s var(--spring)}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.donate-thanks .iban-box{background:var(--cream);border:1px dashed var(--tan);border-radius:14px;padding:1.2rem;text-align:left;margin-top:1.3rem;font-family:var(--display)}
@media(max-width:860px){.donate-wrap{grid-template-columns:1fr;gap:2rem}}

/* ---------- Donation callout band ---------- */
.donate-band{position:relative;background:linear-gradient(125deg,var(--orange),#9c3a0c);color:#fff;border-radius:var(--radius-lg);padding:clamp(2rem,4vw,3.4rem);overflow:hidden}
.donate-band::before{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.08)}
.donate-band::after{content:"";position:absolute;left:-40px;bottom:-80px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.06)}
.donate-band h2{color:#fff}
.donate-band .iban{font-family:var(--display);background:rgba(255,255,255,.15);border-radius:14px;padding:1.1rem 1.3rem;display:inline-block;margin-top:1rem}

/* ---------- Article / detail ---------- */
.article-body img{border-radius:var(--radius);margin:1.5rem 0;box-shadow:var(--shadow-sm)}
.prose.article-wrap{max-width:1080px;overflow-x:clip}
.prose .row{align-items:flex-start}
/* nested scraped containers must not re-pad nor overflow the article gutter */
.prose .container{padding-inline:0;max-width:100%;overflow-x:clip}
/* keep flowing body text to a comfortable reading measure */
.prose>p,.prose .content-block>p,.prose>ul,.prose>ol,.prose>h2,.prose>h3,.prose>h4{max-width:72ch}
.prose img{border-radius:var(--radius-sm)}
.prose .card{background:var(--cream-2)}
.gallery-grid img:hover{transform:scale(1.03)}

/* ---------- Footer ---------- */
.site-footer{background:var(--maroon);color:rgba(255,255,255,.82);position:relative}
.footer-strip{height:42px;background:url("../img/site/border-pattern.svg") repeat-x center/contain}
.footer-main{padding:70px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.4rem}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:1.1rem}
.site-footer a{color:rgba(255,255,255,.82)}.site-footer a:hover{color:var(--tan-2)}
.footer-links{list-style:none;padding:0;margin:0;line-height:2}
.footer-logo{height:56px;margin-bottom:1.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);padding:18px 0;font-size:.85rem;color:rgba(255,255,255,.6)}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-bottom a{color:rgba(255,255,255,.7)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.09s}.reveal.d2{transition-delay:.18s}.reveal.d3{transition-delay:.27s}.reveal.d4{transition-delay:.36s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-bg img,.page-hero .ph-bg img{animation:none;transform:none}
  .bg-shapes{display:none}
  *{scroll-behavior:auto!important}
}

/* ---------- Responsive nav switch ---------- */
@media(max-width:1140px){
  .main-nav,.nav-cta .btn-cta{display:none}
  .menu-toggle{display:flex}
  :root{--header-h:74px}
  .topbar .langswitch{display:none}
}
@media(max-width:768px){
  body{font-size:16px}
  .topbar .tb-left a:not(:first-child){display:none}
}
.fas{font-style:normal}

/* =====================================================================
   v3 — Robust identity overhaul  (overrides above; distinctive signature)
   ===================================================================== */

/* Bigger, tighter, more confident type scale */
.fs-1{font-size:clamp(2.7rem,1.4rem + 5vw,5rem);letter-spacing:-.045em;line-height:1.02}
.hero h1{font-size:clamp(2.7rem,1.2rem + 6vw,5.4rem);letter-spacing:-.045em;line-height:1}
.sec-head h2{font-size:clamp(2.1rem,1.2rem + 3vw,3.4rem);letter-spacing:-.035em}

/* Signature eyebrow: leading accent bar instead of plain caps */
.eyebrow,.kicker{position:relative;padding-left:34px;letter-spacing:.22em;font-size:.74rem}
.eyebrow::before,.kicker::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:24px;height:2px;background:linear-gradient(90deg,var(--orange),var(--orange-2));border-radius:2px}
.eyebrow.on-dark::before,.hero .eyebrow::before,.page-hero .eyebrow::before{background:var(--tan-2)}

/* Gradient-clipped accent on key display headings (light backgrounds only) */
.sec-head h2,.donate-pitch h2,.map-info .prov-name{
  background:linear-gradient(120deg,var(--maroon) 0%,var(--maroon) 55%,var(--orange) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}

/* Section heads default to bold left-aligned, asymmetric rhythm */
.sec-head{max-width:880px}
.sec-head.left{max-width:760px}

/* Distinctive accent rule under each major section's heading */
.sec-head::after{content:"";display:block;width:64px;height:4px;border-radius:3px;
  margin:1.1rem auto 0;background:linear-gradient(90deg,var(--orange),var(--orange-2))}
.sec-head.left::after{margin-left:0}

/* Cards: sharper, with a reveal-on-hover top accent */
.card{border-radius:var(--radius-sm)}
.card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;z-index:3;
  background:linear-gradient(90deg,var(--orange),var(--orange-2));transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease)}
.card{position:relative}
.card:hover::before{transform:scaleX(1)}

/* Feature tiles: stronger, more architectural */
.feature{border-radius:var(--radius-sm);min-height:400px}
.feature h3{font-size:1.55rem;letter-spacing:-.02em}

/* Stat numbers: more dramatic, with accent baseline */
.stat .num{font-size:clamp(3rem,1.6rem + 4vw,4.8rem)}
.stat{position:relative;padding:.4rem 0}

/* Buttons: slightly squarer = more contemporary, keep motion */
.btn,.btn-brand-color-A,.btn-brand-color-B,.btn-brand-color-C,.btn-brand-color-D{
  border-radius:14px;letter-spacing:.01em;padding:1em 1.7em}
.btn-lg{padding:1.15em 2.1em;font-size:1.1rem}

/* Section rhythm: more generous breathing room, alternating tint depth */
.section{padding:clamp(72px,9vw,140px) 0}

/* Page hero: taller, more cinematic, stronger headline */
.page-hero h1{font-size:clamp(2.4rem,1.3rem + 4.4vw,4rem);letter-spacing:-.04em}
.page-hero .container{padding-top:clamp(80px,10vw,140px);padding-bottom:clamp(80px,10vw,140px)}

/* Subnav: pill rail with clearer active state */
.subnav a{border-radius:12px}

/* Mobile: keep everything well inside the frame */
@media(max-width:768px){
  .sec-head{text-align:left}
  .sec-head::after{margin-left:0}
  .hero h1{font-size:clamp(2.3rem,1rem + 8vw,3.4rem)}
}

/* =====================================================================
   v3.1 — Living footer, people cards, panels, partners, map, heros
   ===================================================================== */

/* ---- Remove the scroll-hint over the hero (per request) ---- */
.hero .scroll-hint{display:none!important}

/* ---- Pre-footer CTA band with living gradient ---- */
.footer-cta{position:relative;overflow:hidden;text-align:center;color:#fff;
  padding:clamp(3.4rem,6vw,5.6rem) 0;
  background:linear-gradient(120deg,var(--maroon-dark),var(--maroon) 35%,var(--orange-dark) 65%,var(--maroon));
  background-size:320% 320%;animation:liveGrad 18s ease infinite}
@keyframes liveGrad{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.footer-cta::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(255,255,255,.10),transparent 55%);pointer-events:none}
.footer-cta-inner{position:relative;z-index:2;max-width:780px}
.footer-cta .eyebrow.on-dark{color:var(--tan-2)}
.footer-cta h2{color:#fff;font-size:clamp(2.1rem,1.2rem + 3.2vw,3.4rem);letter-spacing:-.035em;margin:.3rem 0 .6rem}
.footer-cta p{color:rgba(255,255,255,.86);margin:0 auto 2rem;max-width:50ch}
.footer-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- Living gradient footer, centered ---- */
.site-footer{background:linear-gradient(160deg,var(--maroon),var(--maroon-dark) 62%,#350f0a);position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 18% 0%,rgba(212,86,32,.20),transparent 46%),
            radial-gradient(circle at 88% 120%,rgba(189,174,120,.16),transparent 50%)}
.footer-main{padding:clamp(56px,7vw,86px) 0 44px;position:relative;z-index:2}
.footer-grid{grid-template-columns:repeat(4,1fr);gap:2.6rem;text-align:left;justify-items:start;align-items:start}
.footer-brand{max-width:360px}
.footer-logo{height:58px;margin:0 0 1.2rem;display:block}
.footer-links{text-align:left}
.footer-iban{margin-top:1.3rem;border:1px solid rgba(255,255,255,.18);border-radius:14px;
  padding:1rem 1.2rem;font-size:.88rem;line-height:1.8;background:rgba(0,0,0,.14);color:rgba(255,255,255,.88)}
.footer-iban strong{color:var(--tan-2)}
.site-footer h4{color:var(--tan-2)}
.footer-bottom{position:relative;z-index:2}
.footer-bottom .container{flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;text-align:left;gap:.5rem 1.2rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1 / -1}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---- People / contact cards (Vorstand, Beirat, Kuratorium, Team) ---- */
.prose .card.bg-brand-color-D{background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:visible;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.prose .card.bg-brand-color-D:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.prose .card.bg-brand-color-D .card-body{padding:1.7rem 1.9rem}
.prose .card.bg-brand-color-D .row{align-items:center;margin-inline:0;flex-wrap:nowrap}
.prose .card.bg-brand-color-D figure{margin:0;padding:0}
.prose figure[class*="col-sm-5"]{flex:0 0 auto;width:auto;padding:0;display:flex;justify-content:center}
.prose figure[class*="col-sm-5"] img{width:148px;height:148px;border-radius:50%;object-fit:cover;
  object-position:top center;border:5px solid var(--cream);box-shadow:var(--shadow-sm)}
.prose .card.bg-brand-color-D .col-sm-7{padding-left:1.6rem;padding-right:0;width:auto;flex:1 1 auto}
.prose .card.bg-brand-color-D .fw-bold{color:var(--orange);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem}
.prose .card.bg-brand-color-D .col-sm-7 p{font-family:var(--display);color:var(--maroon);font-size:1.3rem;font-weight:700;letter-spacing:-.01em;margin:.15rem 0 .4rem}
.prose .card.bg-brand-color-D .col-sm-7 p:has(a){font-family:var(--sans);font-size:.95rem;font-weight:500}
@media(max-width:520px){
  .prose .card.bg-brand-color-D .row{flex-wrap:wrap;justify-content:center;text-align:center}
  .prose .card.bg-brand-color-D .col-sm-7{padding-left:0;margin-top:1rem;text-align:center}
}

/* ---- Team org chart ---- */
.section-team{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(150deg,var(--maroon),var(--maroon-dark) 62%,#350f0a);
  background-size:300% 300%;animation:liveGrad 20s ease infinite}
.section-team::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 80% 18%,rgba(212,86,32,.22),transparent 56%)}
.section-team>.container{position:relative;z-index:2}
.section-team .sec-head h2{-webkit-text-fill-color:#fff;color:#fff;background:none}
.org-chart{display:flex;flex-direction:column;align-items:center;gap:.4rem;max-width:1120px;margin-inline:auto}
.org-link{width:3px;height:40px;border-radius:3px;
  background:linear-gradient(var(--orange),var(--tan-2));opacity:.85}
.org-row3{display:flex;flex-wrap:nowrap;justify-content:center;gap:1.2rem;margin-top:.4rem;
  position:relative;width:100%}
.org-row3::before{content:"";position:absolute;top:-22px;left:16%;right:16%;height:3px;
  background:linear-gradient(90deg,transparent,var(--tan-2),transparent);opacity:.8}
.org-node{display:flex;align-items:center;gap:1.1rem;width:min(420px,100%);
  background:#fff;border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-lg);
  padding:1.1rem 1.3rem;box-shadow:0 14px 34px -16px rgba(0,0,0,.5);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.org-node:hover{transform:translateY(-5px);box-shadow:0 22px 44px -16px rgba(0,0,0,.55)}
.org-row3 .org-node{flex:1 1 0;min-width:0;width:auto;gap:.95rem;padding:1rem 1.15rem}
.org-photo{width:104px;height:104px;flex:0 0 auto;border-radius:50%;object-fit:cover;
  object-position:top center;border:5px solid var(--cream);box-shadow:var(--shadow-sm)}
.org-row3 .org-photo{width:82px;height:82px;border-width:4px}
.org-mono{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--orange),var(--maroon));color:#fff;
  font-family:var(--display);font-size:1.7rem;font-weight:700;letter-spacing:.02em}
.org-info{min-width:0;text-align:left;align-self:center}
.org-role{display:block;color:var(--orange);text-transform:uppercase;
  letter-spacing:.09em;font-size:.68rem;font-weight:700;line-height:1.3}
.org-name{font-family:var(--display);color:var(--maroon);font-size:1.25rem;
  font-weight:700;letter-spacing:-.01em;margin:.2rem 0 .45rem;line-height:1.15}
.org-row3 .org-name{font-size:1.1rem}
.org-contact{margin:0;display:flex;flex-direction:column;align-items:flex-start;gap:.18rem;font-size:.9rem}
.org-contact a{color:var(--ink);display:block;text-align:left;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;max-width:100%}
.org-contact .org-tel{font-variant-numeric:tabular-nums;letter-spacing:.01em}
.org-contact a:hover{color:var(--orange)}
@media(max-width:760px){
  .org-row3{flex-wrap:wrap}
  .org-row3 .org-node{flex:1 1 280px}
  .org-row3 .org-photo{width:104px;height:104px}
  .org-row3 .org-name{font-size:1.25rem}
}
@media(max-width:560px){
  .org-node,.org-row3 .org-node{flex-direction:column;align-items:flex-start;text-align:left;width:100%}
  .org-info{text-align:left}
  .org-contact a{justify-content:flex-start}
  .org-row3::before{display:none}
}
@media(prefers-reduced-motion:reduce){.section-team{animation:none}}

/* ---- Tinted content panels must breathe & cohere (section OR div) ---- */
/* Applies to project pages that wrap image + side card + grid in
   <div class="bg-brand-color-D">; excludes people contact cards. */
.prose [class*="bg-brand-color-"]:not(.card){
  border-radius:var(--radius-lg);margin:2.8rem 0;
  padding-block:clamp(2rem,4vw,3.4rem);overflow:hidden}
.prose .bg-brand-color-D:not(.card){background:linear-gradient(140deg,var(--cream-2),var(--cream))}
.prose [class*="bg-brand-color-"]:not(.card)>.container{
  padding-inline:clamp(1.6rem,4vw,3rem);max-width:100%}
/* the inner py-5 would double the panel's own padding */
.prose [class*="bg-brand-color-"]:not(.card) .py-5{padding-top:0!important;padding-bottom:0!important}
/* image + side-card row: equal-height, gutters, no flush edges */
.prose [class*="bg-brand-color-"] .row{margin-inline:-12px;align-items:stretch}
.prose [class*="bg-brand-color-"] .row>[class*="col"]{padding-inline:12px}
.prose [class*="bg-brand-color-"] .row.mb-5{margin-bottom:clamp(1.6rem,3vw,2.4rem)!important}
.prose [class*="bg-brand-color-"] figure{margin:0;display:flex}
.prose [class*="bg-brand-color-"] figure>img{border-radius:var(--radius);box-shadow:var(--shadow-sm);
  width:100%;height:100%;object-fit:cover}
/* side card: fill height, content vertically centered (kills the big empty gap) */
.prose [class*="bg-brand-color-"] .card{background:#fff;height:100%}
.prose [class*="bg-brand-color-"] .card .card-body{justify-content:center}
.prose [class*="bg-brand-color-"] .card .mt-auto{margin-top:0!important}
/* sub-grid below: consistent rhythm with the row above */
.prose [class*="bg-brand-color-"] [class*="row-cols"]>*{margin-bottom:clamp(1.2rem,2.5vw,1.75rem)}
.prose [class*="bg-brand-color-"] [class*="row-cols"] img{border-radius:var(--radius-sm)}
@media(max-width:767px){
  .prose [class*="bg-brand-color-"] .row>[class*="col"]{margin-bottom:1.2rem}
  .prose [class*="bg-brand-color-"] figure>img{height:auto}
}

/* ---- Partners: all logos centered ---- */
.partner-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.4rem}
.partner-grid .p-cell{flex:0 1 175px;min-height:118px}

/* ---- Map section: wine gradient, light text, dynamic hint ---- */
.map-section{background:linear-gradient(155deg,var(--maroon),var(--maroon-dark) 68%,#350f0a);color:#fff}
.map-section::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 78% 28%,rgba(212,86,32,.24),transparent 56%)}
.map-section .container{position:relative;z-index:2}
.map-info .eyebrow{color:var(--tan-2)}
.map-info .prov-name{background:linear-gradient(110deg,#fff 0%,var(--tan-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.map-info h3.prov-tag{color:var(--orange-2)}
.map-info .prov-desc{color:rgba(255,255,255,.86)}
.map-legend{color:rgba(255,255,255,.82)}
.prov-chip{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.26);color:#fff}
.prov-chip:hover,.prov-chip.active{background:var(--orange);border-color:var(--orange);color:#fff}
.map-figure svg{filter:drop-shadow(0 18px 44px rgba(0,0,0,.42))}
.map-hint{display:inline-flex;align-items:center;gap:.6rem;margin-top:1.5rem;padding:.6rem 1.1rem;
  border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  font-size:.86rem;font-weight:600;color:#fff}
.map-hint .pulse{width:10px;height:10px;border-radius:50%;background:var(--orange-2);
  box-shadow:0 0 0 0 rgba(233,106,44,.7);animation:pulseRing 1.9s infinite}
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(233,106,44,.7)}70%{box-shadow:0 0 0 13px rgba(233,106,44,0)}100%{box-shadow:0 0 0 0 rgba(233,106,44,0)}}

/* ---- Grelha de notícias do projecto: 1 item sozinho ocupa linha toda ---- */
.row-cols-lg-3>.col:only-child{flex:0 0 100%;max-width:100%;display:flex;gap:1.5rem;align-items:flex-start}
.row-cols-lg-3>.col:only-child img.img-fluid{width:55%;flex-shrink:0;border-radius:8px}
.row-cols-lg-3>.col:only-child h3{margin-top:0}
@media(max-width:767px){
  .row-cols-lg-3>.col:only-child{flex-direction:column}
  .row-cols-lg-3>.col:only-child img.img-fluid{width:100%}
}

/* ---- Interior mini-hero: more room to breathe ---- */
.page-hero{min-height:clamp(340px,40vw,500px);display:flex;align-items:flex-end}
.page-hero .container{width:100%}

/* ---- More living gradient on the donation band ---- */
.donate-band{background:linear-gradient(125deg,var(--orange),#9c3a0c 45%,var(--orange-2) 70%,#9c3a0c);
  background-size:300% 300%;animation:liveGrad 16s ease infinite}

@media(prefers-reduced-motion:reduce){
  .footer-cta,.donate-band{animation:none}
  .map-hint .pulse{animation:none}
}

/* ===== Projekte in Planung ===== */
.section-plan{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:clamp(1.4rem,3vw,2.2rem);align-items:stretch}
.plan-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.plan-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan-thumb{position:relative;height:120px;background:linear-gradient(135deg,var(--maroon),var(--orange-dark) 120%);display:flex;align-items:flex-end;padding:1rem 1.25rem}
.plan-num{font-family:var(--display);font-weight:700;font-size:2.4rem;line-height:1;color:rgba(255,255,255,.85)}
.plan-body{display:flex;flex-direction:column;flex:1 1 auto;padding:1.4rem 1.4rem 1.5rem;gap:.6rem}
.plan-focus{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--orange-dark)}
.plan-title{font-family:var(--display);font-size:1.18rem;line-height:1.25;margin:0;color:var(--maroon-dark)}
.plan-text{font-size:.95rem;line-height:1.55;color:#4a4038;margin:0}
.plan-data{display:grid;grid-template-columns:1fr 1fr;gap:.65rem .8rem;margin:.4rem 0 .2rem;padding:0;border-top:1px solid rgba(95,35,30,.1);padding-top:.9rem}
.plan-data>div{margin:0}
.plan-data dt{font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:#8a7d70;margin:0}
.plan-data dd{margin:.15rem 0 0;font-weight:700;color:var(--maroon-dark);font-size:1rem}
.plan-prog{margin-top:.4rem}
.plan-prog-head{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;color:#5a4f45;margin-bottom:.4rem}
.plan-bar{height:9px;border-radius:99px;background:rgba(95,35,30,.12);overflow:hidden}
.plan-bar>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--orange),var(--orange-2));transition:width 1.1s var(--ease)}
.plan-cta{margin-top:auto;align-self:flex-start}
@media(max-width:560px){.plan-grid{grid-template-columns:1fr}.plan-data{grid-template-columns:1fr 1fr}}

/* =====================================================================
   v3.2 — Responsiveness hardening (global, all page types)
   ===================================================================== */
/* Media never forces horizontal scroll */
img,svg,video,iframe,canvas{max-width:100%}
iframe,video{height:auto}
/* Long unbreakable strings (emails, URLs) wrap instead of overflowing */
.prose a,.org-contact a,.footer-links a,.plan-text{overflow-wrap:anywhere;word-break:break-word}
.org-contact a{word-break:normal}
/* Bootstrap row never spills past the container on mobile */
.row{max-width:100%}
/* Subnav becomes a tidy horizontal scroll rail on small screens */
@media(max-width:560px){
  .subnav .container{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding-block:.6rem}
  .subnav .container::-webkit-scrollbar{display:none}
  .subnav a{flex:0 0 auto;white-space:nowrap}
}
/* Tablet: planning cards two-up, comfortable feature heights */
@media(min-width:561px) and (max-width:900px){
  .plan-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .feature{min-height:300px}
  .stat .num{font-size:clamp(2.6rem,8vw,3.6rem)}
}
/* Small phones: trim heavy vertical padding so content fills the frame */
@media(max-width:480px){
  .section{padding:clamp(48px,12vw,72px) 0}
  .page-hero .container{padding-top:clamp(60px,18vw,80px);padding-bottom:clamp(48px,14vw,72px)}
  .plan-body{padding:1.2rem 1.15rem 1.3rem}
  .container{padding-inline:18px}
}
/* ==================== HERO SLIM + PAGE TITLE ==================== */
.page-hero--slim{min-height:clamp(160px,16vw,240px)}
.page-hero--slim .container{display:none}

.page-title-section{background:var(--cream,#F2EFE4);border-bottom:1px solid rgba(0,0,0,.06);padding:2rem 0 1.75rem}
.page-title-section .crumbs{font-size:.82rem;color:rgba(0,0,0,.5);margin-bottom:.75rem}
.page-title-section .crumbs a{color:rgba(0,0,0,.5)}.page-title-section .crumbs a:hover{color:var(--orange,#C0501A)}
.page-title-section .eyebrow{display:block;color:var(--orange,#C0501A);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3em}
.page-title-section h1{color:var(--orange,#C0501A);margin:.1em 0 .3em;font-size:clamp(1.9rem,1rem + 3vw,3rem)}
.page-title-section .lead{font-size:clamp(1rem,1rem + .25vw,1.15rem);color:rgba(0,0,0,.6);max-width:62ch;margin:0}

.page-intro>p:first-child,.page-intro>div:first-child>p:first-child{border-left:3px solid var(--orange,#C0501A);padding-left:1.25rem;margin-bottom:1rem}
/* ==================== fim HERO SLIM ==================== */

/* Home hero: keep the photo from over-cropping on phones and tablets */
@media(max-width:760px){
  .hero{min-height:auto;align-items:stretch}
  .hero-bg img{object-position:center 22%;transform:scale(1.08)}
  @keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
  .hero .container{padding-top:clamp(96px,22vw,140px);padding-bottom:clamp(72px,18vw,110px)}
  .hero p{max-width:100%}
}
