/* ============================================
   COMPONENTS — nav, cards, modal, footer, newsletter
   ============================================ */

/* ── NAV ── */

nav{position:sticky;top:0;z-index:1000;background:var(--dark1);border-bottom:1px solid var(--dark3)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:70px}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo img{height:56px;filter:brightness(1.1)}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-links a{color:rgba(255,255,255,.75);text-decoration:none;font-size:.85rem;font-weight:500;padding:.45rem .9rem;border-radius:6px;transition:all .2s;letter-spacing:.02em}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(64,181,189,.15)}
.nav-donate{background:var(--gold)!important;color:var(--dark1)!important;font-weight:600!important;border-radius:6px!important;padding:.45rem 1.1rem!important}
.nav-donate:hover{background:#b8913e!important}

/* ── LANGUAGE SELECT ── */
.lang-select{position:relative;margin-left:.5rem}
.lang-trigger{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.06);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:.4rem .7rem;font-family:inherit;font-size:.8rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .2s}
.lang-trigger:hover{background:rgba(64,181,189,.18);color:#fff;border-color:rgba(64,181,189,.35)}
.lang-trigger svg{opacity:.85}
.lang-menu{display:none;position:absolute;top:calc(100% + .4rem);right:0;background:var(--dark1);border:1px solid var(--dark3);border-radius:8px;padding:.35rem;min-width:180px;box-shadow:0 10px 30px rgba(0,0,0,.4);max-height:70vh;overflow-y:auto;z-index:1001}
.lang-menu.open{display:block}
.lang-menu button{display:block;width:100%;text-align:left;background:transparent;border:none;color:rgba(255,255,255,.78);font-family:inherit;font-size:.83rem;padding:.5rem .75rem;border-radius:5px;cursor:pointer;transition:all .15s}
.lang-menu button:hover{background:rgba(64,181,189,.15);color:#fff}

/* Hide Google Translate banner / tooltips */
.goog-te-banner-frame.skiptranslate,.goog-te-gadget-icon,.goog-tooltip,.goog-tooltip:hover,.goog-text-highlight{display:none!important;visibility:hidden!important;box-shadow:none!important;background:transparent!important}
body{top:0!important}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:.3s}
@media(max-width:900px){
  .nav-links{display:none;position:absolute;top:70px;left:0;right:0;background:var(--dark1);flex-direction:column;padding:1rem 2rem;gap:.25rem;border-bottom:1px solid var(--dark3)}
  .nav-links.open{display:flex}
  .hamburger{display:flex}
}

/* ── SECTION SHARED ── */

.section{padding:6rem 2rem}
.section-inner{max-width:1200px;margin:0 auto}
.section-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--deep-teal);margin-bottom:.75rem}
.section-title{font-family:var(--h);font-size:clamp(2rem,3.5vw,3rem);font-weight:600;color:var(--dark-text);line-height:1.2;margin-bottom:1rem}
.section-title em{color:var(--teal);font-style:italic}
.section-sub{color:var(--mid);font-size:1rem;line-height:1.75;max-width:600px}
.gold-divider{width:60px;height:3px;background:var(--gold);border-radius:2px;margin:1.25rem 0}

/* ── COMING SOON BADGE ── */

