/* ═══════════════════════════════════════════════════════
   RENAISSANCE ASSOCIATION — GLOBAL STYLESHEET
═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Cinzel:wght@400;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

/* ── TOKENS ── */
:root {
  --navy:        #0b1130;
  --navy-mid:    #111d45;
  --navy-light:  #1a2a5e;
  --navy-deep:   #070c20;
  --gold:        #f0c040;
  --gold-bright: #ffd966;
  --gold-dim:    #b8922a;
  --gold-glow:   rgba(240,192,64,.22);
  --white:       #ffffff;
  --off-white:   #e8dfc8;
  --muted:       #9aa3c0;
  --card:        linear-gradient(145deg,rgba(17,29,69,.92),rgba(11,17,48,.96));
  --border:      rgba(240,192,64,.18);
  --tr:          .3s ease;
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--navy);
  color:var(--off-white);
  font-family:'Cormorant Garamond',Georgia,serif;
  overflow-x:hidden;
  min-height:100vh;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* noise texture */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  opacity:.45;
}

/* ── TYPOGRAPHY HELPERS ── */
.label  { font-family:'Cinzel',serif; font-size:.64rem; font-weight:700; letter-spacing:.4em; text-transform:uppercase; color:var(--gold); }
.title  { font-family:'Cinzel Decorative',serif; font-size:clamp(1.8rem,4vw,3.2rem); font-weight:700; color:var(--white); line-height:1.08; }
.title .g { color:var(--gold); }
.gold-bar { width:72px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); margin:1rem 0 2rem; }
.gold-bar.c { margin-left:auto; margin-right:auto; }

/* ── BUTTONS ── */
.btn-gold {
  display:inline-block; font-family:'Cinzel',serif; font-size:.75rem; font-weight:700;
  letter-spacing:.15em; color:var(--navy);
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  padding:.85rem 2.2rem;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  transition:filter var(--tr),transform var(--tr),box-shadow var(--tr);
  box-shadow:0 6px 28px rgba(240,192,64,.28);
  border:none;
}
.btn-gold:hover { filter:brightness(1.12); transform:translateY(-2px); box-shadow:0 10px 38px rgba(240,192,64,.38); }
.btn-ghost {
  display:inline-block; font-family:'Cinzel',serif; font-size:.75rem; font-weight:600;
  letter-spacing:.15em; color:var(--gold);
  border:1px solid rgba(240,192,64,.45); padding:.85rem 2.2rem;
  transition:background var(--tr),border-color var(--tr),transform var(--tr);
}
.btn-ghost:hover { background:rgba(240,192,64,.08); border-color:var(--gold); transform:translateY(-2px); }

/* ── NAV ── */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem 5%;
  background:rgba(7,11,30,.93); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:padding var(--tr);
}
#nav.scrolled { padding:.65rem 5%; }
.nav-brand { display:flex; align-items:center; gap:.7rem; }
.nav-brand-name { font-family:'Cinzel',serif; font-size:.88rem; font-weight:700; color:var(--gold); letter-spacing:.1em; line-height:1.2; }
.nav-brand-name span { display:block; font-size:.58rem; font-weight:400; color:var(--muted); letter-spacing:.22em; }
.nav-menu { display:flex; align-items:center; gap:2.2rem; }
.nav-menu a {
  font-family:'Cinzel',serif; font-size:.68rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--off-white);
  transition:color var(--tr); position:relative;
}
.nav-menu a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:1px; background:var(--gold); transform:scaleX(0); transition:transform var(--tr);
}
.nav-menu a:hover, .nav-menu a.active { color:var(--gold); }
.nav-menu a:hover::after, .nav-menu a.active::after { transform:scaleX(1); }
.nav-cta {
  font-family:'Cinzel',serif; font-size:.68rem; font-weight:700; letter-spacing:.14em;
  color:var(--navy); background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  padding:.48rem 1.3rem; clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);
  transition:filter var(--tr);
}
.nav-cta:hover { filter:brightness(1.12); }
.ham { display:none; flex-direction:column; gap:5px; padding:4px; }
.ham span { display:block; width:24px; height:2px; background:var(--gold); transition:.3s; }
.ham.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.ham.open span:nth-child(2) { opacity:0; }
.ham.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── PAGE HERO BANNER (inner pages) ── */
.page-banner {
  min-height:38vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:8rem 5% 4rem; position:relative; overflow:hidden;
}
.page-banner-bg {
  position:absolute; inset:0; z-index:0;
  background:radial-gradient(ellipse 80% 60% at 50% 30%,rgba(240,192,64,.1) 0%,transparent 65%),
             linear-gradient(170deg,var(--navy-deep) 0%,var(--navy) 60%,var(--navy-mid) 100%);
}
.page-banner-bg::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(240,192,64,.03) 40px),
             repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(240,192,64,.03) 40px);
}
.page-banner .inner { position:relative; z-index:1; }
.page-banner .label { margin-bottom:.7rem; }
.page-banner .title { margin-bottom:.5rem; }
.banner-divider { width:120px; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); margin:.8rem auto 0; }

