/* ===========================================================
   WCE Luxembourg — wcelux.charity
   Brand: deep purple #301050  ·  gold #C09030
   =========================================================== */

:root{
  --purple:#301050;
  --purple-deep:#23093f;
  --purple-soft:#4a2278;
  --gold:#C09030;
  --gold-light:#d9a948;
  --ink:#1f2230;
  --muted:#5d6172;
  --bg:#ffffff;
  --bg-soft:#f7f5fa;
  --line:#ece8f1;
  --radius:14px;
  --shadow:0 18px 45px rgba(48,16,80,.10);
  --shadow-sm:0 8px 22px rgba(48,16,80,.08);
  --maxw:1180px;
  --font-head:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:88px}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.2;color:var(--purple);font-weight:700}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--soft{background:var(--bg-soft)}
.center{text-align:center}
.eyebrow{
  font-family:var(--font-head);font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;font-size:.8rem;color:var(--gold);margin-bottom:14px;
}
.lead{font-size:1.12rem;color:var(--muted);max-width:720px}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-head);font-weight:600;font-size:.98rem;
  padding:14px 30px;border-radius:50px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:#fff}
.btn--gold:hover{background:var(--gold-light)}
.btn--purple{background:var(--purple);color:#fff}
.btn--purple:hover{background:var(--purple-soft)}
.btn--outline{border-color:var(--purple);color:var(--purple);background:transparent}
.btn--outline:hover{background:var(--purple);color:#fff}
.btn--ghost-light{border-color:#fff;color:#fff;background:transparent}
.btn--ghost-light:hover{background:#fff;color:var(--purple)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700;color:var(--purple)}
.brand img{height:48px;width:auto}
.brand span{font-size:.95rem;letter-spacing:.01em;line-height:1.25}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-family:var(--font-head);font-weight:500;font-size:.98rem;color:var(--ink);position:relative;padding:4px 0}
.nav-links a:hover,.nav-links a.active{color:var(--purple)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--gold)}
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-phone{font-family:var(--font-body);font-weight:500;color:var(--muted);font-size:.82rem;letter-spacing:.01em;white-space:nowrap}
.nav-phone:hover{color:var(--purple)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:26px;height:3px;background:var(--purple);border-radius:3px;transition:.25s}
.nav-mobile-foot{display:none}  /* shown only inside the mobile menu panel */

/* ---------- Dropdown nav ---------- */
.has-dropdown{position:relative}
.has-dropdown>a::after{content:" ▾";font-size:.65rem;opacity:.7}
.dropdown{
  display:none;position:absolute;top:calc(100% + 10px);left:-16px;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow-sm);min-width:200px;padding:8px 0;
  list-style:none;z-index:200;
}
.has-dropdown:hover .dropdown{display:block}
.dropdown li{padding:0}
.dropdown a{
  display:block;padding:11px 20px;font-size:.93rem;
  font-family:var(--font-head);font-weight:500;color:var(--ink);white-space:nowrap;
}
.dropdown a:hover{background:var(--bg-soft);color:var(--purple)}
.dropdown a.active{color:var(--purple);font-weight:600}
/* active parent underline on desktop */
.active-parent>a{color:var(--purple)}
.active-parent>a::before{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--gold)}

