/* =========================================================
   International Throwball Federation — shared design system
   Palette: Indigo #283593 · Marigold #F5A623 · Ivory #FBF8F1
   Type: Fraunces (display) + Hanken Grotesk (text)
   ========================================================= */
:root{
  --ivory:#FBF8F1;
  --ivory-2:#F3EEE1;
  --ink:#1A1A2E;
  --ink-soft:#4A4A63;
  --indigo:#283593;
  --indigo-deep:#1B2566;
  --indigo-100:#E7E9F4;
  --marigold:#F5A623;
  --marigold-deep:#E08E1A;
  --pine:#0E7C66;
  --line:rgba(26,26,46,.12);
  --line-soft:rgba(26,26,46,.07);
  --shadow:0 1px 2px rgba(27,37,102,.04),0 12px 32px -12px rgba(27,37,102,.18);
  --shadow-lg:0 2px 4px rgba(27,37,102,.06),0 28px 60px -20px rgba(27,37,102,.28);
  --maxw:1180px;
  --r:18px;
  --net:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28'%3E%3Cpath d='M28 0H0v28' fill='none' stroke='%23283593' stroke-width='1' stroke-opacity='0.08'/%3E%3C/svg%3E");
  --net-w:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath d='M30 0H0v30' fill='none' stroke='%23ffffff' stroke-width='1' stroke-opacity='0.09'/%3E%3C/svg%3E");
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;background:var(--ivory);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.05;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--indigo);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--marigold);display:inline-block}
.eyebrow.c{justify-content:center}
.icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.95rem;padding:.85em 1.4em;border-radius:999px;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--marigold);color:var(--indigo-deep);box-shadow:0 8px 22px -8px rgba(245,166,35,.7)}
.btn-primary:hover{transform:translateY(-2px);background:var(--marigold-deep);box-shadow:0 14px 28px -10px rgba(245,166,35,.8)}
.btn-ghost{background:transparent;color:var(--indigo);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--indigo);transform:translateY(-2px)}
.btn-light{background:var(--ivory);color:var(--indigo-deep)}
.btn-light:hover{transform:translateY(-2px)}

/* utility strip */
.util{background:var(--indigo-deep);color:#cfd3ee;font-size:.8rem}
.util .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;height:38px}
.util b{color:#fff;font-weight:600}
.util .dot{color:var(--marigold)}
.util-r{display:flex;gap:18px;align-items:center}
@media(max-width:720px){.util-r span:first-child{display:none}}

/* header / nav */
header{position:sticky;top:0;z-index:50;background:rgba(251,248,241,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;position:relative}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{flex:none}
.brand img.mark{display:block;object-fit:contain}
.f-brand img{display:block;margin-bottom:2px}
.brand .name{font-family:"Fraunces",serif;font-weight:600;font-size:1.18rem;color:var(--indigo-deep);line-height:1}
.brand .sub{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-top:3px}
nav ul{list-style:none;display:flex;gap:30px;align-items:center}
nav .links a{font-size:.93rem;font-weight:500;color:var(--ink);position:relative;padding:6px 0}
nav .links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--marigold);transition:width .25s ease}
nav .links a:hover{color:var(--indigo)}
nav .links a:hover::after,nav .links a.active::after{width:100%}
nav .links a.active{color:var(--indigo)}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:10px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.burger span{width:18px;height:2px;background:var(--ink);position:relative;display:block}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.burger span::before{top:-6px}.burger span::after{top:6px}
@media(max-width:980px){
  .links,.nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  header.open .links{display:flex;flex-direction:column;align-items:flex-start;gap:16px;position:absolute;top:100%;left:0;right:0;background:var(--ivory);padding:22px 28px 26px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);z-index:60}
}

