/* =========================================================
   Base Reset & Layout
   ========================================================= */
html, body {
  width: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  overflow-x: hidden;
}
*, *::before, *::after { box-sizing: inherit; }
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--page-bg, #fff);
  color: var(--color-text, #111);
  font-family: var(--header-font, ui-sans-serif, system-ui, sans-serif);
}

/* =========================================================
   HEADER (two rows: primary 3-col + secondary buttons)
   ========================================================= */

/* Root variables. PHP sets: --header-primary-h, --color-primary, --header-font */
:root{
  /* Buttons sizing */
  --btn-font: 1.07em;
  --btn-lh: 1.17;
  --btn-vpad: 0.38em;
  --btn-hpad: 1.20em;
  --btn-bottom-gap: 5px;

  /* Computed secondary height */
  --header-secondary-h: calc((var(--btn-font) * var(--btn-lh)) + (2 * var(--btn-vpad)) + var(--btn-bottom-gap));

  /* If a page adds --header-h / --btn-row-h, keep compatible */
  --header-total-h: calc(var(--header-primary-h, 64px) + var(--header-secondary-h));
}

/* Shell */
.site-header {
  width: 100%;
  background: var(--header-bg, #fff);
  color: var(--header-text, #111);
  font-family: var(--header-font, ui-sans-serif, system-ui, sans-serif);
  position: relative;
  z-index: 10;
  box-shadow: 0 4px 18px rgba(40,44,52,.10);
  transition: background .3s, box-shadow .23s;
}
.site-header.sticky { position: sticky; top: 0; }
.site-header.fixed  { position: fixed;  top: 0; left: 0; width: 100%; }

/* ROW 1: 3 columns (left | center | right) */
.header-primary {
  min-height: var(--header-primary-h, 80px);
  display: grid;
  grid-template-columns: minmax(0,1fr) auto minmax(0,1fr);
  align-items: center;           /* center-align all elements vertically */
  column-gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* slots */
.header-left  { justify-self: start;  display: flex; align-items: center; gap: .8rem; min-width: 0; }
.header-center{ justify-self: center; display: flex; align-items: center; gap: .8rem; min-width: 0; }
.header-right { justify-self: end;   display: flex; align-items: center; gap: .8rem; min-width: 0; }

/* logo + icons */
.header-logo img {
  display: block;
  max-height: var(--header-primary-h, 80px);
  height: auto;
}
.header-custom-ico { height: 32px; max-width: 32px; margin: 0 5px; }

/* menu button */
.header-primary .menu-btn { margin-left: 0 !important; }
.menu-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: inherit;
  font-size: 1.6rem;
  line-height: 1;
}

/* ROW 2: buttons row (full width) */
.site-header .header-secondary { margin-top: 0; padding-top: 0; }
.header-secondary {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem var(--btn-bottom-gap);
  display: grid;
  align-items: start;     /* anchor to top */
  align-content: start;
  justify-items: center;
  gap: .6rem;
  min-height: var(--header-secondary-h);
}
.site-header.btn-count-1 .header-secondary { grid-template-columns: 1fr; }
.site-header.btn-count-2 .header-secondary { grid-template-columns: 1fr 1fr; }
.site-header.btn-count-3plus .header-secondary {
  grid-template-columns: repeat(auto-fit, minmax(140px,1fr));
}

/* Buttons */
.header-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--btn-vpad) var(--btn-hpad);
  font-size: var(--btn-font);
  font-weight: 700;
  border-radius: 2.2em;
  border: none;
  box-shadow: 0 2px 12px rgba(0,0,0,0.09);
  cursor: pointer;
  text-align: center;
  margin: 0 0.18em;
  text-decoration: none !important;
  line-height: var(--btn-lh);
  letter-spacing: 0.02em;
  user-select: none;
  transition: background .22s, color .17s, box-shadow .17s, transform .16s;
  will-change: background, color, box-shadow, transform;
  color: #fff;
}
.header-btn:active { transform: scale(.98) rotate(-2deg); }