/* ---------- Donate amount cards – dual buttons ---------- */
.donate-btns{display:flex;gap:10px;width:100%;margin-top:auto}
.donate-btns .btn{flex:1;font-size:.84rem;padding:10px 14px;justify-content:center}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(35,9,63,.92) 0%,rgba(48,16,80,.78) 45%,rgba(192,144,48,.55) 100%);
  z-index:1;
}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-inner{position:relative;z-index:2;padding:120px 24px 130px;max-width:780px}
.hero .logo-badge{height:200px;width:200px;object-fit:contain;background:#fff;border-radius:50%;padding:22px;margin-bottom:30px;box-shadow:0 16px 40px rgba(0,0,0,.3)}
.hero h1{color:#fff;font-size:clamp(2.1rem,5vw,3.5rem);margin-bottom:20px}
.hero p{font-size:1.2rem;color:rgba(255,255,255,.92);max-width:640px;margin-bottom:32px}
.hero p strong{color:var(--gold-light)}

/* ---------- Split (text/image) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split--reverse .split-media{order:-1}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.split h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:18px}

/* ---------- Values / wavy grid ---------- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.vcard{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}
.vcard img{height:200px;width:100%;object-fit:cover}
.vcard-body{padding:26px;text-align:left}
.vcard-body h3{font-size:1.25rem;margin-bottom:10px}

/* values list */
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:46px}
.value{background:#fff;border-left:4px solid var(--gold);padding:22px 26px;border-radius:10px;box-shadow:var(--shadow-sm)}
.value h4{color:var(--purple);font-size:1.1rem;margin-bottom:6px}
.value p{color:var(--muted);font-size:.97rem}

/* ---------- Join the movement ---------- */
.join-list{list-style:none;display:grid;grid-template-columns:1fr;gap:16px;margin-top:14px}
.join-list li{font-size:1.05rem;background:#fff;padding:16px 22px;border-radius:10px;box-shadow:var(--shadow-sm)}
.join-list strong{color:var(--purple)}

/* ---------- Programs ---------- */
.programs{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.program{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.program img{height:240px;width:100%;object-fit:cover}
.program-body{padding:28px;flex:1;display:flex;flex-direction:column;text-align:left}
.program-body h3{font-size:1.3rem;margin-bottom:14px}
.program-body ul{list-style:none;margin-bottom:20px;flex:1}
.program-body li{padding:7px 0 7px 26px;position:relative;color:var(--muted)}
.program-body li::before{content:"";position:absolute;left:0;top:15px;width:9px;height:9px;border-radius:50%;background:var(--gold)}

/* ---------- Partners ---------- */
.partners{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:50px;margin-top:46px}
.partners img{max-height:110px;width:auto;object-fit:contain;filter:grayscale(.1)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--purple-deep),var(--purple-soft));color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:10px}
.cta-band p{color:rgba(255,255,255,.9);margin-bottom:26px;font-size:1.1rem}

/* ---------- Forms ---------- */
.form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:40px;max-width:720px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1 / -1}
.field label{font-family:var(--font-head);font-weight:500;font-size:.92rem;color:var(--purple)}
.field input,.field textarea,.field select{
  border:1px solid var(--line);border-radius:10px;padding:13px 15px;font-family:var(--font-body);
  font-size:1rem;background:#fcfbfe;transition:border .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(48,16,80,.12)}
.field textarea{resize:vertical;min-height:130px}
.req{color:var(--gold)}

/* ---------- Contact info ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:50px;align-items:start}
.info-list{list-style:none;display:grid;gap:22px}
.info-list li{display:flex;gap:16px;align-items:flex-start}
.info-ico{flex:none;width:46px;height:46px;border-radius:12px;background:var(--purple);color:#fff;display:grid;place-items:center;font-size:1.2rem}
.info-list h4{font-size:1rem;margin-bottom:2px}
.info-list a,.info-list span{color:var(--muted)}

/* ---------- Donate ---------- */
.donate-options{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.donate-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:34px 28px;text-align:center;border-top:5px solid var(--gold);display:flex;flex-direction:column}
.donate-card .amt{font-family:var(--font-head);font-weight:700;font-size:2.1rem;color:var(--purple);margin-bottom:6px}
.donate-card p{color:var(--muted);flex:1;margin-bottom:22px}
.donate-methods{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:40px}
.method-chip{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:50px;padding:12px 24px;font-family:var(--font-head);font-weight:500;box-shadow:var(--shadow-sm)}

/* ---------- Crypto ---------- */
.crypto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:26px;margin-top:50px}
.coin-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px;text-align:center;display:flex;flex-direction:column;align-items:center;border:1px solid var(--line);transition:transform .15s,box-shadow .2s}
.coin-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.coin-head{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.coin-sym{width:40px;height:40px;border-radius:50%;background:var(--purple);color:var(--gold-light);display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:.85rem}
.coin-name{font-family:var(--font-head);font-weight:600;color:var(--purple)}
.coin-net{display:block;font-size:.78rem;color:var(--muted);font-weight:400}
.qr-box{width:170px;height:170px;border-radius:12px;background:var(--bg-soft);border:2px dashed var(--line);display:grid;place-items:center;color:var(--muted);font-size:.82rem;text-align:center;padding:10px;margin-bottom:16px;overflow:hidden}
.qr-box img{width:100%;height:100%;object-fit:contain}
.addr{width:100%;background:var(--bg-soft);border-radius:10px;padding:11px 12px;font-family:"SFMono-Regular",Consolas,monospace;font-size:.78rem;color:var(--ink);word-break:break-all;border:1px solid var(--line);margin-bottom:12px;min-height:44px;display:flex;align-items:center;justify-content:center}
.copy-btn{font-family:var(--font-head);font-weight:600;font-size:.85rem;color:var(--purple);background:none;border:1px solid var(--purple);border-radius:50px;padding:8px 20px;cursor:pointer;transition:.2s}
.copy-btn:hover{background:var(--purple);color:#fff}
.note-box{background:#fff;border-left:4px solid var(--gold);border-radius:10px;padding:22px 26px;box-shadow:var(--shadow-sm);max-width:820px;margin:40px auto 0;color:var(--muted)}

/* ---------- Embedded form (Airtable) ---------- */
.form-embed{max-width:820px;margin:46px auto 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff}
.form-embed iframe{width:100%;height:920px;border:0;display:block}
.form-pending{max-width:820px;margin:46px auto 0;background:#fff;border:2px dashed var(--line);border-radius:var(--radius);padding:48px 40px;text-align:center;color:var(--muted)}
.form-pending h3{margin-bottom:10px}
.steps{counter-reset:s;list-style:none;max-width:760px;margin:30px auto 0;text-align:left;display:grid;gap:14px}
.steps li{position:relative;padding:16px 20px 16px 60px;background:#fff;border-radius:10px;box-shadow:var(--shadow-sm)}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;left:16px;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;background:var(--purple);color:#fff;font-family:var(--font-head);font-weight:600;display:grid;place-items:center;font-size:.9rem}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:38px 46px;margin-top:50px}
.member{display:flex;gap:24px;align-items:flex-start;background:none;box-shadow:none;border:0;border-radius:0;padding:0;overflow:visible}
.member-photo{width:140px;height:170px;flex:none;border-radius:50%;object-fit:cover;object-position:center top;background:var(--bg-soft)}
.member-photo.placeholder{display:grid;place-items:center;color:var(--muted);font-size:.7rem;text-align:center;padding:10px;border:1px dashed var(--line)}
.member-body{padding:0;flex:1}
.member h3{font-size:1.2rem;margin-bottom:8px}
.member .role{font-family:var(--font-head);font-weight:500;color:var(--gold);font-size:.85rem;margin-bottom:10px;display:block}
.member p{color:var(--muted);font-size:.92rem;line-height:1.6}

/* ---------- Legal / prose ---------- */
.prose{max-width:820px;margin:0 auto;text-align:left}
.prose h2{font-size:1.4rem;margin:38px 0 12px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.1rem;margin:24px 0 8px;color:var(--purple-soft)}
.prose p{color:var(--ink);margin-bottom:14px}
.prose ul{margin:0 0 16px 22px;color:var(--ink)}
.prose li{margin-bottom:8px}
.prose a{color:var(--purple);font-weight:500;text-decoration:underline}
.prose .updated{color:var(--muted);font-size:.92rem;margin-bottom:30px}
.prose .legal-note{background:var(--bg-soft);border-left:4px solid var(--gold);border-radius:10px;padding:18px 22px;color:var(--muted);font-size:.92rem;margin:24px 0}

/* ---------- Footer ---------- */
.site-footer{background:var(--purple-deep);color:rgba(255,255,255,.82);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:44px;padding-bottom:48px}
.site-footer h5{font-family:var(--font-head);color:#fff;font-size:1.05rem;margin-bottom:18px;text-transform:uppercase;letter-spacing:.06em}
.site-footer .brand span{color:#fff}
.footer-about p{font-size:.95rem;margin-top:16px}
.footer-links{list-style:none;display:grid;gap:10px}
.footer-links a{color:rgba(255,255,255,.78);font-size:.95rem}
.footer-links a:hover{color:var(--gold-light)}
.footer-contact{list-style:none;display:grid;gap:12px;font-size:.95rem}
.footer-contact a:hover{color:var(--gold-light)}
.socials{display:flex;gap:14px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:.2s}
.socials a:hover{background:var(--gold)}
.socials svg{width:18px;height:18px;fill:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;text-align:center;font-size:.88rem;color:rgba(255,255,255,.6)}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .split,.contact-grid{grid-template-columns:1fr;gap:36px}
  .split--reverse .split-media{order:0}
  .cards-3,.programs,.donate-options{grid-template-columns:1fr}
  .values-grid,.team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:34px}
  .nav-links{
    position:fixed;top:78px;left:0;right:0;
    height:calc(100vh - 78px);height:calc(100dvh - 78px);
    background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:8px 0 0;border-top:1px solid var(--line);
    box-shadow:0 12px 30px rgba(40,20,70,.10);
    display:none;overflow-y:auto;z-index:1200;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%;padding:0;border-bottom:1px solid var(--line)}
  .nav-links li a{
    display:block;width:100%;padding:18px 26px;font-size:1.08rem;font-weight:600;
  }
  .nav-links li a.active::after{display:none}
  .nav-links li a.active{color:var(--purple)}
  /* contact block pinned to the bottom of the panel */
  .nav-mobile-foot{
    display:flex !important;margin-top:auto;border-bottom:none !important;
    padding:24px 26px 28px !important;background:var(--bg-soft);
    flex-direction:column;gap:14px;
  }
  .nav-mobile-foot .nmf-cta{
    display:block;text-align:center;background:var(--gold);color:#fff;
    padding:14px;border-radius:50px;font-family:var(--font-head);font-weight:600;
    font-size:1rem;text-decoration:none;
  }
  .nav-mobile-foot .nmf-row{
    display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.92rem;
  }
  .nav-mobile-foot .nmf-row a{color:var(--purple);font-weight:600;word-break:break-all}
  .nav-mobile-foot .nmf-org{
    font-family:var(--font-head);font-weight:600;color:var(--purple);font-size:.9rem;line-height:1.4;
  }
  .nav-phone{display:none}
  .nav-toggle{display:flex}
  /* hamburger -> X when menu open */
  .nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  body.nav-open{overflow:hidden}
  .form-grid{grid-template-columns:1fr}
  /* Dropdown becomes flat list on mobile */
  .has-dropdown>a::after{content:" ▾"}
  .dropdown{
    position:static;display:flex;flex-direction:column;
    box-shadow:none;border:none;border-radius:0;
    background:var(--bg-soft);padding:4px 0 4px 16px;min-width:unset;
  }
  .dropdown a{padding:9px 8px;font-size:.9rem;color:var(--muted);border-bottom:none}
  .has-dropdown:hover .dropdown{display:flex} /* always show on mobile */
  .has-dropdown .dropdown{display:flex}       /* always visible in open menu */
}
@media(max-width:520px){
  .section{padding:58px 0}

  /* Header: hide brand text to save space; Donate button stays */
  .brand span{display:none}

  /* Footer: always show "WCELUX" text even on small screens */
  .site-footer .brand span{display:inline !important}

  /* Hero: reduce vertical padding and keep side margins */
  .hero-inner{padding:70px 24px 80px}

  .form-card{padding:26px}
  .member{flex-direction:column;align-items:center;text-align:center}
  .hero .logo-badge{height:130px;width:130px;padding:14px;margin-bottom:20px}
}
