/* ═══════════════════════════════════════════════════════════
   IPP — css/style.css
   Shared stylesheet · April 2026
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ── Tokens ─────────────────────────────────────────────── */
:root {
  --navy:       #0D1B3D;
  --navy-mid:   #112249;
  --navy-light: #1a3060;
  --navy-deep:  #080f22;
  --red:        #C0392B;
  --red-light:  #e04040;
  --gold:       #C9A84C;
  --gold-light: #e8c96a;
  --student:    #0077B6;
  --blue:       #0077B6;
  --associate:  #7B1FA2;
  --member-col: #D7263D;
  --fellow-col: #1E8E3E;
  --green:      #1E8E3E;
  --white:      #FFFFFF;
  --off-white:  #F4F5F8;
  --cream:      #F8F7F4;
  --text:       #1a1f2e;
  --grey-200:   #E2E8F0;
  --grey-400:   #94A3B8;
  --grey-500:   #64748B;
  --grey-600:   #475569;
  --border:     rgba(255,255,255,0.08);
  --border-mid: rgba(255,255,255,0.14);
  --radius:     8px;
  --radius-lg:  16px;
}

/* ── Reset ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit}
button{font-family:inherit}

/* ── Type ───────────────────────────────────────────────── */
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;font-weight:700;line-height:1.15;color:var(--navy)}
h1{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem}
h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:.75rem}
h3{font-size:1.4rem;margin-bottom:.5rem}
h4{font-size:1.1rem;margin-bottom:.375rem}
h5{font-size:.95rem;margin-bottom:.25rem}
p{margin-bottom:1rem;color:var(--grey-600);line-height:1.75}
p:last-child{margin-bottom:0}

/* ── Layout ─────────────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 2.5rem}
.section{padding:5rem 0;background:var(--white)}
.section.light{background:var(--off-white)}
.section.dark{background:var(--navy)}
.section.dark p{color:rgba(255,255,255,.82)}
.section.cream{background:var(--cream)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.flex{display:flex}
.gap-2{gap:.5rem}
.w-full{width:100%}

/* ── Eyebrow ────────────────────────────────────────────── */
.eyebrow{display:flex;align-items:center;gap:.5rem;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:.75rem}
.eyebrow::before{content:'';display:inline-block;width:18px;height:2px;background:var(--red);border-radius:1px;flex-shrink:0}
.eyebrow-white{color:rgba(255,255,255,.82)}
.eyebrow-white::before{background:rgba(255,255,255,.3)}

/* ── Rule ───────────────────────────────────────────────── */
.rule{height:2px;width:48px;background:var(--red);margin-bottom:1.75rem;border-radius:1px}
.rule-center{margin-left:auto;margin-right:auto}

/* ── Buttons ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.75rem;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;border:none;transition:all .2s;letter-spacing:.01em;line-height:1}
.btn-primary{background:var(--red);color:var(--white)}
.btn-primary:hover{background:var(--red-light);box-shadow:0 6px 20px rgba(192,57,43,.3);transform:translateY(-1px)}
.btn-outline{background:transparent;color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.35)}
.btn-outline:hover{border-color:rgba(255,255,255,.5);color:var(--white)}
.btn-outline-dark{background:transparent;color:var(--navy);border:1px solid var(--grey-200)}
.btn-outline-dark:hover{border-color:var(--navy);background:var(--off-white)}
.btn-lg{padding:1rem 2.25rem;font-size:.95rem}

/* ── Cards ──────────────────────────────────────────────── */
.card{background:var(--white);border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:2rem}
.card-dark{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}

/* ── Feature list ───────────────────────────────────────── */
.feature-list{list-style:none}
.feature-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.875rem;color:var(--grey-600);padding:.45rem 0;border-bottom:1px solid var(--grey-200)}
.feature-list li:last-child{border-bottom:none}
.feature-list li::before{content:'✓';color:var(--fellow-col);font-weight:700;font-size:.7rem;flex-shrink:0;margin-top:2px}