/* ── SECTION WRAPPER ── */
.sec { position:relative; z-index:1; }
.inner { max-width:1140px; margin:0 auto; padding:5.5rem 5%; }

/* ── REVEAL ANIMATION ── */
.reveal { opacity:0; transform:translateY(22px); transition:opacity .65s ease,transform .65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── CARDS ── */
.card {
  border:1px solid var(--border); background:var(--card);
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
}
.card:hover { border-color:rgba(240,192,64,.4); transform:translateY(-5px); box-shadow:0 16px 48px rgba(240,192,64,.08); }

/* ── FORMS ── */
.fld { display:flex; flex-direction:column; gap:.35rem; }
.fld label { font-family:'Cinzel',serif; font-size:.62rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.fld input,.fld select,.fld textarea {
  background:rgba(17,29,69,.65); border:1px solid var(--border);
  color:var(--white); font-family:'Cormorant Garamond',serif; font-size:1rem;
  padding:.75rem 1rem; outline:none;
  transition:border-color var(--tr),background var(--tr);
}
.fld input::placeholder,.fld textarea::placeholder { color:rgba(154,163,192,.45); }
.fld input:focus,.fld select:focus,.fld textarea:focus { border-color:rgba(240,192,64,.55); background:rgba(26,42,94,.45); }
.fld textarea { resize:vertical; min-height:110px; }
.fld select option { background:var(--navy-mid); }
.row2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

/* ── FOOTER ── */
footer {
  background:var(--navy-deep);
  border-top:1px solid var(--border);
}
.footer-top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:3rem; padding:4rem 5% 3rem; max-width:1140px; margin:0 auto;
}
.footer-brand-name { font-family:'Cinzel Decorative',serif; font-size:1.1rem; color:var(--gold); margin-bottom:.25rem; }
.footer-brand-tag { font-family:'Cinzel',serif; font-size:.58rem; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); margin-bottom:.9rem; }
.footer-brand-p { font-size:.92rem; color:var(--muted); line-height:1.72; }
.foot-col h4 { font-family:'Cinzel',serif; font-size:.68rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.9rem; }
.foot-col ul { display:flex; flex-direction:column; gap:.55rem; }
.foot-col li a { font-size:.9rem; color:var(--muted); transition:color var(--tr); }
.foot-col li a:hover { color:var(--gold); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.05);
  padding:1.3rem 5%; display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:1rem;
  max-width:1140px; margin:0 auto;
}
.footer-bottom p { font-size:.8rem; color:rgba(154,163,192,.5); }
.footer-socials { display:flex; gap:.6rem; }
.fsoc {
  width:32px; height:32px; border:1px solid rgba(240,192,64,.15);
  display:flex; align-items:center; justify-content:center; font-size:.88rem;
  color:var(--muted); transition:color var(--tr),border-color var(--tr);
}
.fsoc:hover { color:var(--gold); border-color:rgba(240,192,64,.4); }

