:root{
    --ink:#1c1410; --ink-soft:#574d44; --cream:#fbf6ec; --cream-2:#f4ecdd; --paper:#fff;
    --coral:#ef5b2b; --coral-deep:#d8451a; --teal:#0f3d3e; --teal-2:#155356; --gold:#e3a72f; --gold-soft:#f3d79a;
    --green:#1f8a4c; --red:#d8451a; --line:rgba(28,20,16,.12);
    --shadow-sm:0 2px 10px rgba(28,20,16,.06);
    --flurvy:0 24px 60px -22px rgba(15,61,62,.30), 0 8px 18px -10px rgba(15,61,62,.18);
    --flurvy-lg:0 44px 90px -30px rgba(15,61,62,.45);
    --r:30px; --maxw:1180px;
    --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
  body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.02em;color:var(--teal)}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,28px)}
  .eyebrow{font-weight:700;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);display:inline-flex;align-items:center;gap:.6em}
  .eyebrow::before{content:"";width:24px;height:2px;background:currentColor}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:700;font-size:.96rem;padding:.9em 1.55em;border-radius:100px;cursor:pointer;border:none;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s;line-height:1}
  .btn svg{width:18px;height:18px}
  .btn-primary{background:var(--coral);color:#fff;box-shadow:0 12px 26px -10px rgba(239,91,43,.7)}
  .btn-primary:hover{background:var(--coral-deep);transform:translateY(-3px)}
  .btn-ghost{background:transparent;color:var(--teal);border:1.5px solid var(--line)}
  .btn-ghost:hover{border-color:var(--teal);background:#fff;transform:translateY(-3px)}
  .btn-light{background:#fff;color:var(--teal)} .btn-light:hover{transform:translateY(-3px);box-shadow:var(--flurvy)}
  .btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)} .btn-outline-light:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
  .btn[disabled]{opacity:.65;cursor:not-allowed;transform:none}

  .appeal{background:var(--ink);color:#fff;font-size:.85rem;text-align:center;padding:9px 16px;display:flex;justify-content:center;gap:.6em;align-items:center;flex-wrap:wrap}
  .appeal b{color:var(--gold)} .appeal a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:3px}

  header{position:sticky;top:0;z-index:1000}
  .navbar{background:rgba(251,246,236,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:.3s}
  header.scrolled .navbar{background:rgba(255,255,255,.93);box-shadow:0 10px 30px -16px rgba(15,61,62,.3)}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0}
  .brand{display:flex;align-items:center;gap:11px}
  .logo{width:44px;height:44px;flex:0 0 auto}
  .brand b{font-family:var(--serif);font-size:1.1rem;color:var(--teal);line-height:1;display:block}
  .brand .sub{display:block;white-space:nowrap;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);font-weight:700}
  .navlinks{display:flex;align-items:center;gap:2px;list-style:none}
  .navlinks a{font-size:.9rem;font-weight:600;padding:.5em .66em;border-radius:100px;color:var(--ink-soft);transition:.2s;white-space:nowrap}
  .navlinks a:hover{color:var(--teal);background:rgba(15,61,62,.07)}
  .nav-cta{display:flex;align-items:center;gap:10px}
  .nav-cta .btn{white-space:nowrap}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
  .burger span{width:24px;height:2.4px;background:var(--teal);border-radius:2px}

  /* SLIDING HERO */
  .slider{position:relative;overflow:hidden}
  .track{display:flex;transition:transform .8s cubic-bezier(.65,0,.35,1)}
  .slide{min-width:100%;position:relative;display:flex;align-items:center}
  .slide .bg{position:absolute;inset:0;background-size:cover;background-position:center;background-color:var(--teal)}
  .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(11,38,39,.86) 0%,rgba(15,61,62,.66) 45%,rgba(15,61,62,.30) 100%)}
  .slide .content{position:relative;z-index:2;color:#fff;padding:clamp(48px,9vw,110px) 0;width:100%;min-height:clamp(500px,78vh,740px);display:flex;flex-direction:column;justify-content:center}
  .slide .inner{max-width:40rem}
  .slide .eyebrow{color:var(--gold)}
  .slide h1{color:#fff;font-size:clamp(2.4rem,5.4vw,4.4rem);margin:.3em 0 .45em}
  .slide h1 em{font-style:italic;color:var(--gold);font-weight:500}
  .slide p{font-size:clamp(1rem,1.6vw,1.18rem);color:rgba(255,255,255,.9);max-width:34em;margin-bottom:1.7em}
  .slide .cta-row{display:flex;gap:12px;flex-wrap:wrap}
  .slide .reg-line{margin-top:22px;font-size:.84rem;color:rgba(255,255,255,.78)} .slide .reg-line b{color:#fff}
  .s-arrows{position:absolute;z-index:5;bottom:clamp(20px,4vw,40px);right:clamp(18px,4vw,40px);display:flex;gap:10px}
  /* static / fade hero */
  .slider[data-mode="static"] .s-arrows,.slider[data-mode="static"] .s-dots,
  .slider[data-mode="fade"] .s-arrows,.slider[data-mode="fade"] .s-dots{display:none}
  .slider[data-mode="fade"] .slide .bg{transition:opacity 1.4s ease;opacity:0}
  .slider[data-mode="fade"] .slide .bg.on{opacity:1}
  .float-card{position:absolute;left:clamp(18px,4vw,40px);bottom:clamp(20px,4vw,40px);z-index:5;background:#fff;border-radius:20px;padding:15px 19px;box-shadow:var(--flurvy);display:flex;align-items:center;gap:13px;max-width:260px}
  .float-card .fc-ic{width:46px;height:46px;border-radius:13px;background:var(--cream-2);display:grid;place-items:center;color:var(--coral);flex:0 0 auto}
  .float-card b{font-family:var(--serif);font-size:1.5rem;color:var(--teal);display:block;line-height:1}
  .float-card .fc-l{font-weight:800;font-size:.82rem;color:var(--teal);display:block}
  .float-card small{font-size:.74rem;color:var(--ink-soft)}
  @media(max-width:680px){.float-card{display:none}}
  .s-arrows button{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,.45);background:rgba(255,255,255,.1);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s;backdrop-filter:blur(6px)}
  .s-arrows button:hover{background:#fff;color:var(--teal)}
  .s-dots{position:absolute;z-index:5;bottom:clamp(24px,4vw,46px);left:50%;transform:translateX(-50%);display:flex;gap:9px}
  .s-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;transition:.3s;padding:0}
  .s-dots button.on{background:var(--gold);width:30px;border-radius:100px}

  section{position:relative}
  .sec{padding:clamp(56px,8vw,92px) 0}
  .sec-head{max-width:60ch;margin-bottom:clamp(34px,5vw,50px)}
  .sec-head.center{margin-inline:auto;text-align:center}
  .sec-head h2{font-size:clamp(1.9rem,4vw,3rem);margin:.34em 0 .4em}
  .sec-head p{color:var(--ink-soft);font-size:1.05rem}

  /* OPACITY BG BAND */
  .band{position:relative;color:#fff;overflow:hidden}
  .band .band-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-color:var(--teal)}
  .band .band-ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(15,61,62,.92),rgba(15,61,62,.74))}
  .band > .wrap{position:relative;z-index:2}
  .band h2,.band h3{color:#fff} .band .sec-head p{color:rgba(255,255,255,.82)} .band .eyebrow{color:var(--gold)}

  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:clamp(34px,5vw,46px) 0}
  .stat{text-align:center}
  .stat b{font-family:var(--serif);font-size:clamp(2rem,4vw,2.9rem);color:var(--gold);display:block;line-height:1}
  .stat small{font-size:.86rem;color:rgba(255,255,255,.8);display:block;margin-top:.4em}

  .about{background:var(--paper)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,56px);align-items:center}
  .media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--flurvy);background:linear-gradient(135deg,var(--teal),var(--coral));aspect-ratio:1/1}
  .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .4s}
  .about-media{position:relative}
  .about-media .stamp{position:absolute;right:-16px;bottom:-16px;width:118px;height:118px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;text-align:center;font-family:var(--serif);box-shadow:var(--flurvy);padding:14px;line-height:1.1}
  .about-media .stamp b{font-size:1.5rem;display:block;line-height:1} .about-media .stamp small{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;opacity:.92;display:block;margin-top:3px}
  .vm{display:grid;gap:16px;margin:24px 0 26px}
  .vm-item{padding:20px 22px;border-radius:20px;background:var(--cream);border:1px solid var(--line)}
  .vm-item h4{color:var(--coral);font-family:var(--sans);font-weight:800;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.45em}
  .vm-item p{font-family:var(--serif);font-size:1.1rem;color:var(--teal);line-height:1.4;font-weight:400}
  .values{display:flex;flex-wrap:wrap;gap:9px}
  .chip{display:inline-flex;align-items:center;gap:.5em;padding:.5em 1em;border-radius:100px;background:var(--cream-2);font-weight:700;font-size:.88rem;color:var(--teal);border:1px solid var(--line)}
  .chip i{width:7px;height:7px;border-radius:50%;background:var(--coral)}

  .prog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
  .card{background:var(--paper);border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--flurvy);transition:transform .35s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column}
  .card:hover{transform:translateY(-8px)}
  .card-img{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--teal),var(--gold));overflow:hidden}
  .card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s,opacity .4s}
  .card:hover .card-img img{transform:scale(1.07)}
  .card-tag{position:absolute;left:13px;top:13px;background:rgba(255,255,255,.94);color:var(--teal);font-weight:800;font-size:.72rem;padding:.42em .8em;border-radius:100px}
  .card-body{padding:24px;display:flex;flex-direction:column;flex:1}
  .card-body h3{font-size:1.32rem;margin-bottom:.45em}
  .card-body p{font-size:.93rem;color:var(--ink-soft);flex:1}
  .card-body a{margin-top:14px;font-weight:800;color:var(--coral);display:inline-flex;gap:.4em;align-items:center;align-self:flex-start}

  .appeal-feature{background:var(--cream-2)}
  .af-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,50px);align-items:center}
  .af-box{background:var(--paper);border-radius:var(--r);padding:clamp(24px,4vw,34px);border:1px solid var(--line);box-shadow:var(--flurvy);margin-top:24px}
  .bar{height:14px;border-radius:100px;background:var(--cream-2);overflow:hidden;margin:16px 0 10px}
  .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--coral),var(--gold));border-radius:100px;width:0;transition:width 1.2s ease}
  .af-nums{display:flex;justify-content:space-between;font-size:.9rem;color:var(--ink-soft)}
  .af-nums b{color:var(--teal);font-family:var(--serif);font-size:1.12rem}

  .ways{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
  .way{background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.16);border-radius:24px;padding:28px 22px;transition:.3s}
  .way:hover{background:#fff;color:var(--teal);transform:translateY(-7px)}
  .way:hover small{color:var(--ink-soft)} .way:hover .wic{background:var(--cream-2);color:var(--coral)}
  .wic{width:54px;height:54px;border-radius:16px;background:rgba(227,167,47,.2);color:var(--gold);display:grid;place-items:center;margin-bottom:16px;font-size:1.5rem}
  .way h3{color:inherit;font-size:1.22rem;margin-bottom:.3em} .way:hover h3{color:var(--teal)}
  .way small{font-size:.85rem;color:rgba(255,255,255,.72);display:block;margin-bottom:16px}
  .way .btn{width:100%}

  .stories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
  .story{background:var(--paper);border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--flurvy);transition:.3s}
  .story:hover{transform:translateY(-6px)}
  .story-body{padding:22px}
  .story-body .tag{font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
  .story-body h3{font-size:1.18rem;margin:.4em 0 .3em}
  .story-body p{font-size:.9rem;color:var(--ink-soft)}

  .trust{background:var(--paper)}
  .trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
  .trust-item{background:var(--cream);border-radius:22px;padding:26px;border:1px solid var(--line)}
  .trust-item .ti{width:46px;height:46px;border-radius:13px;background:var(--cream-2);color:var(--teal);display:grid;place-items:center;margin-bottom:13px;font-size:1.3rem}
  .trust-item h4{font-size:1.08rem;color:var(--teal);margin-bottom:.3em}
  .trust-item p{font-size:.87rem;color:var(--ink-soft)}

  /* REGISTRATION FORM */
  .register{background:var(--cream-2)}
  .reg-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(30px,5vw,54px);align-items:start}
  .reg-aside h2{font-size:clamp(1.9rem,4vw,2.8rem);margin:.3em 0 .4em}
  .reg-aside p{color:var(--ink-soft)}
  .reg-points{display:grid;gap:14px;margin-top:26px}
  .reg-point{display:flex;gap:13px;align-items:flex-start}
  .reg-point .rp{width:40px;height:40px;border-radius:12px;background:var(--paper);border:1px solid var(--line);color:var(--coral);display:grid;place-items:center;flex:0 0 auto}
  .reg-point b{display:block;color:var(--teal);font-family:var(--serif);font-size:1.05rem}
  .reg-point span{font-size:.9rem;color:var(--ink-soft)}
  form.card-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,4vw,34px);box-shadow:var(--flurvy)}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .field{margin-bottom:16px;position:relative}
  .field.full{grid-column:1/-1}
  .field label{display:block;font-weight:700;font-size:.84rem;color:var(--teal);margin-bottom:6px}
  .field label .req{color:var(--coral)}
  .field input,.field select,.field textarea{width:100%;padding:.85em 1em;border-radius:14px;border:1.5px solid var(--line);background:var(--cream);font-family:var(--sans);font-size:.96rem;color:var(--ink);transition:.2s}
  .field textarea{resize:vertical;min-height:110px}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--coral);background:#fff;box-shadow:0 0 0 4px rgba(239,91,43,.12)}
  .field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--red);background:#fdf3f0}
  .field.valid input,.field.valid select,.field.valid textarea{border-color:var(--green)}
  .err{display:none;color:var(--red);font-size:.78rem;margin-top:5px;font-weight:600}
  .field.invalid .err{display:block}
  .ok-tick{position:absolute;right:14px;top:38px;color:var(--green);opacity:0;transition:.2s}
  .field.valid .ok-tick{opacity:1}
  .form-note{font-size:.8rem;color:var(--ink-soft);margin-top:8px;text-align:center}
  .success-panel{display:none;text-align:center;padding:14px 6px}
  .success-panel .sp-ic{width:72px;height:72px;border-radius:50%;background:rgba(31,138,76,.12);color:var(--green);display:grid;place-items:center;margin:0 auto 18px}
  .success-panel h3{font-size:1.5rem;margin-bottom:.3em}
  .success-panel p{color:var(--ink-soft);margin-bottom:18px}
  .spinner{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
  @keyframes spin{to{transform:rotate(360deg)}}

  .news .news-box{border-radius:var(--r);padding:clamp(28px,5vw,46px);color:#fff;display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(24px,4vw,36px);align-items:center;box-shadow:var(--flurvy);position:relative;overflow:hidden}
  .news .news-box .band-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-color:var(--teal)}
  .news .news-box .band-ov{position:absolute;inset:0;background:linear-gradient(150deg,rgba(15,61,62,.92),rgba(21,83,86,.8))}
  .news .news-box > *{position:relative;z-index:2}
  .news h2{color:#fff;font-size:clamp(1.6rem,3vw,2rem)} .news p{color:rgba(255,255,255,.82);margin-top:.4em}
  .news-form{display:flex;gap:10px;flex-wrap:wrap}
  .news-form input{flex:1;min-width:180px;padding:.9em 1.1em;border-radius:100px;border:none;font-family:var(--sans);font-size:.95rem}
  .news-form input:focus{outline:3px solid var(--gold)}

  footer{background:var(--ink);color:rgba(255,255,255,.72);padding:clamp(48px,7vw,64px) 0 110px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(28px,4vw,38px);margin-bottom:42px}
  footer h5{color:#fff;font-family:var(--serif);font-size:1.1rem;margin-bottom:16px}
  footer ul{list-style:none;display:grid;gap:9px}
  footer ul a,footer ul li{color:rgba(255,255,255,.66);font-size:.92rem} footer ul a:hover{color:var(--coral)}
  .foot-about p{font-size:.92rem;margin:14px 0;max-width:34ch}
  .cac{display:inline-flex;align-items:center;gap:.5em;font-size:.8rem;font-weight:700;color:var(--gold);background:rgba(227,167,47,.12);padding:.5em 1em;border-radius:100px}
  .socials{display:flex;gap:9px;margin-top:14px}
  .socials a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;transition:.25s}
  .socials a:hover{background:var(--coral);transform:translateY(-4px)}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.83rem}

  .mobnav{position:fixed;left:0;right:0;bottom:0;z-index:1200;display:none;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 10px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -10px 30px -16px rgba(15,61,62,.35)}
  .mobnav ul{list-style:none;display:flex;justify-content:space-around;align-items:flex-end}
  .mobnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.66rem;font-weight:700;color:var(--ink-soft);padding:4px 8px}
  .mobnav a svg{width:22px;height:22px}
  .mobnav a.fab{margin-top:-26px}
  .mobnav a.fab .fab-c{width:54px;height:54px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;box-shadow:0 12px 24px -8px rgba(239,91,43,.8);border:4px solid var(--cream)}
  .mobnav a.fab .fab-c svg{width:26px;height:26px} .mobnav a.fab span{color:var(--coral)}

  .toasts{position:fixed;z-index:3000;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;max-width:min(92vw,360px)}
  .toast{background:var(--paper);border:1px solid var(--line);border-left:5px solid var(--teal);border-radius:14px;padding:13px 16px;box-shadow:var(--flurvy);display:flex;gap:11px;align-items:flex-start;transform:translateX(120%);opacity:0;transition:transform .4s cubic-bezier(.2,.8,.2,1),opacity .4s}
  .toast.show{transform:none;opacity:1}
  .toast.success{border-left-color:var(--green)} .toast.error{border-left-color:var(--red)}
  .toast .t-ic{flex:0 0 auto;margin-top:1px}
  .toast.success .t-ic{color:var(--green)} .toast.error .t-ic{color:var(--red)} .toast.info .t-ic{color:var(--teal)}
  .toast b{display:block;font-family:var(--serif);color:var(--teal);font-size:1rem} .toast span{font-size:.86rem;color:var(--ink-soft)}

  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s cubic-bezier(.2,.8,.2,1)}
  .reveal.in{opacity:1;transform:none}

  @media(max-width:980px){
    .about-grid,.af-grid,.reg-grid,.news .news-box{grid-template-columns:1fr;gap:34px}
    .about-media{max-width:440px;margin:0 auto}
    .stats-grid{grid-template-columns:1fr 1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
    .nav-cta .btn-ghost{display:none}
    .mobnav{display:block}
  }
  /* Collapse the horizontal menu to the hamburger well before the links would
     get crammed, so the bar is always tidy. Full row only when it truly fits. */
  @media(max-width:1150px){
    .navlinks{display:none}
    .burger{display:flex}
    .navlinks.open{display:flex;position:absolute;top:70px;left:14px;right:14px;flex-direction:column;background:#fff;padding:12px;border-radius:22px;box-shadow:var(--flurvy);align-items:stretch;gap:2px;z-index:1100}
    .navlinks.open a{padding:.85em 1em;font-size:1rem}
  }
  @media(max-width:560px){
    .stats-grid,.foot-grid,.form-row{grid-template-columns:1fr}
    .s-dots{display:none}
  }

/* ===== inner pages ===== */
.page-hero{background:var(--paper);padding:clamp(48px,8vw,80px) 0 clamp(30px,4vw,40px);border-bottom:1px solid var(--line)}
.page-hero .eyebrow{justify-content:flex-start}
.page-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);margin-top:.3em}
.prose{max-width:74ch;font-size:1.05rem;color:var(--ink-soft)}
.prose h3{color:var(--teal);margin:1.4em 0 .4em;font-size:1.4rem}
.prose p{margin:0 0 1em}
.prose ul{margin:0 0 1em 1.2em}
.trustee-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:24px}
.trustee{background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:22px}
.trustee b{font-family:var(--serif);color:var(--teal);font-size:1.15rem;display:block}
.trustee span{font-size:.88rem;color:var(--coral);font-weight:700}
.trustee small{display:block;color:var(--ink-soft);margin-top:6px;font-size:.85rem}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,54px);align-items:start}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px;box-shadow:var(--flurvy)}
.contact-card .ci{display:flex;gap:13px;align-items:flex-start;margin-bottom:18px}
.contact-card .ci .cic{width:42px;height:42px;border-radius:12px;background:var(--cream-2);color:var(--coral);display:grid;place-items:center;flex:0 0 auto}
.contact-card .ci b{display:block;color:var(--teal);font-size:.92rem}
.contact-card .ci span{font-size:.9rem;color:var(--ink-soft)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}