/* ── Helpers ────────────────────────────────────────────── */
.text-white{color:var(--white)!important}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}

/* ══════════════════════════════════════════════════════════
   PASSWORD GATE
══════════════════════════════════════════════════════════ */
#password-gate{position:fixed;inset:0;z-index:9999;background:var(--navy-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}
#password-gate img{width:56px;height:56px;border-radius:50%;margin-bottom:.5rem}
#password-gate h2{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--white);letter-spacing:.1em}
#password-gate p{font-size:.85rem;color:rgba(255,255,255,.45);margin:0;text-align:center}
.gate-form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px;margin-top:.5rem}
.gate-form input{padding:.85rem 1rem;border-radius:var(--radius);border:1px solid var(--border-mid);background:rgba(255,255,255,.07);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9rem;outline:none;transition:border-color .2s}
.gate-form input:focus{border-color:rgba(255,255,255,.4)}
.gate-form button{padding:.85rem;background:var(--red);color:var(--white);border:none;border-radius:var(--radius);cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9rem;transition:background .2s}
.gate-form button:hover{background:var(--red-light)}
.gate-error{font-size:.8rem;color:#e07b6e;text-align:center;min-height:1.2em}
.gate-notice{font-size:.72rem;color:rgba(255,255,255,.25);letter-spacing:.06em;text-transform:uppercase}

/* ══════════════════════════════════════════════════════════
   PUBLIC NAV
══════════════════════════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,27,61,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2.5rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-brand img{width:32px;height:32px;border-radius:50%}
.nav-wordmark{display:flex;flex-direction:column;line-height:1.2}
.nav-wordmark span:first-child{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:700;color:var(--white);letter-spacing:.05em}
.nav-wordmark span:last-child{font-size:.6rem;color:rgba(255,255,255,.4);letter-spacing:.08em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links li a{display:block;padding:.4rem .75rem;font-size:.82rem;font-weight:500;color:rgba(255,255,255,.85);text-decoration:none;border-radius:6px;transition:color .2s,background .2s;letter-spacing:.01em}
.nav-links li a:hover{color:var(--white);background:rgba(255,255,255,.06)}
.nav-links li a.active{color:var(--white)}
.nav-cta{background:var(--red)!important;color:var(--white)!important;padding:.45rem 1.1rem!important;border-radius:6px!important;font-weight:600!important;transition:background .2s!important}
.nav-cta:hover,.nav-cta.active{background:var(--red-light)!important}
.nav-mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-mobile-toggle span{display:block;width:22px;height:2px;background:rgba(255,255,255,.7);border-radius:1px;transition:all .2s}

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero{position:relative;overflow:hidden;background:var(--navy);padding:9rem 0 6rem}
.hero-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:64px 64px}
.hero-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 70% 50%,rgba(192,57,43,.12) 0%,transparent 60%),radial-gradient(ellipse 50% 70% at 15% 80%,rgba(0,119,182,.08) 0%,transparent 55%)}
.hero-content{position:relative;z-index:1}
.hero h1{color:var(--white)}

/* ══════════════════════════════════════════════════════════
   MEMBERS NAV
══════════════════════════════════════════════════════════ */
.members-nav{background:var(--navy);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.members-nav-inner{max-width:1200px;margin:0 auto;padding:0 2.5rem;display:flex;align-items:center;justify-content:space-between;height:56px}
.members-nav-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.members-nav-brand img{width:28px;height:28px;border-radius:50%}
.members-nav-brand span{font-family:'Cormorant Garamond',serif;color:var(--white);font-size:1.1rem;font-weight:700;letter-spacing:.08em}
.members-nav-links{display:flex;align-items:center;gap:0;list-style:none}
.members-nav-links a{display:block;padding:0 1rem;height:56px;line-height:56px;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.82);text-decoration:none;letter-spacing:.04em;transition:color .15s;border-bottom:2px solid transparent}
.members-nav-links a:hover{color:rgba(255,255,255,.95)}
.members-nav-links a.active{color:var(--white);border-bottom-color:var(--red)}
.members-nav-actions{display:flex;align-items:center;gap:1rem}
.members-nav-actions a{font-size:.8rem;color:rgba(255,255,255,.72);text-decoration:none;transition:color .2s}
.members-nav-actions a:hover{color:rgba(255,255,255,.92)}

/* ══════════════════════════════════════════════════════════
   MEMBER HEADER
══════════════════════════════════════════════════════════ */
.member-header{background:var(--navy);padding:3.5rem 0 3rem}
.member-header .container{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem}
.member-greeting{color:rgba(255,255,255,.75);font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem}
.member-name{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:700;color:var(--white);margin:0 0 1.25rem;line-height:1.15}
.member-badges{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .8rem;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.badge-student{background:rgba(255,255,255,.08);color:rgba(255,255,255,.82)}
.badge-aipp{background:rgba(123,31,162,.2);color:#b57be0;border:1px solid rgba(123,31,162,.35)}
.badge-mipp{background:rgba(215,38,61,.18);color:#e07b6e;border:1px solid rgba(215,38,61,.3)}
.badge-fipp{background:rgba(30,142,62,.18);color:#7be0a0;border:1px solid rgba(30,142,62,.3)}
.badge-active{background:rgba(16,185,129,.12);color:#6ee7b7;border:1px solid rgba(16,185,129,.22)}
.badge-lapsed{background:rgba(245,158,11,.12);color:#fcd34d;border:1px solid rgba(245,158,11,.22)}
.badge-suspended{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.22)}
.member-number{font-size:.75rem;color:rgba(255,255,255,.3);margin-top:.75rem;font-family:monospace;letter-spacing:.05em}

/* ══════════════════════════════════════════════════════════
   DASHBOARD CARDS
══════════════════════════════════════════════════════════ */
.dashboard-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.dash-card{background:var(--white);border-radius:var(--radius-lg);padding:2rem;border:1px solid var(--grey-200);transition:box-shadow .2s}
.dash-card:hover{box-shadow:0 4px 20px rgba(13,27,61,.08)}
.dash-card-label{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-400);margin-bottom:1rem}
.dash-card h3{font-size:1rem;color:var(--navy);margin-bottom:.5rem}
.dash-card p{font-size:.85rem;color:var(--grey-600);line-height:1.6;margin-bottom:1.25rem}
.dash-card .btn{font-size:.8rem}
.doc-links{display:flex;flex-direction:column;gap:.4rem;margin-top:.25rem}
.doc-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--navy);text-decoration:none;padding:.5rem 0;border-bottom:1px solid var(--grey-200);transition:color .2s}
.doc-link:last-child{border-bottom:none}
.doc-link:hover{color:var(--red)}
.doc-link-icon{font-size:.7rem;opacity:.45}
.notice-card{background:var(--off-white);border-radius:var(--radius-lg);padding:1.75rem 2rem;border:1px solid var(--grey-200);margin-top:1.5rem;display:flex;align-items:flex-start;gap:1.25rem}
.notice-card-icon{width:36px;height:36px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notice-card-icon svg{width:16px;height:16px;stroke:var(--white);fill:none}
.notice-card p{font-size:.875rem;color:var(--grey-600);margin:0;line-height:1.6}
.notice-card p strong{color:var(--navy)}
.notice-card a{color:var(--red);text-decoration:none}
.notice-card a:hover{text-decoration:underline}

/* ══════════════════════════════════════════════════════════
   PROFILE / SETTINGS
══════════════════════════════════════════════════════════ */
.page-header{background:var(--navy);padding:3.5rem 0 3rem}
.settings-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--grey-200);overflow:hidden;margin-bottom:1.5rem}
.copy-block{background:var(--off-white);border-radius:var(--radius);padding:.75rem 1rem;font-size:.82rem;font-family:monospace;color:var(--grey-600);border:1px solid var(--grey-200);word-break:break-all}
.btn-save{padding:.75rem 1.75rem;background:var(--red);color:var(--white);border:none;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}
.btn-save:hover{background:var(--red-light)}
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);background:var(--navy);color:var(--white);padding:.75rem 1.5rem;border-radius:var(--radius);font-size:.85rem;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .3s;z-index:999}
.toast.show{opacity:1;pointer-events:auto}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 0;border-bottom:1px solid var(--grey-200)}
.toggle-row:last-child{border-bottom:none}
.toggle-label{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:.15rem}
.toggle-sub{font-size:.8rem;color:var(--grey-400)}
.toggle{position:relative;width:44px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;border-radius:12px;background:var(--grey-200);cursor:pointer;transition:background .2s}
.toggle-track::before{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:var(--white);top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked+.toggle-track{background:var(--red)}
.toggle input:checked+.toggle-track::before{transform:translateX(20px)}
.preview-card{background:var(--white);border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:1.5rem}
.preview-card-label{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-400);margin-bottom:1rem}
.preview-avatar{width:48px;height:48px;border-radius:50%;background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}
.preview-name{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.15rem}
.preview-desig{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.preview-meta{font-size:.75rem;color:var(--grey-400);margin-top:.2rem}
.preview-bio{font-size:.78rem;color:var(--grey-500);line-height:1.5;margin-top:.5rem}
.preview-private{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--grey-400);padding:1rem;background:var(--off-white);border-radius:var(--radius);margin-top:1rem}

