/* Formidio — layout.css : shell, grid, header, footer, sections */

/* ---- App grid (named template areas) ---- */
.app {
  display: grid;
  grid-template-areas:
    "header"
    "main"
    "footer";
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
}
.module--main   { grid-area: main; }
.module--footer { grid-area: footer; }

.module { position: relative; }
.module__inner { width: 100%; }
.module__content { display: flex; align-items: center; }

.cnt {
  width: var(--shell);
  max-width: 100%;
  margin: 0 auto;
  padding-left: var(--space-3);
  padding-right: var(--space-3);
}

/* ---- Page transition (desktop-first default) ---- */
.page-transition { animation: slideIn 0.5s ease; }
@keyframes slideIn {
  from { transform: translateX(-2.5rem); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

/* ---- Header (sticky top) ---- */
.module--header {
  grid-area: header;
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-line);
}
[data-mm-header] {
  --mm-bg: #ffffff;
  --mm-text: #2a2d38;
  --mm-primary: #e2542b;
  --mm-overlay-bg: rgba(27, 32, 48, 0.55);
}
.bar { padding-top: var(--space-2); padding-bottom: var(--space-2); }
.logo {
  font-family: Georgia, serif;
  font-size: 1.7rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-decoration: none;
  color: var(--color-ink);
}
.logo b { color: var(--color-primary); font-weight: 700; }

.burger { color: var(--color-text); }
.burger span { border-radius: 2px; }

.nav { font-family: -apple-system, 'Segoe UI', Roboto, sans-serif; }
.nav__overlay { backdrop-filter: blur(1px); }
.nav__list { gap: var(--space-1); }
.nav__link {
  font-family: -apple-system, 'Segoe UI', Roboto, sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  color: var(--color-text);
}
.nav__link:hover { color: var(--color-primary); }
.nav__cta {
  background: var(--color-primary);
  color: #fff !important;
  border-radius: 3px;
  padding: 0.5rem 1rem !important;
}
.nav__cta:hover { background: var(--color-primary-dark); }
.nav__close { color: var(--color-ink); }

/* ---- Sections ---- */
.module--section { padding: var(--space-5) 0; }
.section--tight { padding: var(--space-4) 0; }
.band-light { background: var(--color-bg); color: var(--color-text); }
.band-soft  { background: var(--color-bg-soft); color: var(--color-text); }
.band-dark  { background: var(--color-ink); color: var(--color-light); }
.band-dark h1, .band-dark h2, .band-dark h3 { color: #fff; }

.section__head { max-width: 40rem; margin-bottom: var(--space-4); }
.section__head.is-centered { margin-left: auto; margin-right: auto; text-align: center; }
.section__head p { color: var(--color-muted); margin-top: var(--space-1); }
.band-dark .section__head p { color: #b9bcc8; }

/* ---- Footer ---- */
.module--footer { background: var(--color-ink); color: var(--color-light); }
.foot { padding: var(--space-5) 0 var(--space-3); }
.foot__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.3fr;
  gap: var(--space-4);
}
.foot__brand .logo { color: #fff; }
.foot__tag { color: #aab; margin-top: var(--space-1); font-size: 1rem; }
.foot__col h4 {
  font-family: -apple-system, 'Segoe UI', Roboto, sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #f0a98f;
  margin-bottom: var(--space-2);
}
.foot__links li { margin-bottom: 0.5rem; }
.foot__links a {
  text-decoration: none;
  color: #c7c9d4;
  font-size: 0.98rem;
}
.foot__links a:hover { color: #fff; }
.foot__info { color: #c7c9d4; font-size: 0.95rem; line-height: 1.85; }
.foot__info a { color: #c7c9d4; }
.foot__bottom {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-2);
}
.foot__bottom small { color: #8b8e9c; }
.foot__note { color: #8b8e9c; font-size: 0.85rem; max-width: 34rem; }
.cc-footer-link, .cc-footer-separator { color: #c7c9d4 !important; }

/* ---- Tablet ---- */
@media (max-width: 1024px) {
  .cnt { width: 46rem; padding-left: var(--space-2); padding-right: var(--space-2); }
  .module--section { padding: var(--space-4) 0; }
  .foot__grid { grid-template-columns: 1fr 1fr; }
}

/* ---- Mobile : accordion-collapse behaviour ---- */
@media (max-width: 768px) {
  .cnt { width: 100%; }
  .foot__grid { grid-template-columns: 1fr; gap: var(--space-3); }
  .page-transition { animation: none; }

  .section--collapsible .section__head { cursor: pointer; }
  .section--collapsible .section__head::after {
    content: "+";
    float: right;
    font-size: 1.6rem;
    line-height: 1;
    color: var(--color-primary);
  }
  .section--collapsible.is-open .section__head::after { content: "\2013"; }
  .section--collapsible .section__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
  }
  .section--collapsible.is-open .section__content { max-height: 4000px; }
}

@media (prefers-reduced-motion: reduce) {
  .page-transition { animation: none; }
  .section--collapsible .section__content { transition: none; }
}

/* ---- Mobile menu : slide-top functional CSS (module) ---- */
[data-mm-header]{--mm-bg:#ffffff;--mm-text:#333333;--mm-primary:#2563eb;--mm-overlay-bg:rgba(0,0,0,0.5);--mm-transition:0.3s ease}[data-mm-header]{position:relative}[data-mm-toggle]{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}[data-mm-toggle] span{display:block;width:24px;height:2px;background:var(--mm-text);transition:var(--mm-transition)}[data-mm-menu]{position:fixed;top:0;left:0;width:100%;background:var(--mm-bg);transform:translateY(-100%);transition:transform var(--mm-transition);z-index:1100;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;padding:60px 24px 24px;box-shadow:0 4px 20px rgba(0,0,0,0.1)}[data-mm-menu].mm-open{transform:translateY(0)}[data-mm-menu] ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}[data-mm-menu] ul li a{display:block;padding:14px 0;color:var(--mm-text);text-decoration:none;font-size:16px;border-bottom:1px solid rgba(0,0,0,0.08);transition:color var(--mm-transition)}[data-mm-menu] ul li a:hover{color:var(--mm-primary)}[data-mm-close]{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--mm-text);padding:4px 8px}[data-mm-overlay]{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--mm-overlay-bg);opacity:0;visibility:hidden;transition:opacity var(--mm-transition),visibility var(--mm-transition);z-index:1050}[data-mm-overlay].mm-visible{opacity:1;visibility:visible}@media(min-width:768px){[data-mm-toggle]{display:none!important}[data-mm-menu]{position:static!important;width:auto!important;height:auto!important;background:transparent!important;transform:none!important;padding:0!important;overflow:visible!important;flex-direction:row!important;box-shadow:none!important}[data-mm-menu] ul{flex-direction:row;gap:0;align-items:center}[data-mm-menu] ul li a{padding:8px 16px;border-bottom:none;font-size:inherit}[data-mm-close]{display:none!important}[data-mm-overlay]{display:none!important}}@media(prefers-reduced-motion:reduce){[data-mm-menu],[data-mm-overlay],[data-mm-toggle] span{transition:none!important}}

/* ---- Mobile menu : Formidio palette (override module defaults) ---- */
[data-mm-header] {
  --mm-bg: #ffffff;
  --mm-text: #2a2d38;
  --mm-primary: #e2542b;
  --mm-overlay-bg: rgba(27, 32, 48, 0.55);
}
