/* ═══ ROTARY COIMBATORE SANGAMAM — SHARED CSS v5 ═══ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,700&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Bebas+Neue&display=swap');

:root{
  --navy:#0B1931; --nm:#162444; --nl:#1E3260;
  --gold:#C8960C; --gb:#F0B429; --gp:#FFF8E7;
  --cream:#F4F1EB; --white:#fff; --mu:#6B7280; --ch:#111827;
  --dc:#E91E8C; --rc:#00ACC1; --ec:#7C3AED; --ac:#E65100; --mc:#2E7D32;
  --sh:0 4px 24px rgba(11,25,49,.09); --shl:0 16px 56px rgba(11,25,49,.16);
  --r:14px; --r2:20px;
  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--cream);color:var(--ch);overflow-x:hidden;-webkit-font-smoothing:antialiased;min-width:320px}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
/* ── ACCESSIBILITY ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100px;left:16px;z-index:10000;background:var(--navy);color:var(--gb);padding:12px 18px;border-radius:8px;font-weight:700;font-size:.85rem;box-shadow:var(--shl);transition:top .2s}
.skip-link:focus{top:16px;outline:3px solid var(--gb);outline-offset:2px}
:focus{outline:none}
:focus-visible{outline:3px solid var(--gb);outline-offset:2px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--gb);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important}
}
/* ── ABOUT PAGE GRIDS ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,56px);align-items:center}
@media(max-width:760px){.about-grid{grid-template-columns:1fr;gap:28px}}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:#060E1D}
::-webkit-scrollbar-thumb{background:var(--gb);border-radius:4px}

/* ── PROGRESS BAR ── */
#prog{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gb),#E91E8C);z-index:9999;width:0;pointer-events:none;transition:width .08s linear}

/* ── BACK TO TOP ── */
#btt{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:12px;background:var(--navy);color:var(--gb);font-size:.9rem;font-weight:700;border:1.5px solid rgba(200,150,12,.3);cursor:pointer;box-shadow:0 4px 18px rgba(0,0,0,.25);z-index:900;opacity:0;pointer-events:none;transition:all .3s;display:flex;align-items:center;justify-content:center}
#btt.vis{opacity:1;pointer-events:all}
#btt:hover{transform:translateY(-3px);background:var(--nm)}

/* ── TOAST ── */
#toast{position:fixed;bottom:84px;right:24px;background:var(--navy);color:#fff;font-size:.8rem;padding:12px 18px;border-radius:10px;border-left:3px solid var(--gb);box-shadow:var(--shl);opacity:0;transform:translateX(16px);transition:all .3s;z-index:1001;max-width:280px;pointer-events:none}
#toast.sh{opacity:1;transform:translateX(0)}

/* ── ADMIN BAR ── */
#admin-bar{display:none;position:fixed;top:70px;left:0;right:0;z-index:890;background:rgba(200,150,12,.96);padding:7px 4vw;align-items:center;justify-content:space-between;font-size:.76rem;font-weight:700;color:var(--navy)}
#admin-bar.vis{display:flex}
#admin-bar button{background:rgba(11,25,49,.15);border:none;color:var(--navy);padding:4px 12px;border-radius:6px;cursor:pointer;font-family:inherit;font-weight:700}