/* Button variants (uses --color-primary/secondary from PHP, with fallbacks) */
.btn-solid {
  background: var(--color-primary, #bb3739);
  color: #fff;
  border: none;
}
.btn-solid:hover, .btn-solid:focus { background: var(--color-secondary, #9a2b2d); color: #fff; }

.btn-outline {
  background: transparent;
  color: var(--header-text, #111);
  border: 2px solid currentColor;
  box-shadow: none;
}
.btn-outline:hover, .btn-outline:focus {
  background: var(--color-primary, #bb3739);
  color: #fff;
  border-color: var(--color-secondary, #9a2b2d);
}

.btn-pill {
  background: linear-gradient(90deg, var(--color-secondary, #0f94aa) 0%, var(--color-primary, #bb3739) 100%);
  color: #fff;
  border-radius: 44em;
  border: none;
  font-weight: 800;
  letter-spacing: 0.035em;
  box-shadow: 0 3px 12px rgba(40,60,99,0.13);
}
.btn-pill:hover, .btn-pill:focus {
  background: linear-gradient(90deg, var(--color-primary, #bb3739) 0%, var(--color-secondary, #0f94aa) 100%);
  color: #fff;
}

/* mobile tweaks */
@media (max-width:640px) {
  .header-primary { column-gap: .75rem; }
  .header-left, .header-center, .header-right { gap: .6rem; }
  .header-secondary { gap: .5rem; }
  .header-custom-ico { height: 26px; max-width: 26px; }
  .header-btn { font-size: 0.97em; padding: 0.45em 1.02em; }
}

/* =========================================================
   MAIN CONTENT
   ========================================================= */
.site-main { 
  width: 100%; 
  flex: 1 0 auto; 
  padding-top: var(--header-total-h); 
  padding-bottom: 0; 
}

/* Fixed header → already has padding-top, no additional offset needed */
body:has(.site-header.fixed) .site-main { 
  /* padding-top already set above */ 
}

/* Footer fixed → content offset by footer height */
body.footer-fixed .site-main { padding-bottom: var(--footer-h); }

/* =========================================================
   SECTIONS (Outer stripes & inner container)
   ========================================================= */
.site-section {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto 10px auto;
  padding: 0;
  background: transparent !important;
  box-sizing: border-box;
}
.site-section:first-child { margin-top: 0; }

.section-inner {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
  display: block;
}
.section-inner > *:first-child { margin-top: 0; }
.section-inner > *:last-child  { margin-bottom: 20px; }

@media (max-width: 1440px) { .section-inner { max-width: 100%; } }
@media (max-width: 980px) {
  .section-inner { width: 100%; max-width: 100%; }
  .header-inner, .footer-inner { max-width: 98vw; padding-left: 0.5rem; padding-right: 0.5rem; }
  .site-section { margin-bottom: 14px; }
}
@media (max-width: 600px) {
  .section-inner { width: 100%; max-width: 100vw; }
  .header-inner, .footer-inner { padding: 0 0.4rem; max-width: 100vw; font-size: 0.97em; }
  .site-section { margin-bottom: 10px; }
}

/* =========================================================
   CARD LAYOUT — 2-col mobile stack guard + centering on wrap
   ========================================================= */
@media (max-width: 980px) {
  .block-card-layout .card-content-block {
    flex-wrap: wrap !important;
    justify-content: center !important;
    row-gap: 1.2em;
  }
  .block-card-layout .card-content-block > .card-image-area,
  .block-card-layout .card-content-block > .card-text-area {
    min-width: min(520px, 100%) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .block-card-layout .card-content-block > .card-text-area {
    text-align: center !important;
    padding-left: 0 !important;
  }
}
@media (max-width: 600px) {
  .block-card-layout .card-content-block > .card-image-area,
  .block-card-layout .card-content-block > .card-text-area {
    max-width: 100% !important;
  }
}

/* =========================================================
   FOOTER (from /templates/footer.php, variable-driven)
   ========================================================= */
.site-footer {
  width: 100%;
  background: var(--footer-bg);
  color: var(--footer-fg);
}
.site-footer.fixed {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
}
.site-footer .footer-inner {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto minmax(0,1fr);
  align-items: center;
  column-gap: 16px;
  row-gap: 8px;
  padding: 12px 16px;
  min-height: var(--footer-h, 90px);
  box-sizing: border-box;
  width: 100%;
}
.site-footer .footer-inner > div {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex-wrap: nowrap;
}
/* Column justifications in desktop mode */
.site-footer .footer-inner > div:nth-child(1) { justify-content: flex-start; }
.site-footer .footer-inner > div:nth-child(2) { justify-content: center; }
.site-footer .footer-inner > div:nth-child(3) { justify-content: flex-end; }

.site-footer .footer-text { max-width: 100%; line-height: 1.35; }
.site-footer .footer-text p { margin: 0; }

.site-footer a { color: inherit; text-decoration: none; }
.site-footer a:hover, .site-footer a:focus { opacity: .9; }

.site-footer .footer-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25em;
  height: 2.25em;
  min-width: 36px;
  min-height: 36px;
}
.site-footer i { color: currentColor; }

/* Breakpoint: when stacking into 3 rows, center ALL content */
@media (max-width: 600px) {
  .site-footer .footer-inner {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
  .site-footer .footer-inner > div {
    justify-content: center !important;
    text-align: center !important;
  }
  .site-footer img {
    max-width: 65vw;
    height: auto;
  }
}

/* =========================================================
   PWA Install Banner
   ========================================================= */
#pwaInstallBanner[hidden]{display:none!important;}
#pwaInstallBanner{
  position:fixed;
  left:12px; right:12px; bottom:12px;
  z-index:9999;
  background:#fff;
  border:1px solid rgba(0,0,0,.1);
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.15);
  padding:12px 14px;
  display:flex; align-items:center; gap:10px;
}
#pwaInstallBanner .msg{flex:1}
#pwaInstallBanner .btn{
  border:0; border-radius:999px; padding:8px 14px; cursor:pointer
}
#pwaInstallBanner .btn.install{
  background: var(--color-primary, #bb3739);
  color:#fff; font-weight:600
}
#pwaInstallBanner .btn.close{ background:#eee }
