/* ====================================================
   Wiper Patriotic Front – stylesheet
   Brand colors: navy #0d1b6e, red #d32f2f, silver #c0c4cc (shiny silver)
   ==================================================== */

:root{
  --navy:#0d1b6e; --navy-dark:#091250; --red:#ee0d0d; --red-dark:#b71c1c;
  /* Shiny silver replaces the previous gold accent */
  --gold:#c0c4cc;          /* legacy variable name kept for compatibility */
  --silver:#c0c4cc;
  --silver-light:#e8eaef;
  --silver-dark:#8a8e96;
  --silver-shine:linear-gradient(135deg,#e8eaef 0%,#c0c4cc 45%,#8a8e96 100%);
  --light:#f0f4ff; --gray-50:#f9fafb; --gray-100:#f3f4f6;
  --gray-200:#e5e7eb; --gray-300:#d1d5db; --gray-400:#9ca3af;
  --gray-500:#6b7280; --gray-600:#4b5563; --gray-700:#374151; --gray-800:#1f2937;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow:0 4px 14px rgba(13,27,110,.08);
  --shadow-lg:0 16px 40px rgba(13,27,110,.15);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--gray-700);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',serif;color:var(--navy);line-height:1.2}
a{color:var(--navy);text-decoration:none;transition:color .2s}
a:hover{color:var(--red)}
img{max-width:100%;display:block}
ul{list-style:none}

.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}
@media(min-width:640px){.container{padding:0 1.5rem}}
@media(min-width:1024px){.container{padding:0 2rem}}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:#fff;box-shadow:var(--shadow)}
.topbar{background:var(--navy-dark);color:#fff;font-size:.75rem;padding:.5rem 0}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.topbar__left{display:flex;gap:1.5rem;flex-wrap:wrap}
.topbar__left span,.topbar__right span{display:inline-flex;align-items:center;gap:.4rem}
.topbar__left a,.topbar__right a{color:inherit}
.topbar__left a:hover,.topbar__right a:hover{color:var(--gold)}
@media(max-width:768px){.topbar{display:none}}

.navbar{background:#fff}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:80px;gap:1rem}
.brand{display:flex;align-items:center;gap:.75rem}
.brand__logo{width:52px;height:52px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow);overflow:hidden}
.brand__logo svg{width:36px;height:36px}
.brand__logo--img{background:#fff;padding:2px}
.brand__logo--img img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__name{font-weight:800;color:var(--navy);font-size:1rem;text-transform:uppercase;letter-spacing:.05em}
.brand__tag{font-weight:600;color:var(--red);font-size:.7rem;text-transform:uppercase;letter-spacing:.15em}

.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-links > li > a{display:block;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--gray-700);border-radius:6px}
.nav-links > li > a:hover{color:var(--navy);background:var(--gray-50)}
.has-dropdown{position:relative}
.dropdown{position:absolute;top:100%;left:0;background:#fff;box-shadow:var(--shadow-lg);border-top:4px solid var(--red);border-radius:0 0 .5rem .5rem;min-width:220px;padding:.5rem 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .2s;z-index:40}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:block;padding:.6rem 1.25rem;font-size:.875rem;color:var(--gray-700)}
.dropdown li a:hover{background:var(--light);color:var(--navy)}

.cta-btn{display:inline-block;background:var(--navy);color:#fff;padding:.65rem 1.25rem;border-radius:9999px;font-weight:600;font-size:.875rem;border:2px solid var(--navy);transition:all .2s;box-shadow:var(--shadow)}
.cta-btn:hover{background:var(--navy-dark);border-color:var(--navy-dark);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-lg)}

.mobile-toggle{display:none;background:none;border:0;width:40px;height:40px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:0}
.mobile-toggle span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.2s}

@media(max-width:1023px){
  .nav-links,.cta-btn{display:none}
  .mobile-toggle{display:flex}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:1rem;box-shadow:var(--shadow-lg);gap:.25rem;border-top:1px solid var(--gray-100)}
  .nav-links.open .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding-left:1rem;display:none}
  .nav-links.open .has-dropdown.open .dropdown{display:block}
  .nav-links.open .cta-btn-mobile{display:block;text-align:center;background:var(--navy);color:#fff;padding:.85rem;border-radius:9999px;font-weight:700;margin-top:.5rem}
}