/* hero (home) */
.hero{position:relative;padding:78px 0 90px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:var(--net);background-size:28px 28px;opacity:.6;-webkit-mask-image:radial-gradient(120% 90% at 80% 0%,#000 30%,transparent 75%);mask-image:radial-gradient(120% 90% at 80% 0%,#000 30%,transparent 75%);z-index:0}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero-copy .eyebrow{display:block;font-family:"Fraunces",Georgia,serif;font-size:clamp(1.65rem,3vw,2.3rem);font-weight:600;letter-spacing:-.01em;text-transform:none;color:var(--indigo);line-height:1.08;margin-bottom:18px}
.hero-copy .eyebrow::before{display:none}
.hero h1{font-size:clamp(1.6rem,2.9vw,2.15rem);font-weight:500;line-height:1.16;color:var(--ink);margin-bottom:26px}
.hero h1 em{font-style:italic;color:var(--indigo)}
.hero h1 .ball{color:var(--marigold);font-style:normal}
.hero p.lead{font-size:1.05rem;line-height:1.6;color:var(--ink-soft);max-width:33em;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.hero-stats .n{font-family:"Fraunces",serif;font-size:1.85rem;font-weight:600;color:var(--indigo);line-height:1}
.hero-stats .l{font-size:.82rem;color:var(--ink-soft);margin-top:4px}
.hero-visual{position:relative;aspect-ratio:1/1;border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg)}
.hero-visual .panel{position:absolute;inset:0;background:radial-gradient(130% 120% at 20% 10%,#34409e 0%,#283593 42%,#1B2566 100%)}
.hero-visual .panel::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34'%3E%3Cpath d='M34 0H0v34' fill='none' stroke='%23ffffff' stroke-width='1' stroke-opacity='0.05'/%3E%3C/svg%3E");background-size:34px 34px}
/* dotted world map */
.emblem{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 22px;z-index:1}
.map-title{font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:clamp(1.2rem,1.9vw,1.55rem);color:#fff;text-align:center;margin-bottom:48px;line-height:1.12}
.map-box{position:relative;width:100%;max-width:600px;aspect-ratio:4378/2435;animation:floaty 7s ease-in-out infinite}
.worldmap-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
/* marigold highlight dots for member nations on the map */
.hl{position:absolute;transform:translate(-50%,-50%);z-index:3;width:11px;height:11px;border-radius:50%;background:#F5A623;box-shadow:0 0 0 3px rgba(245,166,35,.28),0 0 12px 2px rgba(245,166,35,.55);animation:hlp 2.8s ease-in-out infinite}
@keyframes hlp{0%,100%{box-shadow:0 0 0 3px rgba(245,166,35,.28),0 0 11px 2px rgba(245,166,35,.5)}50%{box-shadow:0 0 0 5px rgba(245,166,35,.15),0 0 16px 3px rgba(245,166,35,.72)}}
a.hl{cursor:pointer}
a.hl:hover{transform:translate(-50%,-50%) scale(1.45);background:var(--marigold-deep)}
.gmark{position:absolute;transform:translate(-50%,-100%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:5px;pointer-events:none}
.gmark .b{width:25px;height:25px;border-radius:50%;background:#fff;border:1px solid rgba(27,37,102,.15);box-shadow:0 5px 12px -3px rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;font-size:13px;line-height:1}
.gmark .d{width:11px;height:11px;border-radius:50%;background:var(--marigold);animation:gping 2.4s ease-out infinite}
@keyframes gping{0%{box-shadow:0 0 0 0 rgba(245,166,35,.55)}70%,100%{box-shadow:0 0 0 14px rgba(245,166,35,0)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.map-box>svg{position:absolute;inset:0;width:100%;height:100%;display:block;overflow:visible}
.map-dot{fill:#b4bcf0;opacity:.9}
.arc{fill:none;stroke:#F5A623;stroke-width:1.6;stroke-opacity:.6;stroke-linecap:round;stroke-dasharray:1300;stroke-dashoffset:1300;animation:draw 2.8s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.mk-core{fill:#F5A623}
.mk-halo{fill:#F5A623;transform-box:fill-box;transform-origin:center;animation:ping 2.6s ease-out infinite}
@keyframes ping{0%{transform:scale(1);opacity:.55}80%,100%{transform:scale(4.6);opacity:0}}
.mk-flag{position:absolute;transform:translate(-50%,-50%);z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none}
.mk-flag .b{width:25px;height:25px;border-radius:50%;background:#fff;border:1px solid rgba(27,37,102,.15);box-shadow:0 5px 12px -3px rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;font-size:13px;line-height:1}
@media(max-width:980px){.hero .wrap{grid-template-columns:1fr;gap:40px}.hero-visual{max-width:460px;margin:0 auto;width:100%}}

/* entrance */
.rise{opacity:0;transform:translateY(18px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.25s}.d4{animation-delay:.35s}.d5{animation-delay:.45s}

/* marquee */
.marquee{background:var(--indigo);color:#dfe3f6;padding:15px 0;overflow:hidden;white-space:nowrap}
.marquee .track{display:inline-flex;gap:46px;animation:scroll 32s linear infinite}
.marquee span{font-size:.86rem;letter-spacing:.04em;display:inline-flex;align-items:center;gap:46px;font-weight:500}
.marquee span::after{content:"●";color:var(--marigold);font-size:.6rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* sections */
section{padding:88px 0}
.sec-head{max-width:640px;margin-bottom:48px}
.sec-head.center{margin:0 auto 54px;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);color:var(--ink);margin:18px 0 16px}
.sec-head p{font-size:1.06rem;color:var(--ink-soft)}
.alt{background:var(--ivory-2)}

/* feature grid */
.sport-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature{background:var(--ivory);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s}
.alt .feature{background:#fff}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.feature .ic{width:50px;height:50px;border-radius:13px;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feature h3{font-size:1.22rem;margin-bottom:8px;color:var(--indigo-deep)}
.feature p{font-size:.94rem;color:var(--ink-soft)}
@media(max-width:880px){.sport-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.sport-grid{grid-template-columns:1fr}}

/* global reach */
.reach{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.reach-visual{position:relative;background:var(--indigo-deep);border-radius:26px;padding:42px;color:#fff;overflow:hidden;box-shadow:var(--shadow-lg)}
.reach-visual::before{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:30px 30px}
.reach-visual .big{position:relative;font-family:"Fraunces",serif;font-size:5rem;font-weight:600;line-height:1;color:var(--marigold)}
.reach-visual .big small{display:block;font-family:"Hanken Grotesk";font-size:1rem;font-weight:500;color:#cfd3ee;letter-spacing:.02em;margin-top:8px}
.reach-visual .conts{position:relative;margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:14px 22px}
.reach-visual .conts div{display:flex;justify-content:space-between;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:8px}
.reach-visual .conts b{color:var(--marigold);font-weight:600}
.countries{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.countries span{font-size:.86rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 15px;font-weight:500;transition:.25s}
.alt .countries span{background:var(--ivory)}
.countries span:hover{border-color:var(--indigo);color:var(--indigo);transform:translateY(-2px)}
@media(max-width:880px){.reach{grid-template-columns:1fr;gap:38px}}

/* impact band */
.impact{background:var(--indigo);color:#fff;border-radius:28px;padding:60px 48px;position:relative;overflow:hidden}
.impact::before{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:32px 32px;opacity:.85}
.impact-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.impact .n{font-family:"Fraunces",serif;font-size:3rem;font-weight:600;color:var(--marigold);line-height:1}
.impact .l{font-size:.95rem;color:#dfe3f6;margin-top:8px}
@media(max-width:760px){.impact-grid{grid-template-columns:1fr 1fr;gap:36px 20px}.impact{padding:46px 28px}}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card .media{aspect-ratio:16/10;position:relative;background:radial-gradient(120% 120% at 25% 15%,#34409e,#283593 55%,#1B2566);overflow:hidden}
.card .media::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26'%3E%3Cpath d='M26 0H0v26' fill='none' stroke='%23ffffff' stroke-width='1' stroke-opacity='0.12'/%3E%3C/svg%3E");background-size:26px 26px}
.card .media .pin{position:absolute;width:78px;height:78px;border-radius:50%;right:-14px;bottom:-14px;background:radial-gradient(circle at 32% 30%,#ffce7a,#F5A623 60%,#E08E1A)}
.card .tagline{position:absolute;top:14px;left:14px;background:var(--marigold);color:var(--indigo-deep);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:999px;z-index:2}
.card .body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.card .date{font-size:.78rem;color:var(--pine);font-weight:600;letter-spacing:.04em;margin-bottom:8px}
.card h3{font-size:1.28rem;color:var(--indigo-deep);margin-bottom:10px;line-height:1.18}
.card p{font-size:.92rem;color:var(--ink-soft);flex:1}
.card .more{margin-top:16px;font-weight:600;font-size:.9rem;color:var(--indigo);display:inline-flex;gap:6px;align-items:center}
.card:hover .more{gap:11px}
@media(max-width:880px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}

/* CTA */
.cta{position:relative;border-radius:28px;background:radial-gradient(120% 160% at 85% 0%,#34409e,#283593 45%,#1B2566 100%);color:#fff;padding:64px 56px;overflow:hidden;text-align:center}
.cta::before{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:30px 30px}
.cta .ball-bg{position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(245,166,35,.5),rgba(245,166,35,0) 70%);right:-60px;top:-60px}
.cta-inner{position:relative}
.cta h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-bottom:16px}
.cta p{color:#dfe3f6;font-size:1.08rem;max-width:34em;margin:0 auto 30px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .note{margin-top:20px;font-size:.84rem;color:#aeb4e0}
@media(max-width:620px){.cta{padding:48px 26px}}

/* footer */
footer{background:var(--ink);color:#b9bbcf;padding:64px 0 30px;margin-top:90px}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.f-brand .name{font-family:"Fraunces",serif;color:#fff;font-size:1.25rem;font-weight:600;margin:14px 0 12px}
.f-brand p{font-size:.9rem;max-width:30em}
footer h4{color:#fff;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer ul a{font-size:.92rem;transition:.2s}
footer ul a:hover{color:var(--marigold)}
.f-contact p{font-size:.92rem;margin-bottom:10px;line-height:1.5}
.f-contact b{color:#fff;font-weight:600}
.socials{display:flex;gap:10px;margin-top:16px}
.socials a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;color:#fff;transition:.25s}
.socials a:hover{background:var(--marigold);color:var(--indigo-deep);border-color:var(--marigold);transform:translateY(-2px)}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.84rem;flex-wrap:wrap;gap:12px}
.f-bottom .badge{background:rgba(245,166,35,.14);color:var(--marigold);border:1px solid rgba(245,166,35,.3);padding:5px 12px;border-radius:999px;font-weight:600;font-size:.78rem}
@media(max-width:880px){.f-grid{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:520px){.f-grid{grid-template-columns:1fr}}

/* =========================================================
   INNER PAGES
   ========================================================= */
/* page banner */
.page-banner{position:relative;background:radial-gradient(120% 150% at 82% 0%,#34409e,#283593 45%,#1B2566 100%);color:#fff;padding:52px 0 58px;overflow:hidden}
.page-banner::before{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:30px 30px}
.page-banner::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;right:-80px;top:-110px;background:radial-gradient(circle at 40% 40%,rgba(245,166,35,.45),rgba(245,166,35,0) 70%)}
.page-banner .wrap{position:relative;z-index:1}
.page-banner h1{font-size:clamp(2.2rem,4.6vw,3.4rem);margin-bottom:12px}
.page-banner p{color:#dfe3f6;font-size:1.08rem;max-width:48em}
.breadcrumb{font-size:.84rem;color:#bcc2ea;margin-bottom:18px;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.breadcrumb a:hover{color:#fff}
.breadcrumb .sep{opacity:.45}
.breadcrumb .here{color:var(--marigold)}

/* doc layout (about) */
.doc{display:grid;grid-template-columns:230px 1fr;gap:56px;align-items:start}
.doc-nav{position:sticky;top:98px;display:flex;flex-direction:column;gap:3px}
.doc-nav .lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:10px}
.doc-nav a{font-size:.92rem;color:var(--ink-soft);padding:8px 14px;border-left:2px solid var(--line);transition:.2s}
.doc-nav a:hover,.doc-nav a.on{color:var(--indigo);border-left-color:var(--marigold);background:var(--indigo-100)}
.doc-body{max-width:760px}
.doc-sec{padding-bottom:54px;scroll-margin-top:96px}
.doc-sec:last-child{padding-bottom:0}
.doc-sec h2{font-size:clamp(1.7rem,3vw,2.3rem);color:var(--ink);margin-bottom:16px}
.doc-sec h3{font-size:1.18rem;color:var(--indigo-deep);margin:26px 0 8px}
.doc-sec p{color:var(--ink-soft);margin-bottom:14px;font-size:1.02rem}
.doc-sec ul.bullets{margin:0 0 16px 1.1em;color:var(--ink-soft)}
.doc-sec ul.bullets li{margin-bottom:8px}
.statement{font-family:"Fraunces",serif;font-size:clamp(1.35rem,2.5vw,1.8rem);line-height:1.32;color:var(--ink);font-weight:500;margin-bottom:18px}
.statement em{font-style:italic;color:var(--indigo)}
@media(max-width:860px){.doc{grid-template-columns:1fr;gap:8px}.doc-nav{position:static;flex-direction:row;flex-wrap:wrap;gap:8px;margin-bottom:28px}.doc-nav .lbl{display:none}.doc-nav a{border-left:0;border:1px solid var(--line);border-radius:999px;padding:7px 14px}}

/* timeline */
.timeline{position:relative;margin-top:8px;padding-left:28px;border-left:2px solid var(--line)}
.timeline .t-item{position:relative;padding-bottom:26px}
.timeline .t-item:last-child{padding-bottom:0}
.timeline .t-item::before{content:"";position:absolute;left:-35px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--marigold);box-shadow:0 0 0 4px var(--ivory)}
.timeline .yr{font-family:"Fraunces",serif;font-weight:600;color:var(--indigo);font-size:1.05rem}
.timeline p{margin:3px 0 0}

/* people / committee */
.people{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.person .ph{aspect-ratio:1;border-radius:16px;background:radial-gradient(130% 130% at 25% 20%,#34409e,#283593 60%,#1B2566);display:flex;align-items:center;justify-content:center;color:#fff;font-family:"Fraunces",serif;font-size:1.7rem;font-weight:600;margin-bottom:12px;position:relative;overflow:hidden;border:1px solid var(--line)}
.person .ph::after{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:24px 24px}
.person .ph span{position:relative;z-index:1}
.person .nm{font-weight:700;color:var(--indigo-deep);line-height:1.2}
.person .ro{font-size:.85rem;color:var(--ink-soft);margin-top:2px}
@media(max-width:760px){.people{grid-template-columns:1fr 1fr}}

/* sub-nav (continent tabs) */
.subnav{position:sticky;top:74px;z-index:40;background:rgba(251,248,241,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}
.subnav .wrap{display:flex;gap:8px;overflow-x:auto;padding-top:12px;padding-bottom:12px}
.subnav a{font-size:.9rem;font-weight:600;color:var(--ink-soft);padding:8px 16px;border-radius:999px;white-space:nowrap;transition:.2s}
.subnav a:hover{color:var(--indigo);background:var(--indigo-100)}

/* members / continents */
.continent{padding:52px 0;border-bottom:1px solid var(--line-soft);scroll-margin-top:130px}
.continent:last-of-type{border-bottom:0}
.c-head{display:flex;align-items:baseline;gap:8px 16px;margin-bottom:24px;flex-wrap:wrap}
.c-head h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink)}
.c-head .cnt{color:var(--pine);font-weight:600;font-size:.92rem;background:rgba(14,124,102,.1);padding:4px 12px;border-radius:999px}
.c-head .desc{flex:1 1 260px;color:var(--ink-soft);font-size:1rem}
.members{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.member{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 16px;transition:.25s}
.member:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.member .fl{font-size:1.8rem;line-height:1;flex:none}
.member .mn{display:block;font-weight:700;color:var(--indigo-deep);font-size:.98rem;line-height:1.15}
.member .st{display:block;font-size:.76rem;color:var(--ink-soft);margin-top:3px}
.member .txt{display:flex;flex-direction:column}
.member .st.full{color:var(--pine);font-weight:600}
.member.soon{border-style:dashed;background:transparent;justify-content:center;color:var(--ink-soft);font-weight:600;font-size:.9rem}
@media(max-width:860px){.members{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.members{grid-template-columns:1fr}}

/* events filter + featured */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filters button{font:inherit;font-size:.9rem;font-weight:600;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;transition:.2s}
.filters button:hover{border-color:var(--indigo);color:var(--indigo)}
.filters button.on{background:var(--indigo);color:#fff;border-color:var(--indigo)}
.is-hidden{display:none!important}
.featured{display:grid;grid-template-columns:1.05fr .95fr;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:42px;background:#fff}
.featured .media{position:relative;min-height:320px;background:radial-gradient(120% 120% at 25% 15%,#34409e,#283593 55%,#1B2566)}
.featured .media::after{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:28px 28px}
.featured .media .pin{position:absolute;width:120px;height:120px;border-radius:50%;right:-24px;bottom:-24px;background:radial-gradient(circle at 32% 30%,#ffce7a,#F5A623 60%,#E08E1A)}
.featured .media .tagline{position:absolute;top:18px;left:18px;background:var(--marigold);color:var(--indigo-deep);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 13px;border-radius:999px;z-index:2}
.featured .body{padding:42px}
.featured .date{font-size:.82rem;color:var(--pine);font-weight:600;margin-bottom:10px}
.featured h2{font-size:clamp(1.6rem,2.6vw,2.1rem);color:var(--ink);margin-bottom:14px}
.featured p{color:var(--ink-soft);margin-bottom:22px}
@media(max-width:760px){.featured{grid-template-columns:1fr}.featured .media{min-height:200px}.featured .body{padding:30px}}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.info-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;margin-bottom:16px;display:flex;gap:16px;align-items:flex-start}
.info-card .ic{width:44px;height:44px;border-radius:11px;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.info-card h4{color:var(--indigo-deep);font-size:.95rem;margin-bottom:4px;letter-spacing:0;text-transform:none}
.info-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.info-card a:hover{color:var(--indigo)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.field label{font-size:.82rem;font-weight:600;color:var(--ink)}
.field input,.field textarea,.field select{font:inherit;font-size:.95rem;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--ivory);color:var(--ink);transition:.2s;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-100);background:#fff}
.field textarea{min-height:140px;resize:vertical}
.map-embed{margin-top:18px;border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;position:relative;background:radial-gradient(120% 120% at 30% 20%,#34409e,#283593 60%,#1B2566)}
.map-embed::after{content:"";position:absolute;inset:0;background-image:var(--net-w);background-size:24px 24px}
.map-embed .pin-lbl{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;display:flex;flex-direction:column;align-items:center;color:#fff;font-size:.82rem;font-weight:600;gap:6px}
.map-embed .pin-lbl .d{width:14px;height:14px;border-radius:50%;background:var(--marigold);box-shadow:0 0 0 5px rgba(245,166,35,.3)}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:32px}.form .row{grid-template-columns:1fr}}

/* helpers */
.lead-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.tight{padding:64px 0}
.callout{background:var(--indigo-100);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.callout p{color:var(--ink-soft);margin:0}
.callout b{color:var(--indigo-deep)}
.note-small{font-size:.82rem;color:var(--ink-soft);font-style:italic;margin-top:18px}