/* ══════════════════════════════════════════════════════════
   DIRECTORY
══════════════════════════════════════════════════════════ */
.verify-wrap{background:var(--white);border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:2rem}
.verify-row{display:flex;gap:.75rem;margin-top:1rem}
.verify-row input{flex:1;padding:.8rem 1rem;border:1px solid var(--grey-200);border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--text);outline:none;transition:border-color .2s;background:var(--white)}
.verify-row input:focus{border-color:var(--red)}
.verify-result{margin-top:1rem}
.member-row{padding:1rem 0;border-bottom:1px solid var(--grey-200)}
.member-row:last-child{border-bottom:none}
.member-info{display:flex;align-items:flex-start;gap:.875rem}
.member-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}
.member-name{font-size:.9rem;font-weight:600;color:var(--navy)}
.member-tier{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-top:.15rem}
.dir-grid{display:grid;gap:0}

/* ══════════════════════════════════════════════════════════
   DATA TABLE
══════════════════════════════════════════════════════════ */
.data-table{width:100%;border-collapse:collapse;font-size:.875rem}
.data-table thead tr{background:var(--navy)}
.data-table th{padding:1.25rem 1rem;text-align:center;font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--white);border-right:1px solid var(--border)}
.data-table th:first-child{text-align:left}
.data-table th:last-child{border-right:none}
.data-table tbody tr{border-bottom:1px solid var(--grey-200);transition:background .15s}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:var(--off-white)}
.data-table td{padding:1rem;text-align:center;color:var(--grey-600);border-right:1px solid var(--grey-200)}
.data-table td:first-child{text-align:left;color:var(--text);font-weight:500}
.data-table td:last-child{border-right:none}
.data-table td.check{color:var(--fellow-col);font-weight:700;font-size:1rem}
.data-table td.cross{color:var(--grey-400)}