.site-main{padding-top:120px}
@media(max-width:768px){.site-main{padding-top:80px}}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center center;background-repeat:no-repeat;filter:brightness(1.05) contrast(1.05) saturate(1.1)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(9,18,80,.78) 0%,rgba(9,18,80,.45) 45%,rgba(9,18,80,.25) 100%)}
.hero__inner{position:relative;padding:6rem 0;max-width:680px}
.hero__chip{display:inline-flex;align-items:center;gap:.5rem;background:rgba(211,47,47,.2);border:1px solid rgba(211,47,47,.4);color:#fff;font-size:.7rem;font-weight:700;padding:.4rem 1rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.5rem}
.hero__chip::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-size:clamp(2.5rem,7vw,5rem);color:#fff;font-weight:800;line-height:1.05;margin-bottom:1.25rem}
.hero h1 span{color:var(--red)}
.hero p.lead{color:#dbeafe;font-size:clamp(1rem,2vw,1.2rem);margin-bottom:2.5rem;max-width:520px}
.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.75rem;border-radius:9999px;font-weight:600;font-size:.9rem;transition:all .2s;border:0;cursor:pointer;box-shadow:var(--shadow)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--red);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-dark);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-dark);color:#fff}
.btn-outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}

/* ---------- Sections ---------- */
section{padding:5rem 0}
.section-eyebrow{color:var(--red);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:.5rem;display:block;text-align:center}
.section-title{text-align:center;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem}
.section-divider{width:60px;height:4px;background:var(--red);margin:0 auto 2rem;border-radius:2px}