/* ============================================================
   ONLINE SCHOOL (LMS)
   ============================================================ */
.btn.full{display:block;width:100%;text-align:center}
.btn.ghost-light{background:transparent;border:2px solid rgba(255,255,255,.55);color:#fff}
.back-link{display:inline-block;color:var(--teal);font-weight:700;margin-bottom:18px;font-size:.92rem}
.back-link.light{color:rgba(255,255,255,.85)}
.eyebrow.light{color:var(--gold-soft)}
.prose{line-height:1.75;color:var(--ink-soft)}
.prose p{margin:0 0 1em}

.learn-hero,.course-hero,.page-hero{background-size:cover;background-position:center;color:#fff;padding:84px 0}
.learn-hero{text-align:center;padding:96px 0}
.learn-hero h1{font-family:var(--serif);font-size:clamp(2rem,5vw,3.3rem);margin:.2em 0}
.learn-hero p{max-width:620px;margin:0 auto;opacity:.92;font-size:1.1rem}
.lh-actions{margin-top:26px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.page-hero h1{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem)}

.cat-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:-30px;position:relative;z-index:3;padding-bottom:6px}
.cat-chip{background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:10px 16px;font-weight:700;color:var(--teal);box-shadow:var(--shadow-sm);font-size:.9rem}
.cat-chip em{color:var(--coral);font-style:normal;margin-left:4px}

.section{padding:48px 0}
.sec-title{font-family:var(--serif);font-size:1.8rem;margin:.1em 0 1em}
.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.course-card{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.course-card:hover{transform:translateY(-4px);box-shadow:var(--flurvy)}
.cc-img{height:160px;background-size:cover;background-position:center;position:relative}
.cc-cat{position:absolute;left:12px;top:12px;background:var(--teal);color:#fff;font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:100px}
.cc-body{padding:18px}
.cc-body h3{font-size:1.12rem;color:var(--ink);margin:0 0 6px;line-height:1.3}
.cc-body p{color:var(--ink-soft);font-size:.9rem;margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cc-meta{display:flex;gap:12px;align-items:center;font-size:.82rem;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:12px}
.cc-free{margin-left:auto;color:var(--coral);font-weight:800}
.cc-prog{margin:6px 0 12px}
.cc-prog .bar,.cr-prog .bar,.ec-prog .bar{background:var(--cream);border-radius:100px;height:8px;overflow:hidden;margin-bottom:4px}
.cc-prog .bar>div,.cr-prog .bar>div,.ec-prog .bar>div{background:var(--coral);height:100%}

/* course detail */
.course-hero h1{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);margin:.1em 0;max-width:760px}
.ch-sub{font-size:1.1rem;opacity:.92;max-width:640px}
.ch-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px;font-weight:700;font-size:.9rem}
.course-layout{display:grid;grid-template-columns:1fr 340px;gap:36px;padding:48px 0;align-items:start}
.course-main .block{margin-bottom:34px}
.course-main h2{font-family:var(--serif);font-size:1.4rem;margin:0 0 14px;color:var(--teal)}
.ticks{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ticks li{padding-left:28px;position:relative;color:var(--ink-soft)}
.ticks li:before{content:"✓";position:absolute;left:0;top:0;color:#fff;background:var(--green);width:18px;height:18px;border-radius:50%;font-size:.7rem;display:grid;place-items:center}
.mod{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.mod-head{display:flex;justify-content:space-between;background:var(--cream);padding:12px 16px;font-size:.95rem}
.les{display:flex;align-items:center;gap:12px;padding:11px 16px;border-top:1px solid var(--line);font-size:.92rem}
.les-ic{color:var(--teal)}.les-t{flex:1}.les-min{font-size:.8rem}
.preview-tag{color:var(--coral);font-weight:700;font-size:.8rem}
.review{border-left:3px solid var(--gold);padding:4px 0 4px 16px;margin-bottom:16px}
.review .stars{color:var(--gold);letter-spacing:2px}
.course-side{position:sticky;top:90px}
.enroll-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--flurvy);padding:24px}
.ec-price{font-family:var(--serif);font-size:2rem;color:var(--coral);font-weight:800;margin-bottom:14px}
.ec-note{font-size:.8rem;margin-top:8px}
.ec-prog{margin-bottom:14px}
.ec-list{list-style:none;padding:16px 0 0;margin:16px 0 0;border-top:1px solid var(--line);display:grid;gap:8px;font-size:.9rem;color:var(--ink-soft)}

/* classroom */
.classroom{display:grid;grid-template-columns:300px 1fr;min-height:70vh}
.cr-side{background:var(--teal);color:#fff;padding:24px 18px;position:sticky;top:0;align-self:start;max-height:100vh;overflow-y:auto}
.cr-side .back-link{color:#fff;font-size:.9rem}
.cr-prog{margin:6px 0 18px}.cr-prog span{font-size:.8rem;opacity:.85}
.cr-mod{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;opacity:.7;margin:16px 0 6px}
.cr-les{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,.85);padding:8px 10px;border-radius:8px;font-size:.88rem;line-height:1.3}
.cr-les:hover{background:rgba(255,255,255,.08)}
.cr-les.cur{background:rgba(255,255,255,.16);color:#fff;font-weight:700}
.tick{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);display:grid;place-items:center;font-size:.7rem;flex-shrink:0}
.tick.on{background:var(--coral);border-color:var(--coral);color:#fff}
.cr-main{padding:40px clamp(20px,5vw,60px);max-width:880px}
.cr-main h1{font-family:var(--serif);font-size:1.9rem;color:var(--ink);margin:0 0 20px}
.cr-flash{background:var(--cream);border:1px solid var(--gold);border-radius:10px;padding:12px 16px;margin-bottom:18px;font-weight:600}
.cr-video{position:relative;padding-top:56.25%;border-radius:14px;overflow:hidden;margin-bottom:24px;background:#000}
.cr-video iframe{position:absolute;inset:0;width:100%;height:100%}
.cr-complete{margin-top:30px;border-top:1px solid var(--line);padding-top:24px}
.quiz{margin-top:10px}
.q{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:14px}
.q-t{margin:0 0 12px}
.q-opt{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:8px;margin-bottom:8px;cursor:pointer}
.q-opt:hover{border-color:var(--coral);background:var(--cream)}

/* auth */
.auth-wrap{min-height:72vh;display:grid;place-items:center;padding:48px 20px;background:var(--cream)}
.auth-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--flurvy);padding:36px;max-width:440px;width:100%}
.auth-card h1{font-family:var(--serif);font-size:1.7rem;margin:.2em 0}
.auth-err{background:#fde8e4;border:1px solid var(--coral);color:var(--coral-deep);padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:.9rem}
.auth-alt{margin-top:18px;font-size:.9rem;color:var(--ink-soft)}
.auth-alt a,.auth-card a{color:var(--coral);font-weight:700}
.auth-card form label{display:block;font-weight:700;font-size:.84rem;color:var(--teal);margin:14px 0 6px}
.auth-card form label:first-of-type{margin-top:6px}
.auth-card form input{display:block;width:100%;padding:.85em 1em;border-radius:14px;border:1.5px solid var(--line);background:var(--cream);font-family:var(--sans);font-size:.96rem;color:var(--ink);transition:.2s}
.auth-card form input:focus{outline:none;border-color:var(--coral);background:#fff;box-shadow:0 0 0 4px rgba(239,91,43,.12)}

/* certificate */
.cert-page{background:var(--cream);padding:40px 16px}
.cert{max-width:840px;margin:0 auto;background:#fff;border:2px solid var(--gold);border-radius:14px;padding:10px}
.cert-inner{border:2px solid var(--teal);border-radius:8px;padding:48px 40px;text-align:center}
.cert-seal{font-size:3rem}
.cert-org{font-family:var(--serif);font-size:1.4rem;color:var(--teal);font-weight:700;margin:8px 0 2px}
.cert-sub{letter-spacing:2px;text-transform:uppercase;font-size:.72rem;color:var(--ink-soft);margin-bottom:28px}
.cert-pre{color:var(--ink-soft);margin:18px 0 4px}
.cert-name{font-family:var(--serif);font-size:2.2rem;color:var(--coral);margin:0;border-bottom:2px solid var(--cream);display:inline-block;padding:0 24px 6px}
.cert-course{font-size:1.3rem;color:var(--ink);margin:8px 0}
.cert-meta{color:var(--ink-soft);font-size:.9rem}
.cert-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:44px;font-size:.82rem;color:var(--ink-soft)}
.cert-line{display:block;width:180px;border-top:1.5px solid var(--ink);margin-bottom:6px}
.cert-actions{text-align:center;margin-top:24px}
@media print{.site-header,.site-footer,.appeal-bar,.cert-actions,.mobile-nav,.fab,.fabs{display:none!important}.cert-page{padding:0;background:#fff}}

@media(max-width:900px){
  .course-layout{grid-template-columns:1fr}
  .course-side{position:static}
  .classroom{grid-template-columns:1fr}
  .cr-side{position:static;max-height:none}
  .ticks{grid-template-columns:1fr}
}

/* ===== v1.2.0 — Giving, Events, Get Involved ===== */
.give-grid{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.give-form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.give-form-card h3{font-family:var(--serif);font-size:1.12rem;margin:22px 0 12px;color:var(--teal)}
.give-form-card h3:first-of-type{margin-top:0}
.give-form-card label{display:block;font-weight:600;font-size:.86rem;margin:10px 0 5px;color:var(--ink)}
.give-form-card input,.give-form-card select,.give-form-card textarea{width:100%;padding:.72em .9em;border:1.5px solid var(--line);border-radius:12px;font:inherit;background:var(--cream);color:var(--ink)}
.give-form-card input:focus,.give-form-card select:focus,.give-form-card textarea:focus{outline:none;border-color:var(--coral)}
.amount-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}
.amt{padding:.95em .5em;border:1.5px solid var(--line);background:var(--cream);border-radius:12px;font-weight:800;font-size:1.05rem;color:var(--teal);cursor:pointer;transition:.15s}
.amt:hover{border-color:var(--coral)}
.amt.sel{background:var(--teal);color:#fff;border-color:var(--teal)}
.amt-custom{display:flex;align-items:center;gap:8px;margin-top:10px}
.amt-custom span{font-weight:800;color:var(--teal);font-size:1.1rem}
.freq{display:flex;gap:18px;margin-top:12px}
.radio{display:flex;align-items:center;gap:8px;font-weight:500!important;cursor:pointer}
.radio input{width:auto!important}
.pay-methods{display:grid;gap:10px}
.pay{display:flex;align-items:center;gap:10px;padding:.8em 1em;border:1.5px solid var(--line);border-radius:12px;cursor:pointer;background:var(--cream)}
.pay.sel{border-color:var(--coral);background:#fff;box-shadow:0 0 0 3px rgba(239,91,43,.12)}
.pay input{width:auto!important}
.give-submit{width:100%;justify-content:center;margin-top:22px;font-size:1.05rem}
.give-secure{text-align:center;color:var(--ink-soft);font-size:.82rem;margin-top:10px}
.give-aside{display:grid;gap:18px;position:sticky;top:90px}
.give-impact,.give-trust{background:var(--teal);color:#fff;border-radius:var(--r);padding:24px}
.give-trust{background:var(--gold-soft);color:var(--ink)}
.give-impact h4{font-family:var(--serif);font-size:1.15rem;margin-bottom:12px}
.give-impact ul{list-style:none;display:grid;gap:10px}
.give-impact li{padding-left:22px;position:relative;font-size:.92rem}
.give-impact li:before{content:"♥";position:absolute;left:0;color:var(--coral)}
.give-impact b{color:var(--gold)}
.form-flash{background:#e8f5e9;border:1px solid #a5d6a7;color:#256029;padding:.8em 1em;border-radius:12px;margin-bottom:16px;font-size:.9rem}
.receipt-row{display:flex;justify-content:space-between;padding:.7em 0;border-bottom:1px solid var(--line);font-size:.95rem}
.receipt-row:last-child{border-bottom:none}
.bank-box{margin-top:18px;padding:18px;background:var(--cream);border:1px dashed var(--coral);border-radius:14px}
.bank-box h4{font-family:var(--serif);margin-bottom:8px;color:var(--teal)}

.sec-title{font-family:var(--serif);font-size:1.5rem;color:var(--teal);margin-bottom:18px}
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.event-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:.18s}
.event-card:hover{transform:translateY(-3px);box-shadow:var(--flurvy)}
.event-card.past{opacity:.72}
.event-img{height:160px;background-size:cover;background-position:center;background-color:var(--cream)}
.event-body{padding:18px}
.event-body h3{font-family:var(--serif);font-size:1.18rem;color:var(--teal);margin:6px 0 8px}
.event-date{font-size:.8rem;font-weight:700;color:var(--coral);text-transform:uppercase;letter-spacing:.4px}
.event-loc{display:inline-block;margin-top:10px;font-size:.84rem;color:var(--ink-soft)}
.event-meta{display:flex;gap:20px;flex-wrap:wrap;margin-top:12px;color:var(--ink-soft);font-size:.92rem}
.event-detail-grid{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.event-hero-img{width:100%;border-radius:var(--r);margin-bottom:18px}
.seg-tabs{display:flex;gap:8px;margin-bottom:18px;background:var(--cream);padding:5px;border-radius:14px}
.seg{flex:1;padding:.7em;border:none;background:transparent;border-radius:10px;font-weight:600;color:var(--ink-soft);cursor:pointer}
.seg.sel{background:#fff;color:var(--teal);box-shadow:var(--shadow-sm)}

.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;background:var(--teal);color:#fff;padding:14px 18px;border-radius:16px;display:flex;align-items:center;gap:16px;box-shadow:var(--flurvy-lg);font-size:.9rem}
.cookie-bar a{color:var(--gold)}
.cookie-bar .btn{white-space:nowrap}
@media(max-width:820px){.give-grid,.event-detail-grid{grid-template-columns:1fr}.give-aside{position:static}.cookie-bar{flex-direction:column;align-items:stretch;text-align:center}}

/* v1.2.1 — currency toggle + fx note */
.cur-toggle{display:flex;align-items:center;gap:8px;margin-bottom:18px;font-size:.85rem;color:var(--ink-soft)}
.cur-toggle a{padding:.35em .8em;border:1.5px solid var(--line);border-radius:999px;text-decoration:none;color:var(--teal);font-weight:700}
.cur-toggle a.sel{background:var(--teal);color:#fff;border-color:var(--teal)}
.give-fx{margin-top:12px;font-size:.84rem;color:var(--ink-soft);background:var(--cream);border:1px dashed var(--line);border-radius:12px;padding:.7em .9em}
.give-fx #fxEcho{color:var(--coral);font-weight:700}

/* ============ JOIN US landing + PWA toast (v1.3.0) ============ */
.ju-hero{position:relative;overflow:hidden;background:var(--teal);color:#fff;isolation:isolate}
.ju-hero-bg{position:absolute;inset:0;z-index:-1;
  background:
   radial-gradient(900px 500px at 18% -10%,rgba(227,167,47,.30),transparent 60%),
   radial-gradient(800px 600px at 100% 120%,rgba(239,91,43,.42),transparent 55%),
   linear-gradient(150deg,#0b2627 0%,#0f3d3e 55%,#14595c 100%)}
.ju-hero-in{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  padding:clamp(56px,9vw,118px) 0 clamp(56px,8vw,104px)}
.ju-hero-copy .eyebrow{color:var(--gold)}
.ju-hero-copy h1{color:#fff;font-size:clamp(2.5rem,5.6vw,4.6rem);margin:.28em 0 .42em;line-height:1.04}
.ju-hero-copy h1 em{font-style:italic;color:var(--gold);font-weight:500}
.ju-hero-copy p{color:rgba(255,255,255,.9);font-size:clamp(1.02rem,1.5vw,1.2rem);max-width:34em;margin-bottom:1.7em}
.ju-hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.ju-reg{margin-top:22px;font-size:.84rem;color:rgba(255,255,255,.72)} .ju-reg b{color:#fff}
.ju-hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:28px;
  padding:34px 30px;text-align:center;backdrop-filter:blur(8px);box-shadow:var(--flurvy)}
.ju-heart{width:120px;height:120px;margin:0 auto 18px;filter:drop-shadow(0 14px 30px rgba(0,0,0,.35))}
.ju-hero-card b{display:block;font-family:var(--serif);font-size:1.55rem;color:#fff;line-height:1.15;margin-bottom:.4em}
.ju-hero-card span{color:rgba(255,255,255,.82);font-size:.95rem}
@media(max-width:860px){.ju-hero-in{grid-template-columns:1fr;gap:34px}.ju-hero-card{display:none}}

.ju-head{max-width:46rem;margin:0 auto clamp(30px,4vw,52px);text-align:center}
.ju-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin-top:.25em}
.ju-head .prose{margin:.7em auto 0;color:var(--ink-soft)}

.ju-values{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ju-value{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:26px 22px;box-shadow:var(--shadow-sm);transition:.3s}
.ju-value:hover{transform:translateY(-4px);box-shadow:var(--flurvy)}
.ju-vic{width:52px;height:52px;border-radius:15px;background:var(--cream-2);color:var(--coral);display:grid;place-items:center;margin-bottom:15px}
.ju-vic svg{width:26px;height:26px}
.ju-value h3{font-size:1.12rem;margin-bottom:.4em}
.ju-value p{font-size:.92rem;color:var(--ink-soft)}
@media(max-width:880px){.ju-values{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ju-values{grid-template-columns:1fr}}

.ju-stats{background:var(--teal);color:#fff}
.ju-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:clamp(40px,5vw,64px) 0;text-align:center}
.ju-stat b{display:block;font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);color:var(--gold);line-height:1}
.ju-stat span{color:rgba(255,255,255,.82);font-size:.92rem;margin-top:.4em;display:block}
@media(max-width:680px){.ju-stats-grid{grid-template-columns:repeat(2,1fr);gap:28px}}

.ju-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ju-pillar{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:26px 24px;display:flex;flex-direction:column;gap:8px;transition:.3s;color:inherit}
.ju-pillar:hover{transform:translateY(-5px);box-shadow:var(--flurvy);border-color:transparent}
.ju-tag{align-self:flex-start;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);background:var(--cream-2);padding:.4em .8em;border-radius:100px}
.ju-pillar h3{font-size:1.22rem}
.ju-pillar p{font-size:.92rem;color:var(--ink-soft);flex:1}
.ju-more{font-weight:700;color:var(--teal);font-size:.9rem}
@media(max-width:820px){.ju-pillars{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ju-pillars{grid-template-columns:1fr}}

.ju-ways-sec{background:var(--cream-2)}
.ju-ways{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ju-way{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:24px;transition:.3s}
.ju-way:hover{transform:translateY(-4px);box-shadow:var(--flurvy)}
.ju-way-ic{font-size:2rem;display:block;margin-bottom:10px}
.ju-way h3{font-size:1.14rem;margin-bottom:.35em}
.ju-way p{font-size:.9rem;color:var(--ink-soft);margin-bottom:1em}
.ju-way-cta{font-weight:700;color:var(--coral);font-size:.92rem}
@media(max-width:820px){.ju-ways{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ju-ways{grid-template-columns:1fr}}

.ju-story{background:var(--teal);color:#fff}
.ju-story-in{max-width:50rem;margin:0 auto;text-align:center;padding:clamp(48px,7vw,86px) 0;position:relative}
.ju-quote{font-family:var(--serif);font-size:5rem;color:var(--gold);line-height:.5;display:block;height:.4em}
.ju-story blockquote{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,2rem);line-height:1.35;color:#fff;font-style:italic;margin:.4em 0 .8em}
.ju-story cite{color:var(--gold-soft);font-style:normal;font-weight:700;letter-spacing:.04em}

.ju-form-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:start}
.ju-form-intro h2{font-size:clamp(1.8rem,3.2vw,2.6rem);margin:.25em 0 .4em}
.ju-checklist{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:12px}
.ju-checklist li{position:relative;padding-left:32px;color:var(--ink-soft);font-size:.95rem}
.ju-checklist li::before{content:"✓";position:absolute;left:0;top:-1px;width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;font-size:.78rem;font-weight:800;display:grid;place-items:center}
.ju-form-card{background:var(--paper);border:1px solid var(--line);border-radius:26px;padding:clamp(24px,3vw,34px);box-shadow:var(--flurvy)}
.ju-form-card label{display:block;font-weight:700;font-size:.84rem;color:var(--teal);margin:14px 0 5px}
.ju-form-card input,.ju-form-card select,.ju-form-card textarea{width:100%;padding:.8em .9em;border:1.5px solid var(--line);border-radius:13px;font:inherit;background:var(--cream);color:var(--ink)}
.ju-form-card input:focus,.ju-form-card select:focus,.ju-form-card textarea:focus{outline:none;border-color:var(--teal);background:#fff}
.ju-form-card .grp2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ju-role{display:flex;gap:8px;background:var(--cream-2);padding:5px;border-radius:100px;margin-bottom:8px}
.ju-role-btn{flex:1;border:none;background:transparent;font:inherit;font-weight:700;font-size:.9rem;color:var(--ink-soft);padding:.7em 1em;border-radius:100px;cursor:pointer;transition:.2s}
.ju-role-btn.on{background:var(--teal);color:#fff;box-shadow:var(--shadow-sm)}
@media(max-width:820px){.ju-form-grid{grid-template-columns:1fr;gap:30px}.ju-form-card .grp2{grid-template-columns:1fr}}

.ju-cta{position:relative;overflow:hidden;color:#fff;background:linear-gradient(135deg,var(--coral) 0%,var(--coral-deep) 60%,#b8390f 100%)}
.ju-cta-in{text-align:center;padding:clamp(52px,7vw,96px) 0;max-width:42rem;margin:0 auto}
.ju-cta h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.9rem)}
.ju-cta p{color:rgba(255,255,255,.92);margin:.6em 0 1.6em;font-size:1.05rem}
.ju-cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* PWA update toast */
.toast.pwa-toast{display:flex;align-items:center;gap:14px;background:var(--teal);color:#fff;padding:14px 18px;border-radius:14px;box-shadow:var(--flurvy);font-size:.92rem}
.toast .toast-btn{background:var(--gold);color:var(--teal);border:none;font:inherit;font-weight:800;padding:.5em 1.1em;border-radius:100px;cursor:pointer}

/* ============================================================
   v1.4.0 — mobile fixes (overflow, cookie bar, footer cards,
   fluid images + scroll reveal, bottom-nav spacing)
   ============================================================ */

/* Fix 1: kill any horizontal/sideways scroll site-wide */
html,body{overflow-x:hidden;max-width:100%}
*{box-sizing:border-box}

/* Fix 4: fluid images everywhere */
img{max-width:100%;height:auto}

/* Image scroll-reveal (fade + zoom + slight blur) */
.img-reveal{opacity:0;transform:scale(1.04);filter:blur(8px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1),filter .7s ease}
.img-reveal.in{opacity:1;transform:none;filter:none}
@media(prefers-reduced-motion:reduce){
  .img-reveal,.img-reveal.in{opacity:1;transform:none;filter:none;transition:none}
}

/* The bottom mobile nav appears at <=980px, so everything that must coexist
   with it (cookie bar, footer cards, nav spacing) shares that breakpoint. */
@media(max-width:980px){
  /* Fix 2: cookie/privacy popup must sit ABOVE the bottom mobile nav at every
     width where that nav is visible (previously only <=820px, leaving an
     821-980px gap where the popup was covered by the nav). */
  .cookie-bar{left:12px;right:12px;bottom:calc(84px + env(safe-area-inset-bottom,0px));z-index:1300;flex-direction:column;align-items:stretch;text-align:center}
  .cookie-bar .btn{width:100%}

  /* Fix 3: the desktop multi-column footer becomes tidy translucent cards,
     single column — on mobile devices only (desktop >=981px is untouched). */
  .foot-grid{grid-template-columns:1fr;gap:14px}
  .foot-grid > div{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:18px 20px}
  .foot-grid > .foot-about{background:transparent;border:0;padding:0}

  /* Fix 4: bottom-nav items must not clip; keep the bar tappable */
  .mobnav{z-index:1200}
  .mobnav li{min-width:0;flex:1 1 0}
  .mobnav a{font-size:.6rem;padding:4px 4px}
}

@media(max-width:820px){
  /* card grids collapse to a single fluid column (spec names + actual class names) */
  .prog-grid,.ways-grid,.ways,.stories-grid,.course-layout,.classroom-grid,.classroom,
  .course-grid,.event-grid,.trust-grid,.trustee-grid{grid-template-columns:1fr !important}
  .card{width:100%}
  /* a touch more breathing room at the edges on small screens */
  .wrap{padding-left:18px;padding-right:18px}
}

/* v1.4.4 — tidy, balanced header on small phones (keeps the brand on one line
   with comfortable margins and stops the Donate pill dominating the bar). */
@media(max-width:520px){
  .nav{gap:10px}
  .logo{width:40px;height:40px}
  .brand{gap:9px}
  .brand b{font-size:1.02rem}
  .brand .sub{font-size:.56rem;letter-spacing:.12em}
  .nav-cta{gap:8px}
  .nav-cta .btn-primary{padding:.58em 1.05em;font-size:.92rem}
  .burger{flex:0 0 auto}
}

/* membership form */
.mem-agree{display:flex;gap:10px;align-items:flex-start;margin-top:14px;font-size:.9rem;color:var(--ink);font-weight:500;cursor:pointer}
.mem-agree input{width:auto;margin-top:3px;flex:0 0 auto}
.mem-poslist{list-style:none;padding:0;margin:0}
.mem-poslist li{padding:10px 0 10px 22px;position:relative;border-bottom:1px solid rgba(255,255,255,.15)}
.mem-poslist li:last-child{border-bottom:none}
.mem-poslist li:before{content:"\2665";position:absolute;left:0;top:10px;color:var(--coral)}
.mem-poslist li b{display:block;color:var(--gold)}
.mem-poslist li span{display:block;font-size:.85rem;color:rgba(255,255,255,.85);margin-top:3px}

/* membership: position cards */
.sec-tint{background:#f4ecdf}
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin-top:8px}
.pos-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:26px;display:flex;flex-direction:column;gap:11px;transition:transform .2s,box-shadow .2s,border-color .2s}
.pos-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px -22px rgba(15,61,62,.4);border-color:transparent}
.pos-badge{width:48px;height:48px;border-radius:14px;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.35rem}
.pos-card h3{color:var(--teal);font-family:var(--serif);font-size:1.22rem;line-height:1.2;margin:0}
.pos-card p{color:var(--soft);font-size:.92rem;margin:0;flex:1}
.pos-card .pos-apply{align-self:flex-start;margin-top:4px}

/* members / team cards */
.team-group{margin-bottom:40px}
.team-group > h3{color:var(--teal);font-family:var(--serif);font-size:1.35rem;margin-bottom:18px;padding-bottom:9px;border-bottom:2px solid var(--line)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px}
.team-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 20px;text-align:center;transition:transform .2s,box-shadow .2s}
.team-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px -22px rgba(15,61,62,.4)}
.team-ava{width:66px;height:66px;border-radius:50%;margin:0 auto 13px;background:linear-gradient(135deg,var(--teal),var(--coral));color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.6rem}
.team-card b{display:block;color:var(--ink);font-size:1.04rem}
.team-card .role{display:block;color:var(--coral);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
.team-card .city{display:block;color:var(--soft);font-size:.85rem;margin-top:5px}

/* testimonials wall + rating */
.tm-grid{columns:3 280px;column-gap:22px}
@media(max-width:900px){.tm-grid{columns:2 260px}}
@media(max-width:600px){.tm-grid{columns:1}}
.tm-card{break-inside:avoid;background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;margin:0 0 22px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.tm-stars{color:var(--gold);letter-spacing:2px;font-size:.95rem;margin-bottom:8px}
.tm-card blockquote{margin:0;color:var(--ink);font-size:.98rem;line-height:1.6;position:relative}
.tm-card blockquote:before{content:"\201C";font-family:var(--serif);color:var(--coral);font-size:2.4rem;line-height:0;position:relative;top:.35em;margin-right:2px}
.tm-card figcaption{display:flex;align-items:center;gap:11px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.tm-card figcaption .tm-ava{width:42px;height:42px;border-radius:50%;flex:0 0 auto;background:linear-gradient(135deg,var(--teal),var(--coral));color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:700}
.tm-card figcaption b{display:block;color:var(--teal)}
.tm-card figcaption small{color:var(--soft);font-size:.82rem}
.tm-rate{display:flex;gap:4px;font-size:1.6rem;line-height:1}
.tm-rate button{background:none;border:none;cursor:pointer;color:var(--gold);padding:0 2px;line-height:1}
.tm-rate button.on{color:var(--gold)}