/* ══════════════════════════════════════════════════════════
   DESIGNATIONS
══════════════════════════════════════════════════════════ */
.desig{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .75rem;border-radius:6px;font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.desig-aipp{background:rgba(123,31,162,.12);color:var(--associate);border:1px solid rgba(123,31,162,.25)}
.desig-mipp{background:rgba(215,38,61,.1);color:var(--member-col);border:1px solid rgba(215,38,61,.25)}
.desig-fipp{background:rgba(30,142,62,.1);color:var(--fellow-col);border:1px solid rgba(30,142,62,.25)}

/* ══════════════════════════════════════════════════════════
   TIER PRICE
══════════════════════════════════════════════════════════ */
.tier-price{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;color:var(--navy);line-height:1}
.tier-price sub{font-size:1rem;color:var(--grey-400);vertical-align:baseline}
.tier-price.text-white{color:var(--white)}

/* ══════════════════════════════════════════════════════════
   TIMELINE
══════════════════════════════════════════════════════════ */
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:.4rem;top:.4rem;bottom:0;width:2px;background:linear-gradient(180deg,var(--red) 0%,var(--grey-200) 100%)}
.tl-item{position:relative;margin-bottom:2rem}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-1.65rem;top:.2rem;width:12px;height:12px;border-radius:50%;background:var(--red);border:2px solid var(--white);box-shadow:0 0 0 2px var(--red)}
.tl-dot.future{background:var(--grey-200);box-shadow:0 0 0 2px var(--grey-200)}
.tl-year{display:block;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:.25rem}
.tl-year.future-yr{color:var(--grey-400)}