/* ════════════════════════════════════
   NAVIGATION
════════════════════════════════════ */
nav#mainnav{position:fixed;top:0;left:0;right:0;z-index:1000;height:76px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 max(12px,env(safe-area-inset-right)) 0 max(12px,env(safe-area-inset-left));background:#f8f4e8;border-bottom:2px solid rgba(200,150,12,.4);box-shadow:0 2px 16px rgba(11,25,49,.08);transition:height .3s,box-shadow .3s}
nav#mainnav.sm{height:58px;box-shadow:0 4px 30px rgba(0,0,0,.3)}
.nav-brand{display:flex;align-items:center;gap:0;cursor:pointer;flex:1 1 auto;min-width:0;position:relative}
.nav-brand-logo{height:58px;width:auto;max-width:min(400px,calc(100vw - 110px));object-fit:contain;display:block;pointer-events:none}
.nav-logo-wrap{display:flex;align-items:center;gap:12px}
.nav-logo-divider{width:1px;height:38px;background:rgba(200,150,12,.3);margin:0 4px;flex-shrink:0}
.nav-brand-text strong{font-family:var(--font-head);color:var(--gb);font-size:1.06rem;font-weight:700;display:block;line-height:1.15;letter-spacing:.01em}
.nav-brand-text span{font-size:.5rem;color:rgba(255,255,255,.28);letter-spacing:.14em;text-transform:uppercase;display:block;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links>a,.nav-links>.nav-dropdown>a{color:var(--navy);font-size:.77rem;font-weight:600;padding:6px 10px;border-radius:8px;transition:all .2s;display:flex;align-items:center;gap:4px}
.nav-links>a:hover,.nav-links>a.active,.nav-links>.nav-dropdown>a:hover,.nav-links>.nav-dropdown>a.active{color:var(--gold);background:rgba(200,150,12,.12)}
.nav-dropdown{position:relative}
.nav-dropdown>a::after{content:"▾";font-size:.6rem;opacity:.6}
/* ── DROPDOWN: uses opacity/visibility with delay so mouse has time to move into menu ── */
.dropdown-menu{
  visibility:hidden;opacity:0;pointer-events:none;
  position:absolute;top:100%;left:0;min-width:240px;
  background:#0d2040;border:1px solid rgba(200,150,12,.2);
  border-radius:14px;padding:8px;box-shadow:0 20px 50px rgba(0,0,0,.5);z-index:500;
  transition:opacity .22s ease,visibility .22s ease;
  /* 8px bridge gap — invisible area prevents menu closing when mouse moves from link to menu */
  margin-top:0;padding-top:16px;
}
/* Invisible hover bridge between trigger and menu */
.nav-dropdown::after{
  content:'';position:absolute;left:0;right:0;
  top:100%;height:16px;
  background:transparent;
}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu{
  visibility:visible;opacity:1;pointer-events:all;
}
@keyframes fdrop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.dropdown-menu a{display:flex;align-items:center;gap:8px;padding:9px 13px;color:rgba(255,255,255,.68);font-size:.78rem;border-radius:8px;transition:all .18s}
.dropdown-menu a:hover{color:var(--gb);background:rgba(200,150,12,.1)}
.dropdown-sub{border-top:1px solid rgba(200,150,12,.12);margin-top:4px;padding-top:4px}
.dropdown-sub-label{padding:4px 13px;font-size:.62rem;color:var(--gold);letter-spacing:.1em;font-weight:700;text-transform:uppercase}
/* ── NESTED SUBMENU on Community Service hover ── */
.dropdown-item-with-sub{position:relative}
.dropdown-item-with-sub>a::after{content:"›";margin-left:auto;opacity:.5;font-size:.8rem}
.dropdown-submenu{
  visibility:hidden;opacity:0;pointer-events:none;
  position:absolute;left:100%;top:-8px;min-width:180px;
  background:#0d2040;border:1px solid rgba(200,150,12,.2);
  border-radius:12px;padding:6px;box-shadow:0 16px 40px rgba(0,0,0,.5);
  transition:opacity .2s ease,visibility .2s ease;
  z-index:600;
}
.dropdown-item-with-sub:hover .dropdown-submenu{
  visibility:visible;opacity:1;pointer-events:all;
}
.dropdown-submenu a{display:flex;align-items:center;gap:7px;padding:8px 12px;color:rgba(255,255,255,.68);font-size:.76rem;border-radius:8px;transition:all .18s}
.dropdown-submenu a:hover{color:var(--gb);background:rgba(200,150,12,.1)}
.nav-join{background:linear-gradient(135deg,var(--gold),var(--gb))!important;color:var(--navy)!important;font-weight:700!important;padding:7px 16px!important;border-radius:8px!important;margin-left:4px}
.nav-join:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(200,150,12,.4)}
.nav-admin{background:var(--navy)!important;color:var(--gb)!important;font-weight:700!important;padding:7px 16px!important;border-radius:8px!important;margin-left:4px;border:1.5px solid rgba(200,150,12,.25)!important}
.nav-admin:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(11,25,49,.25);background:var(--nm)!important}
.nav-ham{display:none;flex-direction:column;gap:5px;padding:10px;cursor:pointer;flex:0 0 auto;min-width:44px;min-height:44px;align-items:center;justify-content:center;z-index:1002;margin-left:4px;-webkit-tap-highlight-color:transparent;border-radius:8px;background:transparent}
.nav-ham span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}
.mob-menu{display:none;position:fixed;inset:0;background:var(--navy);z-index:1100;padding:calc(76px + env(safe-area-inset-top,0px)) 6vw calc(40px + env(safe-area-inset-bottom,0px));flex-direction:column;gap:4px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mob-menu.open{display:flex;animation:mobin .25s ease}
.mob-close{position:absolute;top:calc(14px + env(safe-area-inset-top,0px));right:max(14px,env(safe-area-inset-right));width:44px;height:44px;border-radius:10px;border:1px solid rgba(200,150,12,.35);background:rgba(255,255,255,.08);color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1101}
@keyframes mobin{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.mob-menu a{font-family:var(--font-head);font-size:1.8rem;color:rgba(255,255,255,.8);padding:10px 0;border-bottom:1px solid rgba(200,150,12,.1)}
.mob-menu a.join{color:var(--gb);border:none;margin-top:12px}
.mob-sub{padding-left:1.2rem}
.mob-sub a{font-size:1.2rem;color:rgba(255,255,255,.5);border:none;padding:5px 0}
@media(max-width:960px){
  .nav-links{display:none!important}
  .nav-ham{display:flex!important}
  .nav-brand-logo{height:42px;max-width:calc(100vw - 76px)}
  nav#mainnav{height:64px;padding:0 8px 0 max(10px,env(safe-area-inset-left))}
  nav#mainnav.sm{height:56px}
  .page-hero{padding:96px 5vw 48px;min-height:220px}
  #btt{bottom:max(20px,env(safe-area-inset-bottom))}
  #toast{bottom:max(84px,env(safe-area-inset-bottom) + 60px)}
}

/* ════════════════════════════════════
   PAGE HERO BANNER
════════════════════════════════════ */
.page-hero{background:var(--navy);padding:120px 5vw 60px;position:relative;overflow:hidden;min-height:260px;display:flex;align-items:flex-end}
.page-hero-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(200,150,12,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(200,150,12,.04) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 20%,transparent 100%)}
.page-hero-orb{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:700px}
.sl{font-family:var(--font-body);font-size:.72rem;font-weight:700;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;margin-bottom:8px}
.page-hero-title{font-family:var(--font-head);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:#fff;line-height:1.1;margin-bottom:12px}
.page-hero-sub{color:rgba(255,255,255,.48);font-size:.95rem;line-height:1.8;max-width:560px}

/* ════════════════════════════════════
   SECTION HELPERS
════════════════════════════════════ */
.container{max-width:1200px;margin:0 auto}
.section{padding:80px 5vw}
.bg-white{background:#fff}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy);position:relative;overflow:hidden}
.sh{font-family:var(--font-head);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;color:var(--navy);line-height:1.15}
.sh em{font-style:italic;color:var(--gold)}
.sh-light{color:#fff}
.sh-light em{color:var(--gb)}

/* ════════════════════════════════════
   BUTTONS
════════════════════════════════════ */
.btn-p{background:linear-gradient(135deg,var(--gold),var(--gb));color:var(--navy);font-weight:700;font-size:.87rem;padding:13px 28px;border-radius:10px;border:none;cursor:pointer;box-shadow:0 4px 18px rgba(200,150,12,.3);font-family:inherit;transition:all .25s;display:inline-flex;align-items:center;gap:7px}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,150,12,.45)}
.btn-o{border:1.5px solid rgba(200,150,12,.45);color:var(--gb);font-weight:600;font-size:.87rem;padding:13px 28px;border-radius:10px;background:transparent;cursor:pointer;font-family:inherit;transition:all .25s;display:inline-flex;align-items:center;gap:7px}
.btn-o:hover{background:rgba(200,150,12,.1);border-color:rgba(200,150,12,.7)}
.btn-outline-dark{border:1.5px solid rgba(200,150,12,.4);color:var(--navy);background:transparent;font-weight:700;font-size:.8rem;padding:9px 20px;border-radius:9px;cursor:pointer;font-family:inherit;transition:all .2s}
.btn-outline-dark:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-sm{padding:6px 13px;border-radius:7px;font-size:.74rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
.btn-edit{border:1px solid rgba(200,150,12,.4);color:var(--gold);background:transparent}
.btn-del{border:1px solid rgba(153,27,27,.35);color:#991B1B;background:transparent}

/* ════════════════════════════════════
   EVENTS (shared)
════════════════════════════════════ */
.ev-card{background:#fff;border-radius:var(--r);padding:20px;display:flex;gap:14px;align-items:flex-start;border:1px solid rgba(0,0,0,.06);transition:all .25s}
.ev-card:hover{box-shadow:var(--sh);transform:translateX(3px)}
.ev-card.past{opacity:.6}
.ev-date{background:var(--navy);border-radius:10px;padding:9px 11px;text-align:center;flex-shrink:0;min-width:52px}
.ev-date strong{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--gb);display:block;line-height:1}
.ev-date span{font-size:.56rem;color:rgba(255,255,255,.42);letter-spacing:.1em;text-transform:uppercase}
.ev-info h4{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:5px}
.ev-info p{font-size:.8rem;color:var(--mu);margin-bottom:9px;line-height:1.55}
.ev-tags{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.tag{font-size:.67rem;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--gp);color:var(--navy)}
.tag-done{background:#ECFDF5;color:#065F46}
.tag-rsvp{background:var(--navy);color:var(--gb);cursor:pointer}

/* ════════════════════════════════════
   MEMBERS
════════════════════════════════════ */
.table-wrap{border-radius:var(--r);overflow-x:auto;overflow-y:hidden;box-shadow:var(--sh);-webkit-overflow-scrolling:touch}
.table-wrap table{width:100%;border-collapse:collapse;background:#fff;min-width:580px}
.table-wrap thead{background:var(--navy)}
.table-wrap th{padding:13px 16px;text-align:left;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);cursor:pointer;white-space:nowrap;user-select:none}
.table-wrap th:hover{color:var(--gb)}
.table-wrap tbody tr{border-bottom:1px solid rgba(0,0,0,.05);transition:background .15s}
.table-wrap tbody tr:hover{background:#FFFBF0}
.table-wrap td{padding:12px 16px;font-size:.84rem}
.td-name{font-weight:600;color:var(--navy)}
.td-role{font-weight:600;color:var(--gold);font-size:.76rem}
.member-av{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--navy),var(--nl));display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.8rem;font-weight:700;color:var(--gb);flex-shrink:0}

/* ════════════════════════════════════
   GALLERY
════════════════════════════════════ */
.gallery-grid{columns:4 200px;gap:11px}
.gitem{break-inside:avoid;margin-bottom:11px;border-radius:12px;overflow:hidden;position:relative;cursor:pointer;background:var(--navy);transition:all .28s}
.gitem:hover{transform:scale(1.02);box-shadow:0 10px 32px rgba(11,25,49,.22)}
.gitem img{width:100%;display:block;object-fit:cover}
.gitem-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,25,49,.85),transparent 55%);opacity:0;transition:opacity .28s;display:flex;align-items:flex-end;padding:10px 12px}
.gitem:hover .gitem-overlay{opacity:1}
.gitem-overlay p{color:#fff;font-size:.76rem;font-weight:500;line-height:1.3}
.gitem-badge{position:absolute;top:8px;left:8px;color:#fff;font-size:.59rem;font-weight:700;letter-spacing:.07em;padding:3px 8px;border-radius:20px}
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:3000;align-items:center;justify-content:center;padding:20px}
#lightbox.open{display:flex}
#lb-close{position:absolute;top:20px;right:24px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:none;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
#lb-img{max-width:90vw;max-height:85vh;border-radius:12px;object-fit:contain}
#lb-cap{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.82rem}
#lb-prev,#lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);color:#fff;border:none;font-size:1.8rem;padding:12px 16px;border-radius:10px;cursor:pointer;transition:background .2s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
#lb-prev{left:16px}
#lb-next{right:16px}
#lb-prev:hover,#lb-next:hover{background:rgba(200,150,12,.35)}

/* ════════════════════════════════════
   FORM ELEMENTS
════════════════════════════════════ */
.form-card{background:#fff;border-radius:18px;padding:32px;border:1px solid rgba(200,150,12,.15);box-shadow:var(--sh)}
.form-card h3{font-family:var(--font-head);font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:22px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-full{grid-column:1/-1}
.flabel{display:block;font-size:.71rem;font-weight:700;color:var(--mu);margin-bottom:5px;letter-spacing:.07em;text-transform:uppercase}
.finput{width:100%;padding:10px 13px;border-radius:9px;border:1.5px solid rgba(0,0,0,.11);font-family:inherit;font-size:.86rem;color:var(--ch);background:#fff;outline:none;transition:border-color .2s}
.finput:focus{border-color:var(--gold)}
.finput.filled{border-color:rgba(200,150,12,.4)}
textarea.finput{resize:vertical;min-height:80px}
.form-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-banner{background:linear-gradient(135deg,var(--navy),var(--nl));border-radius:16px;padding:22px 24px;margin-bottom:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;border:1px solid rgba(200,150,12,.18)}
.admin-banner-label{color:var(--gb);font-family:'Bebas Neue',sans-serif;font-size:.8rem;letter-spacing:.15em;margin-bottom:4px}
.admin-banner p{color:rgba(255,255,255,.5);font-size:.81rem}

/* ════════════════════════════════════
   CONTACT
════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.contact-info-stack{display:flex;flex-direction:column;gap:14px}
.cic{background:var(--cream);border-radius:var(--r);padding:22px;border:1px solid rgba(0,0,0,.07);transition:all .25s;position:relative;overflow:hidden}
.cic:hover{transform:translateX(4px);border-color:rgba(200,150,12,.25)}
.cic-label{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.cic-name{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:9px}
.cic-links a{display:flex;align-items:center;gap:7px;font-size:.8rem;color:var(--mu);text-decoration:none;margin-bottom:5px;transition:color .2s}
.cic-links a:hover{color:var(--gold)}
.map-box{background:var(--navy);border-radius:var(--r);padding:22px;text-align:center;color:rgba(255,255,255,.42);font-size:.82rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(200,150,12,.14)}
.map-box a{color:var(--gb);font-size:.78rem;margin-top:4px}

/* ════════════════════════════════════
   MEET CARD
════════════════════════════════════ */
.meet-card{background:var(--navy);border-radius:18px;padding:26px;border:1px solid rgba(200,150,12,.18)}
.meet-card-title{font-family:var(--font-head);font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:18px;padding-bottom:13px;border-bottom:1px solid rgba(200,150,12,.15)}
.meet-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.82rem}
.meet-row:last-of-type{border-bottom:none}
.meet-label{color:rgba(255,255,255,.38);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}
.meet-val{color:#fff;font-weight:500}
.meet-val.gold{color:var(--gb)}
.rsvp-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:18px;background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;font-weight:700;font-size:.82rem;padding:12px;border-radius:9px;text-align:center;text-decoration:none;transition:all .25s}
.rsvp-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(37,211,102,.35)}

/* ════════════════════════════════════
   PROJECTS PAGE
════════════════════════════════════ */
.proj-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.proj-tab{padding:9px 18px;border-radius:10px;border:1.5px solid rgba(11,25,49,.14);background:#fff;color:rgba(11,25,49,.72);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .22s;display:flex;align-items:center;gap:6px;font-family:inherit}
.proj-tab.active,.proj-tab:hover{border-color:var(--gold);background:var(--gold);color:#fff}
.proj-panel{display:none}
.proj-panel.active{display:block;animation:fadein .2s ease}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.proj-subtabs{display:flex;gap:8px;margin-bottom:20px}
.proj-subtab{padding:7px 16px;border-radius:8px;border:1.5px solid rgba(0,0,0,.09);background:#fff;font-size:.76rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}
.proj-subtab.active,.proj-subtab:hover{background:var(--navy);color:var(--gb);border-color:var(--navy)}
.proj-events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.proj-event-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:var(--r);padding:20px;border-left:4px solid var(--gold);transition:all .25s;position:relative}
.proj-event-card:hover{box-shadow:var(--sh);transform:translateX(4px)}
.proj-event-date{font-size:.7rem;color:var(--mu);margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.proj-event-name{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:7px}
.proj-event-desc{font-size:.82rem;color:var(--mu);line-height:1.65}
.proj-anchor{scroll-margin-top:90px}
.proj-cat-header{display:flex;align-items:center;gap:14px;padding:22px 0 18px;border-bottom:2px solid rgba(0,0,0,.07);margin-bottom:28px}
.proj-cat-icon{font-size:1.9rem;width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proj-cat-title{font-family:var(--font-head);font-size:1.7rem;font-weight:700;color:var(--navy)}
.proj-cat-desc{font-size:.86rem;color:var(--mu);line-height:1.72;margin-top:4px;max-width:640px}

/* ════════════════════════════════════
   FOOTER
════════════════════════════════════ */
.social-strip{background:#060E1D;padding:16px 5vw;display:flex;justify-content:center;gap:10px;flex-wrap:wrap;border-top:1px solid rgba(200,150,12,.1)}
.social-chip{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);border:1px solid rgba(200,150,12,.15);color:rgba(255,255,255,.52);font-size:.74rem;font-weight:500;padding:7px 14px;border-radius:8px;text-decoration:none;transition:all .2s}
.social-chip:hover{background:rgba(200,150,12,.1);color:var(--gb);transform:translateY(-2px)}
footer{background:#060E1D;padding:52px 5vw 24px;border-top:1px solid rgba(200,150,12,.08)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-brand strong{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--gb);display:block;margin-bottom:10px}
.footer-brand p{color:rgba(255,255,255,.3);font-size:.78rem;line-height:1.75;max-width:240px}
.footer-social{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.footer-social a{font-size:.74rem;color:rgba(255,255,255,.36);transition:color .2s}
.footer-social a:hover{color:var(--gb)}
.footer-col h4{font-family:var(--font-head);font-size:.92rem;font-weight:700;color:var(--gb);margin-bottom:12px}
.footer-col a,.footer-col p{display:block;color:rgba(255,255,255,.32);font-size:.77rem;margin-bottom:7px;transition:color .2s}
.footer-col a:hover{color:var(--gb)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-top:18px;border-top:1px solid rgba(255,255,255,.05)}
.footer-bottom p{font-size:.7rem;color:rgba(255,255,255,.2)}

/* ════════════════════════════════════
   REVEAL ANIMATION
════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-left.vis{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-right.vis{opacity:1;transform:translateX(0)}
/* Mobile / iOS: avoid invisible content if scroll-reveal does not fire */
@media(max-width:960px){
  .reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important}
}

/* ════════════════════════════════════
   FILTER TABS (events page)
════════════════════════════════════ */
.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.ftab{padding:7px 17px;border-radius:40px;font-size:.77rem;font-weight:600;border:1.5px solid rgba(200,150,12,.22);color:var(--mu);background:#fff;cursor:pointer;font-family:inherit;transition:all .2s}
.ftab.on,.ftab:hover{background:var(--navy);color:var(--gb);border-color:var(--navy)}
.events-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
.ev-card-rich{background:#fff;border-radius:16px;padding:0;border:1px solid rgba(0,0,0,.07);transition:all .3s;overflow:hidden;margin-bottom:14px;display:flex}
.ev-card-rich:hover{box-shadow:0 12px 40px rgba(0,0,0,.1);transform:translateY(-2px)}
.ev-card-rich.past{opacity:.6}
.ev-card-date-col{width:76px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 8px;background:var(--navy)}
.ev-card-date-col .day{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:var(--gb);line-height:1;display:block}
.ev-card-date-col .mon{font-size:.58rem;color:rgba(255,255,255,.36);letter-spacing:.1em;text-transform:uppercase}
.ev-card-date-col .yr{font-size:.55rem;color:rgba(255,255,255,.2);letter-spacing:.06em}
.ev-card-color-bar{width:4px;flex-shrink:0}
.ev-card-body{flex:1;padding:18px 20px}
.ev-card-body h4{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:5px}
.ev-card-body p{font-size:.8rem;color:var(--mu);line-height:1.6;margin-bottom:10px}
.ev-card-actions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.ev-rsvp-btn{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;font-size:.75rem;font-weight:700;padding:7px 13px;border-radius:8px;text-decoration:none;transition:all .2s}
.ev-rsvp-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,211,102,.3)}

/* ════════════════════════════════════
   JOIN PAGE
════════════════════════════════════ */
.join-steps{display:flex;border:1px solid rgba(200,150,12,.18);border-radius:13px;overflow:hidden;max-width:680px;margin:0 auto 40px}
.join-step{flex:1;padding:22px 14px;text-align:center;border-right:1px solid rgba(200,150,12,.13)}
.join-step:last-child{border-right:none}
.join-step-num{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:rgba(200,150,12,.22);line-height:1;display:block}
.join-step h4{font-size:.8rem;font-weight:600;color:#fff;margin-bottom:4px}
.join-step p{font-size:.72rem;color:rgba(255,255,255,.36)}
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.bcard{background:var(--cream);border:1px solid rgba(0,0,0,.07);border-radius:var(--r);padding:24px 20px;border-top:3px solid var(--gold)}
.bcard-icon{font-size:1.8rem;margin-bottom:12px}
.bcard h4{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:7px}
.bcard p{font-size:.81rem;color:var(--mu);line-height:1.7}

/* ════════════════════════════════════
   RESPONSIVE
════════════════════════════════════ */
@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{columns:3 160px}
  .events-layout{grid-template-columns:1fr}
  .ev-card-rich{flex-direction:column}
  .ev-card-date-col{width:100%;flex-direction:row;gap:10px;padding:12px 16px;justify-content:flex-start}
  .ev-card-date-col .day{font-size:2rem}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
  .join-steps{flex-direction:column}
  .join-step{border-right:none;border-bottom:1px solid rgba(200,150,12,.12)}
  .join-step:last-child{border-bottom:none}
  .gallery-grid{columns:2 140px}
  .proj-events-grid{grid-template-columns:1fr}
  .page-hero{padding:48px 5vw 40px}
  .section{padding:48px 5vw}
  .container{padding:0}
}
@media(max-width:480px){
  nav#mainnav{padding:0 14px}
  .page-hero-title{font-size:clamp(1.8rem,8vw,2.6rem)}
  .social-strip{gap:6px;padding:10px 14px}
  .social-chip{font-size:.68rem;padding:5px 10px}
}
