:root{
  --navy:#191A2E;        /* matches the logo background exactly */
  --navy-soft:#23212F;
  --panel:#21243F;
  --panel-hover:#2A2D4D;
  --gold:#C7A15B;
  --gold-bright:#E2C386;
  --cream:#F4EFE4;
  --muted:#9A9AB0;
  --line:rgba(199,161,91,0.28);
  --maxw:540px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--navy);
  color:var(--cream);
  font-family:"EB Garamond",Georgia,serif;
  font-size:18px;
  line-height:1.6;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:48px 22px;
  position:relative;
  overflow-x:hidden;
}

/* soft radial glow echoing the banner's lit ellipse */
.bg-glow{
  position:fixed;
  top:-10%;left:50%;
  width:1100px;height:1100px;
  transform:translateX(-50%);
  background:radial-gradient(closest-side,
     rgba(199,161,91,0.10),
     rgba(35,33,47,0.55) 45%,
     transparent 70%);
  pointer-events:none;
  z-index:0;
}

.hub{
  position:relative;
  z-index:1;
  width:100%;
  max-width:var(--maxw);
  text-align:center;
}

/* ---- header ---- */
.hub-head{margin-bottom:34px}
.logo{
  width:min(440px,84%);
  height:auto;
  border-radius:14px;
  display:block;
  margin:0 auto 22px;
  /* logo art sits on the same navy, so it blends; soft frame on hover only */
}
.tagline{
  font-family:"Playfair Display",serif;
  font-style:italic;
  font-size:1.18rem;
  line-height:1.4;
  color:var(--gold-bright);
  max-width:24em;
  margin:0 auto 22px;
}
.lede{
  color:var(--muted);
  font-size:1.02rem;
  max-width:32em;
  margin:0 auto 14px;
}
.lede:last-of-type{margin-bottom:0}

/* ---- link cards ---- */
.links{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:6px;
}
.link-card{
  display:flex;
  align-items:center;
  gap:16px;
  text-decoration:none;
  color:var(--cream);
  background:var(--panel);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:14px;
  padding:16px 18px;
  text-align:left;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.link-card:hover,
.link-card:focus-visible{
  background:var(--panel-hover);
  border-color:var(--line);
  transform:translateY(-2px);
  outline:none;
}
.link-card:focus-visible{box-shadow:0 0 0 2px var(--gold)}

.link-primary{
  background:linear-gradient(135deg,#2A2D4D,#23263F);
  border-color:var(--line);
}

.link-mark{
  flex:0 0 46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(199,161,91,0.12);
  color:var(--gold-bright);
  font-size:1.05rem;
  border:1px solid var(--line);
}
.link-text{flex:1 1 auto;line-height:1.3}
.link-text strong{
  font-family:"Playfair Display",serif;
  font-weight:600;
  font-size:1.16rem;
  color:var(--cream);
  display:block;
}
.link-text small{
  color:var(--muted);
  font-size:0.92rem;
}
.link-arrow{
  flex:0 0 auto;
  color:var(--gold);
  font-size:1.2rem;
  transition:transform .18s ease;
}
.link-card:hover .link-arrow{transform:translateX(4px)}
.link-quiet{background:transparent;border-style:dashed;border-color:rgba(255,255,255,0.14)}
.link-quiet:hover{background:var(--navy-soft)}

/* ---- contact form ---- */
.contact{margin-top:40px;text-align:center}
.contact h2{
  font-family:"Playfair Display",serif;
  font-weight:600;
  font-size:1.7rem;
  color:var(--cream);
  margin-bottom:8px;
}
.contact-intro{
  color:var(--muted);
  font-size:0.98rem;
  max-width:30em;
  margin:0 auto 22px;
}
.contact-form{text-align:left}
.form-row{
  display:flex;
  gap:14px;
}
.contact-form label{
  display:block;
  flex:1 1 0;
  margin-bottom:14px;
  font-size:0.86rem;
  letter-spacing:0.04em;
  color:var(--muted);
}
.contact-form input,
.contact-form textarea{
  width:100%;
  margin-top:6px;
  background:#15172A;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:10px;
  padding:11px 13px;
  color:var(--cream);
  font-family:"EB Garamond",serif;
  font-size:1rem;
  transition:border-color .18s ease, box-shadow .18s ease;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(199,161,91,0.22);
}
.contact-form textarea{resize:vertical;min-height:108px}

/* honeypot — hidden from people, bots fill it (Web3Forms 'botcheck') */
.hp{
  position:absolute!important;
  left:-9999px!important;
  width:1px;height:1px;
  opacity:0;
  overflow:hidden;
}

.h-captcha{margin:6px 0 16px}

.submit-btn{
  display:inline-flex;
  align-items:center;
  gap:9px;
  background:linear-gradient(135deg,var(--gold),#B68F49);
  color:#1B1B22;
  font-family:"Playfair Display",serif;
  font-weight:600;
  font-size:1.02rem;
  border:none;
  border-radius:11px;
  padding:12px 26px;
  cursor:pointer;
  transition:transform .18s ease, filter .18s ease;
}
.submit-btn:hover{transform:translateY(-2px);filter:brightness(1.06)}
.submit-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(199,161,91,0.5)}

.form-status{
  min-height:1.2em;
  margin-top:12px;
  font-size:0.95rem;
  color:var(--muted);
}
.form-status.ok{color:#7FD1A6}
.form-status.err{color:#E1937F}

@media (max-width:440px){
  .form-row{flex-direction:column;gap:0}
}

/* ---- footer ---- */
.hub-foot{margin-top:34px;text-align:center}
.rule{
  width:64px;height:1px;
  background:var(--gold);
  opacity:.5;
  margin:0 auto 16px;
}
.copyright{
  color:var(--muted);
  font-size:0.85rem;
  letter-spacing:0.04em;
}

@media (max-width:420px){
  body{padding:34px 16px}
  .link-text strong{font-size:1.08rem}
  .tagline{letter-spacing:0.26em;font-size:0.76rem}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none!important}
}