.coming-soon-banner{background:var(--dark2);border:1px solid rgba(201,168,76,.3);border-radius:16px;padding:2rem 2.5rem;text-align:center;margin-top:3rem;position:relative;overflow:hidden}
.coming-soon-banner::before{content:'';position:absolute;top:-40px;right:-40px;width:150px;height:150px;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 70%);border-radius:50%}
.coming-soon-banner .cs-tag{display:inline-block;background:rgba(201,168,76,.2);color:var(--gold);font-size:.72rem;font-weight:600;padding:.3rem .9rem;border-radius:20px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}
.coming-soon-banner h3{font-family:var(--h);color:#fff;font-size:1.8rem;margin-bottom:.5rem}
.coming-soon-banner p{color:rgba(255,255,255,.6);font-size:.9rem;max-width:500px;margin:0 auto}
.coming-soon-programs{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
@media(max-width:768px){.coming-soon-programs{grid-template-columns:1fr}}
.cs-program-pill{background:rgba(64,181,189,.08);border:1px solid rgba(64,181,189,.2);border-radius:10px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem}
.cs-icon{width:36px;height:36px;background:rgba(64,181,189,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cs-icon svg{width:18px;height:18px;stroke:var(--teal);fill:none;stroke-width:2}
.cs-program-pill span{color:rgba(255,255,255,.8);font-size:.85rem;font-weight:500}

/* ── PROGRAM CARDS ── */

.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
@media(max-width:900px){.programs-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.programs-grid{grid-template-columns:1fr}}
.program-card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:.25s;position:relative}
.program-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(42,143,151,.12)}
.program-card img{width:100%;height:200px;object-fit:cover}
.program-card-body{padding:1.5rem}
.program-card-body h4{font-family:var(--h);font-size:1.3rem;font-weight:600;color:var(--dark-text);margin-bottom:.5rem}
.program-card-body p{color:var(--mid);font-size:.88rem;line-height:1.65}
.program-card-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.program-link{color:var(--deep-teal);font-size:.85rem;font-weight:600;text-decoration:none;display:flex;align-items:center;gap:.35rem}
.program-link:hover{color:var(--teal)}
.cs-badge{background:rgba(201,168,76,.12);color:#9c7535;font-size:.72rem;font-weight:600;padding:.25rem .75rem;border-radius:20px;letter-spacing:.06em;border:1px solid rgba(201,168,76,.25)}

/* ── STATS BAR ── */

.stats-bar{background:var(--dark2);border-top:2px solid var(--deep-teal);border-bottom:2px solid var(--deep-teal)}
.stats-bar-inner{max-width:1200px;margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
@media(max-width:768px){.stats-bar-inner{grid-template-columns:repeat(2,1fr)}}
.stat-item .stat-num{font-family:var(--h);font-size:2.8rem;font-weight:700;color:var(--teal)}
.stat-item .stat-label{font-size:.82rem;color:rgba(255,255,255,.55);margin-top:.25rem}

/* ── VOLUNTEER MODAL ── */

.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2000;display:none;justify-content:center;align-items:flex-start;overflow-y:auto;padding:2rem 1rem}
.modal-backdrop.open{display:flex}
.modal-box{background:var(--light);border-radius:16px;width:100%;max-width:720px;overflow:hidden;margin:auto;position:relative;animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:.2s}
.modal-close:hover{background:rgba(255,255,255,.25)}
.vol-form-wrap{font-family:var(--b);padding:0}
.vol-form-header{background:#004E4A;padding:2rem;border-top:8px solid #C4941F}
.vol-form-header h1{color:#fff;font-size:1.4rem;font-weight:500;margin-bottom:.4rem;font-family:var(--b)}
.vol-form-header p{color:rgba(255,255,255,.75);font-size:.82rem;line-height:1.6}
.vol-badge{display:inline-block;background:rgba(196,148,31,.25);color:#E8AE2C;font-size:.7rem;padding:.2rem .65rem;border-radius:4px;margin-bottom:.75rem;letter-spacing:.03em;font-weight:600}
.vol-section{background:#fff;border:0.5px solid #D4E8EA;padding:1.5rem 2rem;margin:0;border-bottom:0}
.vol-section+.vol-section{border-top:1px solid var(--border)}
.vol-section:last-child{border-radius:0 0 16px 16px}
.vol-sec-title{font-size:.78rem;font-weight:600;color:#004E4A;border-bottom:2px solid #0ABAB5;padding-bottom:.4rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}
.vol-field{margin-bottom:1rem}
.vol-field label{display:block;font-size:.82rem;font-weight:500;color:var(--dark-text);margin-bottom:.35rem}
.vol-field input[type=text],.vol-field input[type=email],.vol-field input[type=tel],.vol-field input[type=url],.vol-field textarea{width:100%;border:none;border-bottom:1.5px solid #c5dde0;background:transparent;padding:.3rem 0;font-size:.85rem;color:var(--mid);outline:none;font-family:var(--b)}
.vol-field textarea{resize:vertical;min-height:70px;border:1px solid #c5dde0;padding:.5rem;border-radius:4px}
.vol-grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.vol-grid2{grid-template-columns:1fr}}
.vol-radio,.vol-check{display:flex;align-items:flex-start;gap:.5rem;margin:.35rem 0;font-size:.82rem;color:var(--dark-text);line-height:1.4}
.vol-radio input,.vol-check input{accent-color:#0ABAB5;margin-top:2px;flex-shrink:0}
.vol-req{color:#c0392b;margin-left:2px}
.vol-avail-table{width:100%;border-collapse:collapse;font-size:.78rem;margin-top:.5rem}
.vol-avail-table th{text-align:center;font-weight:500;font-size:.7rem;color:var(--mid);padding:.3rem .5rem;border-bottom:1px solid var(--border)}
.vol-avail-table th:first-child{text-align:left}
.vol-avail-table td{text-align:center;padding:.35rem .5rem;border-bottom:0.5px solid var(--border)}
.vol-avail-table td:first-child{text-align:left;font-size:.78rem;color:var(--dark-text)}
.vol-avail-table input[type=checkbox]{accent-color:#0ABAB5}
.vol-role-card{border:0.5px solid var(--border);border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem}
.vol-role-title{font-size:.82rem;font-weight:600;color:#004E4A;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}
.vol-role-desc{font-size:.75rem;color:var(--mid);line-height:1.4;margin-bottom:.5rem}
.vol-role-skill{display:flex;gap:1rem;font-size:.75rem;color:var(--mid)}
.vol-waiver{background:#f5fafb;border-left:3px solid #0ABAB5;border-radius:0 6px 6px 0;padding:.75rem 1rem;font-size:.78rem;color:var(--mid);line-height:1.6;margin-bottom:.75rem}
.vol-waiver strong{color:var(--dark-text)}
.vol-gold-note{background:#FAEEDA;color:#633806;font-size:.78rem;padding:.65rem 1rem;border-radius:6px;line-height:1.5;margin-top:.75rem;border-left:3px solid #C4941F}
.vol-submit{background:#004E4A;color:#fff;border:none;border-radius:6px;padding:.75rem 2rem;font-size:.9rem;font-weight:500;cursor:pointer;margin-top:1rem;font-family:var(--b);transition:.2s}
.vol-submit:hover{background:#006460}

/* ── NEWSLETTER ── */

.newsletter-section{background:var(--dark2);padding:4rem 2rem}
.newsletter-inner{max-width:600px;margin:0 auto;text-align:center}
.newsletter-inner h3{font-family:var(--h);color:#fff;font-size:2rem;margin-bottom:.5rem}
.newsletter-inner p{color:rgba(255,255,255,.55);font-size:.9rem;margin-bottom:1.75rem}
.newsletter-form{display:flex;gap:.75rem;max-width:450px;margin:0 auto}
.newsletter-form input{flex:1;padding:.8rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);color:#fff;font-size:.9rem;font-family:var(--b);outline:none}
.newsletter-form input::placeholder{color:rgba(255,255,255,.35)}
.newsletter-form input:focus{border-color:var(--teal)}
.newsletter-form button{background:var(--teal);color:#fff;border:none;border-radius:8px;padding:.8rem 1.5rem;font-size:.9rem;font-weight:600;cursor:pointer;font-family:var(--b);white-space:nowrap;transition:.2s}
.newsletter-form button:hover{background:var(--deep-teal)}

/* ── FOOTER ── */

footer{background:var(--dark1);border-top:1px solid var(--dark3);padding:4rem 2rem 2rem}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
@media(max-width:900px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-inner{grid-template-columns:1fr}}
.footer-brand img{height:50px;margin-bottom:1rem;opacity:.9}
.footer-brand p{color:rgba(255,255,255,.45);font-size:.82rem;line-height:1.65;max-width:280px}
.footer-col h5{color:var(--teal);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul li a{color:rgba(255,255,255,.5);text-decoration:none;font-size:.83rem;transition:.2s}
.footer-col ul li a:hover{color:var(--teal)}
.footer-col .contact-item{color:rgba(255,255,255,.5);font-size:.82rem;margin-bottom:.5rem;display:flex;align-items:flex-start;gap:.5rem}
.footer-bottom{border-top:1px solid var(--dark3);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{color:rgba(255,255,255,.3);font-size:.78rem}
.social-links{display:flex;gap:.75rem}
.social-link{width:36px;height:36px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:.2s;text-decoration:none}
.social-link:hover{background:rgba(64,181,189,.15);border-color:var(--teal)}
.social-link svg{width:16px;height:16px;fill:rgba(255,255,255,.5)}
.social-link:hover svg{fill:var(--teal)}