/* ── NEWSLETTER STRIP ── */
.nl-strip {
  background:linear-gradient(135deg,var(--navy-light),var(--navy-mid));
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.nl-inner {
  max-width:1140px; margin:0 auto; padding:3rem 5%;
  display:flex; align-items:center; justify-content:space-between; gap:3rem; flex-wrap:wrap;
}
.nl-text h3 { font-family:'Cinzel Decorative',serif; font-size:clamp(1.2rem,2.5vw,1.7rem); color:var(--white); margin-bottom:.3rem; }
.nl-text p { font-size:.98rem; color:var(--muted); }
.nl-form { display:flex; flex:1; max-width:460px; }
.nl-form input {
  flex:1; background:rgba(11,17,48,.7); border:1px solid var(--border); border-right:none;
  color:var(--white); font-family:'Cormorant Garamond',serif; font-size:1rem;
  padding:.78rem 1rem; outline:none; transition:border-color var(--tr);
}
.nl-form input::placeholder { color:rgba(154,163,192,.45); }
.nl-form input:focus { border-color:rgba(240,192,64,.5); }
.nl-form button {
  font-family:'Cinzel',serif; font-size:.68rem; font-weight:700; letter-spacing:.13em;
  color:var(--navy); background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  padding:.78rem 1.5rem; white-space:nowrap; transition:filter var(--tr);
}
.nl-form button:hover { filter:brightness(1.1); }

/* ── MEMBERSHIP MODAL ── */
#modal {
  position:fixed; inset:0; z-index:900; background:rgba(5,8,20,.96);
  display:none; align-items:center; justify-content:center; padding:2rem; overflow-y:auto;
}
#modal.open { display:flex; }
.modal-box {
  background:linear-gradient(145deg,#111d45,#0b1130);
  border:1px solid rgba(240,192,64,.25);
  max-width:640px; width:100%; padding:2.5rem; position:relative;
  animation:slideUp .4s ease; max-height:90vh; overflow-y:auto;
}
@keyframes slideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.modal-close { position:absolute; top:1rem; right:1.2rem; font-size:1.5rem; color:var(--gold); line-height:1; }
.modal-box h2 { font-family:'Cinzel Decorative',serif; font-size:1.5rem; color:var(--white); margin-bottom:.3rem; }
.modal-box .modal-sub { font-size:1rem; color:var(--muted); margin-bottom:1.5rem; }
.step-bar { display:flex; gap:.5rem; margin-bottom:2rem; }
.step-dot { flex:1; height:3px; background:rgba(240,192,64,.18); transition:background .4s; }
.step-dot.done { background:var(--gold); }
.form-step { display:none; flex-direction:column; gap:.9rem; }
.form-step.active { display:flex; }
.step-btns { display:flex; gap:.8rem; justify-content:flex-end; margin-top:.5rem; }
.step-btns .btn-ghost,.step-btns .btn-gold { padding:.6rem 1.4rem; font-size:.7rem; }
.success-msg { text-align:center; padding:2rem 0; }
.success-msg .check { font-size:3.5rem; margin-bottom:1rem; }
.success-msg h3 { font-family:'Cinzel Decorative',serif; font-size:1.4rem; color:var(--gold); margin-bottom:.5rem; }
.success-msg p { font-size:1rem; color:var(--muted); }

/* ── STATS STRIP ── */
.stats-strip {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:rgba(240,192,64,.08); border:1px solid var(--border);
}
.stat {
  background:linear-gradient(145deg,rgba(17,29,69,.9),rgba(11,17,48,.95));
  padding:2rem 1rem; text-align:center; transition:background var(--tr);
}
.stat:hover { background:rgba(26,42,94,.7); }
.stat-n { font-family:'Cinzel Decorative',serif; font-size:clamp(1.8rem,3vw,2.8rem); font-weight:900; color:var(--gold); line-height:1; }
.stat-l { font-family:'Cinzel',serif; font-size:.58rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-top:.3rem; }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .footer-top { grid-template-columns:1fr 1fr; gap:2rem; }
  .stats-strip { grid-template-columns:repeat(2,1fr); }
  .row2 { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  #nav { padding:.9rem 4%; }
  .nav-menu {
    display:none; position:fixed; top:66px; left:0; right:0;
    flex-direction:column; align-items:flex-start; gap:1.2rem;
    background:rgba(7,11,30,.97); padding:1.8rem 5%;
    border-bottom:1px solid var(--border);
  }
  .nav-menu.open { display:flex; }
  .nav-cta { display:none; }
  .ham { display:flex; }
  .nl-inner { flex-direction:column; gap:1.5rem; }
  .nl-form { max-width:100%; width:100%; }
  .footer-top { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
}
@media(max-width:480px) {
  .stats-strip { grid-template-columns:1fr 1fr; }
  .inner { padding:4rem 4%; }
}
</style>