/* By-elections banner */
.byelect{background:var(--navy);padding:2.5rem 0;color:#fff}
.byelect__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
.byelect h2{color:#fff;font-size:1.75rem}
.byelect .label{color:var(--gold);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em}
.byelect .sub{color:#bfdbfe;font-size:.875rem;margin-top:.25rem}

/* Leader */
.leader-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;max-width:1000px;margin:0 auto}
@media(min-width:1024px){.leader-grid{grid-template-columns:1fr 1.2fr}}
.leader-photo{position:relative;border-radius:1.25rem;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5;background:linear-gradient(135deg,var(--navy),#1e40af)}
.leader-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.leader-photo .badge{position:absolute;bottom:-1rem;right:-1rem;background:var(--red);color:#fff;padding:.75rem 1.25rem;border-radius:.75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;box-shadow:var(--shadow)}
.leader-info h3{font-size:1.6rem;margin-bottom:.5rem}
.leader-info .role{color:var(--red);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;margin-bottom:1.5rem}
.leader-info p{margin-bottom:1rem;color:var(--gray-600)}

/* Stand-for grid */
.bg-gray{background:var(--gray-50)}
.stand-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;max-width:1000px;margin:0 auto}
@media(min-width:1024px){.stand-grid{grid-template-columns:1fr 1fr}}
.stand-image{aspect-ratio:4/3;background:linear-gradient(135deg,var(--navy),var(--red));border-radius:1.25rem;box-shadow:var(--shadow-lg);background-size:cover;background-position:center}
.stand-list{display:flex;flex-direction:column;gap:2rem}
.stand-item{display:flex;gap:1.25rem}
.stand-item .icon{width:48px;height:48px;border-radius:.75rem;background:rgba(13,27,110,.1);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.5rem}
.stand-item h3{font-size:1.1rem;margin-bottom:.25rem}
.stand-item p{font-size:.875rem;color:var(--gray-600)}

/* Principles */
.grid-3{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.principle{background:#fff;border:1px solid var(--gray-100);border-radius:1.25rem;padding:1.75rem;box-shadow:var(--shadow-sm);transition:all .25s}
.principle:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.principle .icon{width:56px;height:56px;border-radius:1rem;background:rgba(13,27,110,.08);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.25rem;transition:.3s}
.principle:hover .icon{background:var(--navy);color:#fff}
.principle h3{font-size:1.1rem;margin-bottom:.75rem}
.principle p{font-size:.875rem;color:var(--gray-500)}

/* Leaders grid */
.leaders-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
@media(min-width:640px){.leaders-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.leaders-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1280px){.leaders-grid{grid-template-columns:repeat(5,1fr)}}
.leader-card{background:#fff;border-radius:1.25rem;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;text-align:center}
.leader-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.leader-card .pic{aspect-ratio:1;background:linear-gradient(135deg,var(--navy),#1e40af);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:2rem;font-weight:800;background-size:cover;background-position:top}
.leader-card .info{padding:1rem}
.leader-card h3{font-size:.875rem;line-height:1.3;margin-bottom:.25rem}
.leader-card p{font-size:.75rem;color:var(--gray-500)}

/* News cards */
.news-grid{display:grid;grid-template-columns:1fr;gap:1.75rem}
@media(min-width:768px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.news-grid{grid-template-columns:repeat(3,1fr)}}
.news-card{background:#fff;border:1px solid var(--gray-100);border-radius:1.25rem;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;display:flex;flex-direction:column}
.news-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.news-card .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--navy),#1e40af);background-size:cover;background-position:center;overflow:hidden}
.news-card .body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.news-card .date{color:var(--red);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:.5rem}
.news-card h3{font-size:1rem;line-height:1.35;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-card .excerpt{font-size:.875rem;color:var(--gray-500);margin-bottom:1rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.news-card a.read{color:var(--navy);font-weight:600;font-size:.875rem;display:inline-flex;align-items:center;gap:.4rem}
.news-card a.read:hover{color:var(--red)}

/* Section header */
.section-head-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:3rem}
.section-head-row h2{font-size:clamp(1.6rem,3vw,2.25rem)}
.section-head-row .underline{width:56px;height:4px;background:var(--red);border-radius:2px;margin-top:.75rem}

/* CTA */
.cta-section{background:var(--navy);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-section h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1rem}
.cta-section h2 span{color:var(--gold)}
.cta-section p{color:#bfdbfe;font-size:1.1rem;max-width:600px;margin:0 auto 2.5rem}

/* Partners */
.partners{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;align-items:center;max-width:1100px;margin:0 auto}
@media(min-width:640px){.partners{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.partners{grid-template-columns:repeat(6,1fr)}}
.partner{text-align:center}
.partner .logo{width:120px;height:90px;background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;display:flex;align-items:center;justify-content:center;padding:.75rem;margin:0 auto .65rem;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.partner .logo img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(20%);transition:.2s}
.partner:hover .logo{border-color:var(--navy);box-shadow:0 4px 12px rgba(0,0,0,.08);transform:translateY(-2px)}
.partner:hover .logo img{filter:grayscale(0%)}
.partner p{font-size:.72rem;color:var(--gray-600);max-width:140px;margin:0 auto;line-height:1.3;font-weight:500}

/* ---------- Forms ---------- */
.page-header{background:var(--navy);color:#fff;padding:4rem 0;text-align:center;position:relative;overflow:hidden}
.page-header h1{color:#fff;font-size:clamp(2rem,5vw,3rem);margin-bottom:.75rem}
.page-header .eyebrow{color:var(--gold);font-size:.75rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.75rem;display:block}
.page-header p{color:#bfdbfe;max-width:640px;margin:0 auto}

.form-card{background:#fff;border-radius:1.25rem;box-shadow:var(--shadow);overflow:hidden;max-width:900px;margin:0 auto}
.form-section{padding:1.5rem;border-bottom:1px solid var(--gray-100)}
.form-section:last-child{border-bottom:0}
.form-section h2{font-size:1.05rem;color:var(--navy);font-family:'Inter',sans-serif;font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.form-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:640px){.form-grid{grid-template-columns:1fr 1fr}}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--gray-700);margin-bottom:.4rem}
.form-group label .req{color:var(--red)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--gray-200);border-radius:.75rem;font-size:.9rem;font-family:inherit;transition:.2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--navy);box-shadow:0 0 0 3px rgba(13,27,110,.15)}
.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--red);background:#fef2f2}
.form-group .err-msg{color:var(--red);font-size:.75rem;margin-top:.35rem;display:flex;align-items:center;gap:.25rem}
.checkbox-row{background:var(--gray-50);padding:1rem;border-radius:.75rem;display:flex;gap:.75rem;align-items:flex-start;font-size:.875rem;color:var(--gray-700)}
.checkbox-row input{margin-top:.2rem;flex-shrink:0}
.alert{padding:1rem;border-radius:.75rem;margin-bottom:1rem;font-size:.875rem;display:flex;gap:.5rem;align-items:flex-start}
.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}

/* Membership tier picker */
.tier-picker{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:600px;margin:0 auto 2rem}
.tier-pick{position:relative;background:#fff;border:2px solid var(--gray-200);border-radius:1rem;padding:1.25rem;cursor:pointer;text-align:left;transition:.2s}
.tier-pick:hover{border-color:var(--gray-300)}
.tier-pick input{position:absolute;opacity:0}
.tier-pick.selected{border-color:var(--navy);background:var(--light)}
.tier-pick .badge-mini{position:absolute;top:.75rem;right:.75rem;background:var(--gold);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.1em}
.tier-pick .name{font-weight:700;color:var(--navy)}
.tier-pick .price{font-size:1.5rem;font-weight:800;color:var(--navy);margin-top:.25rem}
.tier-pick .sub{font-size:.7rem;color:var(--gray-500)}

/* Membership tier cards */
.tier-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:900px;margin:0 auto}
@media(min-width:768px){.tier-grid{grid-template-columns:1fr 1fr}}
.tier-card{background:#fff;border-radius:1.25rem;box-shadow:var(--shadow);overflow:hidden;border:2px solid transparent}
.tier-card.premium{border-color:var(--navy)}
.tier-card .head{padding:2rem;color:#fff}
.tier-card.premium .head{background:var(--navy)}
.tier-card .head h2{color:#fff;font-size:1.5rem;margin-bottom:.25rem}
.tier-card.normal .head{background:var(--gray-50);color:var(--navy)}
.tier-card.normal .head h2{color:var(--navy)}
.tier-card .head .price{font-size:2.5rem;font-weight:800;margin-top:.75rem}
.tier-card.premium .price{color:var(--red)}
.tier-card.normal .price{color:var(--navy)}
.tier-card .head .sub{font-size:.875rem;opacity:.8;margin-left:.5rem;font-weight:400}
.tier-card .body{padding:2rem}
.tier-card ul{margin-bottom:1.5rem}
.tier-card ul li{padding:.4rem 0;font-size:.875rem;color:var(--gray-700);display:flex;gap:.5rem;align-items:flex-start}
.tier-card ul li::before{content:"✓";color:var(--navy);font-weight:700;flex-shrink:0}
.tier-card .btn-block{display:block;width:100%;text-align:center;padding:.85rem;border-radius:.75rem;font-weight:700;font-size:.875rem}

/* Steps */
.steps-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin:3rem 0}
@media(min-width:640px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.steps-grid{grid-template-columns:repeat(4,1fr)}}
.step{text-align:center}
.step .num{width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;margin:0 auto 1rem}
.step h3{font-size:1rem;margin-bottom:.5rem}
.step p{font-size:.875rem;color:var(--gray-500)}

.join-methods{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:2rem}
@media(min-width:768px){.join-methods{grid-template-columns:repeat(3,1fr)}}
.join-card{background:var(--gray-50);padding:1.75rem;border-radius:1.25rem;text-align:center}
.join-card.dark{background:var(--navy);color:#fff}
.join-card.dark h3,.join-card.dark a{color:#fff}
.join-card .icon{width:48px;height:48px;border-radius:.75rem;background:rgba(13,27,110,.1);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin:0 auto 1rem}
.join-card.dark .icon{background:rgba(255,255,255,.1);color:#fff}
.join-card h3{margin-bottom:.5rem;font-size:1rem}
.join-card p{font-size:.875rem;color:var(--gray-500);margin-bottom:1rem}
.join-card.dark p{color:#bfdbfe}

/* News article */
.article-body{background:#fff;border-radius:1.25rem;box-shadow:var(--shadow);overflow:hidden;max-width:760px;margin:0 auto}
.article-body .thumb{aspect-ratio:16/9;background-size:cover;background-position:center;background-color:var(--navy)}
.article-body .body{padding:2rem}
@media(min-width:768px){.article-body .body{padding:3rem}}
.article-body h1{font-size:clamp(1.6rem,4vw,2.25rem);margin-bottom:1.5rem;line-height:1.2}
.article-meta{display:flex;flex-wrap:wrap;gap:1rem;color:var(--gray-400);font-size:.75rem;margin-bottom:1.25rem}
.article-excerpt{font-size:1.05rem;color:var(--gray-600);font-style:italic;border-left:4px solid var(--red);padding-left:1.25rem;margin-bottom:2rem;font-weight:500}
.article-content p{margin-bottom:1rem;color:var(--gray-700)}

.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--navy);font-weight:600;font-size:.875rem;margin-bottom:2rem}
.back-link:hover{color:var(--red)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;max-width:1100px;margin:0 auto}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}
.contact-info-item{display:flex;gap:1rem}
.contact-info-item .icon{width:48px;height:48px;border-radius:.75rem;background:rgba(13,27,110,.1);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.contact-info-item h3{font-size:1rem;margin-bottom:.25rem}
.contact-info-item p{font-size:.875rem;color:var(--gray-600);white-space:pre-line}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#fff;margin-top:4rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;padding:3.5rem 1rem}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:repeat(4,1fr)}}
.brand--footer .brand__logo{background:rgba(255,255,255,.1)}
.brand--footer .brand__name{color:#fff}
.brand--footer .brand__tag{color:var(--red)}
.footer-blurb{color:#bfdbfe;font-size:.875rem;margin:1.25rem 0;line-height:1.7}
.socials{display:flex;gap:.75rem}
.socials a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.socials a:hover{background:rgba(255,255,255,.2);color:#fff}
.site-footer h4{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.2);font-family:'Inter',sans-serif;font-weight:700}
.site-footer ul li{padding:.3rem 0}
.site-footer ul li a{color:#bfdbfe;font-size:.875rem;display:flex;align-items:center;gap:.5rem}
.site-footer ul li a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0;transition:.2s}
.site-footer ul li a:hover{color:#fff}
.site-footer ul li a:hover::before{background:var(--red)}
.contact-list li{color:#bfdbfe;font-size:.875rem;line-height:1.6}
.contact-list li a{color:#bfdbfe}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom__inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1.25rem 0;color:#93c5fd;font-size:.85rem}
.footer-bottom__inner a{color:#93c5fd;margin-left:1rem}
.footer-bottom__inner a:hover{color:#fff}

/* ---------- Admin ---------- */
.admin-layout{min-height:100vh;display:flex;background:var(--gray-50)}
.admin-sidebar{width:240px;background:var(--navy);color:#fff;padding:1.5rem 1rem;flex-shrink:0}
.admin-sidebar h2{color:#fff;font-size:1rem;margin-bottom:1.5rem;font-family:'Inter',sans-serif}
.admin-sidebar nav a{display:block;padding:.6rem .85rem;color:#bfdbfe;border-radius:.5rem;font-size:.875rem;margin-bottom:.25rem}
.admin-sidebar nav a:hover,.admin-sidebar nav a.active{background:rgba(255,255,255,.1);color:#fff}
.admin-main{flex:1;padding:2rem;overflow-x:auto}
.admin-main h1{font-size:1.6rem;margin-bottom:1.5rem;font-family:'Inter',sans-serif}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:#fff;padding:1.25rem;border-radius:.75rem;box-shadow:var(--shadow-sm)}
.stat-card .label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.stat-card .value{font-size:1.75rem;font-weight:800;color:var(--navy)}
.admin-table{width:100%;background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);border-collapse:collapse}
.admin-table th{background:var(--gray-50);padding:.85rem 1rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-600);font-weight:600;border-bottom:1px solid var(--gray-200)}
.admin-table td{padding:.85rem 1rem;font-size:.875rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}
.admin-table tr:hover td{background:var(--gray-50)}
.badge{display:inline-block;padding:.2rem .65rem;border-radius:9999px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.badge.pending{background:#fef3c7;color:#92400e}
.badge.approved{background:#dcfce7;color:#166534}
.badge.rejected{background:#fee2e2;color:#991b1b}
.btn-sm{padding:.4rem .8rem;border-radius:.5rem;font-size:.75rem;font-weight:600;border:0;cursor:pointer;text-decoration:none;display:inline-block;margin-right:.25rem}
.btn-sm.green{background:#16a34a;color:#fff}
.btn-sm.red{background:#dc2626;color:#fff}
.btn-sm.gray{background:var(--gray-200);color:var(--gray-700)}

.login-card{max-width:420px;margin:6rem auto;background:#fff;padding:2.5rem;border-radius:1.25rem;box-shadow:var(--shadow-lg)}
.login-card h1{text-align:center;margin-bottom:.5rem}
.login-card p.subtitle{text-align:center;color:var(--gray-500);margin-bottom:2rem;font-size:.875rem}

.success-card{max-width:520px;margin:6rem auto;background:#fff;border-radius:1.25rem;box-shadow:var(--shadow-lg);padding:2.5rem;text-align:center}
.success-card .check{width:80px;height:80px;border-radius:50%;background:#dcfce7;color:#16a34a;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.5rem}
.success-card h2{margin-bottom:.75rem}
.success-card p{color:var(--gray-600);margin-bottom:2rem}
.success-card .actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}

/* Misc */
.text-center{text-align:center}
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}
.empty-state{text-align:center;padding:4rem 1rem;color:var(--gray-400)}
.empty-state h3{color:var(--gray-500);margin-bottom:.5rem}

/* fade in */
.fade-in{animation:fadeInUp .7s ease forwards}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ===== page.php content blocks ===== */
.prose-section{padding:4rem 0;background:#fff}
.prose{max-width:780px;margin:0 auto;color:var(--gray-700,#374151);font-size:1.0625rem;line-height:1.75}
.prose h3{font-family:'Playfair Display',serif;color:var(--navy);margin:2rem 0 .75rem;font-size:1.5rem}
.prose ul{padding-left:1.25rem;margin:1rem 0}
.prose li{margin:.5rem 0}
.prose .lead{font-size:1.125rem;color:var(--gray-600,#4b5563);margin-bottom:1.5rem}
.prose a{color:var(--red);font-weight:600;text-decoration:underline}

.docs-section{padding:4rem 0;background:#f8fafc}
.docs-section .lead{max-width:760px;margin:0 auto 2rem;color:var(--gray-500);font-size:1.0625rem;text-align:center}
.docs-list{display:grid;gap:1rem;max-width:780px;margin:0 auto}
.doc-card{display:flex;gap:1rem;align-items:center;background:#fff;border-radius:1rem;padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);border-left:4px solid var(--gold);transition:.2s}
.doc-card:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.doc-card__icon{font-size:2rem;flex-shrink:0}
.doc-card__body{flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.doc-card__body h3{font-size:1rem;color:var(--navy);margin:0;flex:1;min-width:200px}

.leader-hero{padding:4rem 0;background:#fff}
.leader-hero__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:center}
.leader-hero__img img{width:100%;border-radius:1.25rem;box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/5}
.leader-hero__copy h2{font-family:'Playfair Display',serif;color:var(--navy);font-size:2rem;margin:.5rem 0 1rem}
.leader-hero__copy p{color:var(--gray-600,#4b5563);line-height:1.75;margin-bottom:1rem}
@media(max-width:820px){.leader-hero__grid{grid-template-columns:1fr}}

.leadership-section{padding:4rem 0;background:#f8fafc}
.leaders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}
.leader-card img{width:100%;aspect-ratio:1;object-fit:cover;object-position:top}
.leader-card h4{font-size:.95rem;color:var(--navy);margin:.75rem .75rem .25rem}
.leader-card p{font-size:.75rem;color:var(--red);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:0 .75rem 1rem}

.principles-section{padding:4rem 0;background:#fff}
.principles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.principle-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.75rem;transition:.25s;border-top:4px solid var(--red)}
.principle-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-top-color:var(--red)}
.principle-card__icon{font-size:2.25rem;margin-bottom:.75rem}
.principle-card h3{color:var(--navy);font-size:1.125rem;margin-bottom:.5rem}
.principle-card p{color:var(--gray-500);line-height:1.6;font-size:.95rem}

.gallery-section{padding:4rem 0;background:#f8fafc}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery-item{display:block;border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;aspect-ratio:4/3;background:#000}
.gallery-item:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery-item:hover img{transform:scale(1.08);opacity:.9}

.empty-state-section{padding:5rem 0;background:#f8fafc}
.empty-state-section .empty-state{max-width:560px;margin:0 auto;background:#fff;padding:3rem 2rem;border-radius:1.25rem;box-shadow:var(--shadow);text-align:center;color:var(--gray-600,#4b5563)}
.empty-state-section .empty-state__icon{font-size:3.5rem;margin-bottom:1rem}
.empty-state-section .empty-state h2{font-family:'Playfair Display',serif;color:var(--navy);margin-bottom:.75rem}
.empty-state-section .empty-state p{margin-bottom:1.25rem;line-height:1.7}
.empty-state-section .empty-state a.btn{margin-top:.5rem}
.empty-state-section .empty-state a:not(.btn){color:var(--red);font-weight:600}

/* ---------- Membership: tier grid (3 + 4 column) ---------- */
.tier-grid--3{max-width:1200px}
@media(min-width:900px){.tier-grid--3{grid-template-columns:repeat(3,1fr)}}
.tier-grid--4{max-width:1400px}
@media(min-width:768px){.tier-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1200px){.tier-grid--4{grid-template-columns:repeat(4,1fr);gap:1.5rem}}

/* ---------- Platinum tier card (premium structure, shiny silver accent) ---------- */
.tier-card.platinum{
  border-color:var(--red);
  position:relative;
  box-shadow:0 20px 50px rgba(0,0,0,.18), 0 0 0 1px rgba(192,196,204,.35);
}
@media(min-width:1024px){ .tier-card.platinum{ transform:translateY(-8px) } }
.tier-card.platinum::before{
  content:"MOST PRESTIGIOUS";
  position:absolute;top:18px;right:-38px;
  background:var(--red);
  color:#1a1a1a;font-size:.62rem;font-weight:800;
  letter-spacing:.15em;padding:.35rem 2.75rem;
  transform:rotate(35deg);z-index:2;
  box-shadow:0 4px 12px rgba(0,0,0,.25);
}
/* Match premium head: solid navy background, white text, silver price */
.tier-card.platinum .head{
  background:var(--navy)
}
.tier-card.platinum .head h2{color:#fff}
.tier-card.platinum .price{
  background:var(--red);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.tier-card.platinum ul li::before{color:var(--red);content:"♛"}
.tier-card.platinum .btn-block.btn-red{
  background:var(--red);
  color:#1a1a1a;border:none;
  box-shadow:0 6px 18px rgba(138,142,150,.45);
  transition:transform .2s, box-shadow .2s, filter .2s;
}
.tier-card.platinum .btn-block.btn-red:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(138,142,150,.6);
  filter:brightness(1.05);
  color:#000;
}

/* ---------- Diaspora tier card ---------- */
.tier-card.diaspora{
  border-color:var(--navy);
  position:relative;
}
.tier-card.diaspora .head{background:linear-gradient(135deg,var(--navy),#1a2e9e)}
.tier-card.diaspora .head h2{color:#fff}
.tier-card.diaspora .price{color:#fff}
.tier-card.diaspora ul li::before{color:var(--navy);content:"🌍"}

/* ---------- Tier picker (3 + 4 column) ---------- */
.tier-picker--3{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.tier-picker--3{grid-template-columns:repeat(3,1fr)}}
.tier-picker--4{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.tier-picker--4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.tier-picker--4{grid-template-columns:repeat(4,1fr)}}
