/* =========================================
   PAGE LAYOUT
   ========================================= */

html,
body{
  min-height: 100%;
}

body{
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.ss-site-wrap{
  flex: 1 0 auto;
  overflow: visible !important;
}

.ss-page{
  overflow: visible !important;
}

.ss-footer{
  flex-shrink: 0;
}

/* =========================================
   FOOTER — TRUE FULL WIDTH
   ========================================= */

.ss-footer{
  width: 100vw;
  max-width: 100vw;
  margin-top: auto;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 18px 0 12px;
  background: #222222;
  border-top: 1px solid rgba(255,255,255,.08);
  position: relative;
  left: 0;
  right: 0;
  z-index: 2;
  box-sizing: border-box;
}

.ss-footer-shell{
  width: 100%;
  max-width: none;
  margin: 0;
  padding-left: 42px;
  padding-right: 42px;
  box-sizing: border-box;
}

.ss-footer-inner{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ss-footer-top{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.ss-footer-brand{
  min-width: 260px;
  flex: 0 1 420px;
}

.ss-footer-title{
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 700;
  color: #ffffff;
}

.ss-footer-text{
  margin: 0;
  max-width: 420px;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(255,255,255,.75);
}

.ss-footer-links{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 18px;
  margin-left: auto;
}

.ss-footer-links a{
  font-size: 14px;
  line-height: 1.2;
  text-decoration: none;
  color: rgba(255,255,255,.85);
  border-bottom: 2px solid transparent;
  padding-bottom: 2px;
  transition: all .18s ease;
}

.ss-footer-links a:hover{
  color: #ffffff;
  border-bottom-color: #e11d2a;
}

.ss-footer-links a[href*="wp-admin"],
.ss-footer-links a[href*="admin"]{
  margin-left: 28px;
  font-weight: 600;
}

.ss-footer-bottom{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: 12px;
  color: rgba(255,255,255,.6);
}

/* =========================================
   PREVENT PANEL SHADOW CLIPPING
   ========================================= */

.ss-page,
.ss-site-wrap,
.ss-shell,
.ss-page-shell,
.ss-main,
.ss-content{
  overflow: visible !important;
}

/* if your CTA panel is the last module above the footer */
.csp-marketing-cta,
.csp-marketing-panel,
.csp-work-panel,
.csp-home-panel,
.ss-panel,
.ss-glass{
  overflow: visible !important;
}

/* =========================================
   MOBILE
   ========================================= */

@media (max-width: 768px){
  .ss-footer-shell{
    padding-left: 16px;
    padding-right: 16px;
  }

  .ss-footer-top{
    flex-direction: column;
    align-items: flex-start;
  }

  .ss-footer-links{
    margin-left: 0;
    justify-content: flex-start;
    gap: 12px;
  }

  .ss-footer-links a[href*="wp-admin"],
  .ss-footer-links a[href*="admin"]{
    margin-left: 0;
  }

  .ss-footer-bottom{
    flex-direction: column;
    align-items: flex-start;
  }
}
/* =========================================
   CTA SHADOW CLIP FIX
   ========================================= */

.csp-marketing-page-wrap,
.csp-marketing-panel,
.csp-marketing-hero,
.csp-marketing-cta,
.csp-marketing-cta__inner,
.csp-page-shell,
.csp-shell,
.ss-page,
.site,
.site-content,
.content-area,
.entry-content,
.site-main,
main{
  overflow: visible !important;
}

/* give the CTA shadow room to render downward */
.csp-marketing-cta{
  position: relative;
  z-index: 3;
  margin-bottom: 28px !important;
}

/* if the CTA itself has the shadow */
.csp-marketing-cta,
.csp-marketing-cta__inner{
  box-shadow:
    0 30px 80px rgba(0,0,0,.45),
    0 12px 30px rgba(0,0,0,.25) !important;
}

/* keep footer above background, but below content shadow flow */
.ss-footer{
  position: relative;
  z-index: 2;
}