/* ══════════════════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════════════════ */
.faq-item{border-bottom:1px solid var(--grey-200)}
.faq-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 0;background:none;border:none;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;color:var(--text);cursor:pointer;text-align:left;transition:color .2s;gap:1rem}
.faq-btn:hover{color:var(--red)}
.faq-icon{font-size:1.2rem;color:var(--grey-400);flex-shrink:0;transition:transform .2s;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--red)}
.faq-answer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}
.faq-item.open .faq-answer{grid-template-rows:1fr}
.faq-answer-body{overflow:hidden;padding-bottom:0;font-size:.875rem;color:var(--grey-600);line-height:1.75;transition:padding-bottom .3s}
.faq-item.open .faq-answer-body{padding-bottom:1.25rem}

/* ══════════════════════════════════════════════════════════
   JOIN
══════════════════════════════════════════════════════════ */
.join-option{border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:2rem;cursor:pointer;transition:all .2s;background:var(--white)}
.join-option:hover{border-color:var(--red);transform:translateY(-2px)}
.join-option.selected{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.join-detail{display:none;margin-top:2rem;animation:fadeInUp .3s ease}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.footer{background:var(--navy-deep);border-top:1px solid var(--border);padding:3.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{font-size:.8rem;color:rgba(255,255,255,.65);margin-top:.75rem;line-height:1.6}
.footer-col h5{font-family:'DM Sans',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col ul li a{font-size:.82rem;color:rgba(255,255,255,.78);text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:var(--white)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:2rem;border-top:1px solid var(--border);flex-wrap:wrap;gap:.5rem}
.footer-bottom p{font-size:.72rem;color:rgba(255,255,255,.55);margin:0;line-height:1.5}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .dashboard-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .container{padding:0 1.25rem}
  .nav-links{display:none}
  .nav-mobile-toggle{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--navy-deep);border-bottom:1px solid var(--border);padding:1rem 1.25rem;gap:.25rem}
  .nav-links.open li a{padding:.6rem .75rem}
  .section{padding:3.5rem 0}
  .hero{padding:7rem 0 4rem}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .members-nav-inner{padding:0 1.25rem}
  .members-nav-links{display:none}
  .dashboard-cards{grid-template-columns:1fr}
  .verify-row{flex-direction:column}
  .data-table{font-size:.78rem}
  .data-table th,.data-table td{padding:.75rem .5rem}
}
@media(max-width:480px){
  h1{font-size:1.9rem}
  h2{font-size:1.5rem}
  .btn-lg{padding:.85rem 1.5rem}
  .member-name{font-size:1.75rem}
}
