/* ============================================================
   JM Ford Law - SHARED clean header + footer component
   Source of truth for the site-wide chrome. The markup lives in
   partials/header.html + partials/footer.html and is injected into
   every page by build.py. This file:
     1) hides Duda's original (tangled, inconsistent) header/footer
     2) styles our clean replacement, fully self-contained so it
        renders identically on every page regardless of Duda's
        per-page inline CSS.
   Brand: maroon #622936, dark #4a1c24, tan #a4938a, light #ece3de
   ============================================================ */

/* ---------- 1. Hide Duda's original chrome ---------- */
.dmHeaderContainer,
.hamburger-header-container,
.p_hfcontainer.showOnMedium,
#hamburger-drawer,
.dmFooterContainer{display:none!important}

/* Duda's footer CONTENT rows live in the page body (NOT inside
   .dmFooterContainer), so the container-hide above missed them and they
   rendered as a duplicate footer above ours on most pages. These ids are
   the site-wide footer rows: main (logo/address/links), disclaimer, and
   copyright. Hide them so only our clean #jmf-footer remains. */
.u_1407485680,   /* footer main row */
.u_1139021877,   /* disclaimer row  */
.u_1218650007,   /* copyright wrapper */
.u_1266359710{display:none!important}   /* copyright inner */

/* Site-wide pre-footer Google map renders the whole world on every page -
   useless clutter. Keep it only on the Contact page (re-pointed to Portland);
   hide it everywhere else. */
.u_1751602384{display:none!important}
body[data-page-alias="contact"] .u_1751602384{display:block!important}

/* Duda gave the hero `header-over-content` (absolute header overlay) and
   reserved top space for it. With our header in normal flow we don't need
   that reservation, but leaving it is harmless. */

/* ---------- 2. Shared box-sizing for our components ---------- */
#jmf-header *,#jmf-footer *{box-sizing:border-box}
#jmf-header,#jmf-footer{
  font-family:"Open Sans","Helvetica Neue",Arial,sans-serif;
  line-height:1.4;-webkit-font-smoothing:antialiased}

/* ============================== HEADER ============================== */
#jmf-header{
  position:sticky;top:0;z-index:9000;
  background:#ffffff;
  box-shadow:0 1px 8px rgba(0,0,0,.12);
  border-bottom:3px solid #622936}
#jmf-header .jmf-bar{
  display:flex;align-items:center;gap:18px;
  max-width:1200px;margin:0 auto;padding:8px 22px}

#jmf-header .jmf-logo{flex:0 0 auto;display:flex;align-items:center}
#jmf-header .jmf-logo img{display:block;height:62px;width:auto}

#jmf-header .jmf-nav{flex:1 1 auto;display:flex;justify-content:center}
#jmf-header .jmf-menu{
  list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:4px}
#jmf-header .jmf-menu>li{position:relative}
#jmf-header .jmf-menu a{
  display:block;text-decoration:none;color:#4a1c24;
  font-size:15px;font-weight:600;padding:10px 12px;border-radius:4px;
  white-space:nowrap;transition:background .15s,color .15s}
#jmf-header .jmf-menu>li>a:hover{background:#f3eceb;color:#622936}
#jmf-header .jmf-caret{
  display:inline-block;width:0;height:0;margin-left:5px;vertical-align:middle;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;opacity:.7}

/* dropdowns */
#jmf-header .jmf-sub{
  list-style:none;margin:0;padding:6px 0;
  position:absolute;top:100%;left:0;min-width:248px;
  background:#fff;border:1px solid #eadfdd;border-top:3px solid #622936;
  box-shadow:0 8px 22px rgba(0,0,0,.16);border-radius:0 0 6px 6px;
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .15s,transform .15s,visibility .15s;z-index:9100}
#jmf-header .jmf-has-sub:hover>.jmf-sub,
#jmf-header .jmf-has-sub:focus-within>.jmf-sub{
  opacity:1;visibility:visible;transform:translateY(0)}
#jmf-header .jmf-sub a{
  padding:9px 18px;font-weight:500;font-size:14px;border-radius:0;color:#4a1c24}
#jmf-header .jmf-sub a:hover{background:#f3eceb;color:#622936}

/* phone CTA */
#jmf-header .jmf-cta{
  flex:0 0 auto;text-decoration:none;display:flex;flex-direction:column;
  align-items:center;line-height:1.15;
  background:#622936;color:#fff;padding:9px 18px;border-radius:6px;
  transition:background .15s}
#jmf-header .jmf-cta:hover{background:#4a1c24}
#jmf-header .jmf-cta-top{font-size:16px;font-weight:700;letter-spacing:.2px}
#jmf-header .jmf-cta-sub{font-size:11px;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.5px}

/* hamburger (hidden on desktop) */
#jmf-header .jmf-nav-toggle{display:none}
#jmf-header .jmf-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;
  padding:10px;margin-left:auto}
#jmf-header .jmf-burger span{display:block;width:26px;height:3px;background:#622936;border-radius:2px;transition:.2s}

/* ---------- header responsive ---------- */
@media (max-width:980px){
  #jmf-header .jmf-bar{flex-wrap:wrap;gap:10px;padding:8px 16px}
  #jmf-header .jmf-logo img{height:52px}
  #jmf-header .jmf-burger{display:flex;order:3}
  #jmf-header .jmf-cta{order:2;margin-left:auto;padding:7px 14px}
  #jmf-header .jmf-cta-top{font-size:14px}
  #jmf-header .jmf-nav{order:4;flex:0 0 100%;display:none}
  #jmf-header .jmf-nav-toggle:checked ~ .jmf-nav{display:block}
  #jmf-header .jmf-nav-toggle:checked ~ .jmf-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  #jmf-header .jmf-nav-toggle:checked ~ .jmf-burger span:nth-child(2){opacity:0}
  #jmf-header .jmf-nav-toggle:checked ~ .jmf-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  #jmf-header .jmf-menu{flex-direction:column;align-items:stretch;gap:0;
    border-top:1px solid #eadfdd;padding:6px 0}
  #jmf-header .jmf-menu>li{border-bottom:1px solid #f1e9e8}
  #jmf-header .jmf-menu a{padding:13px 8px;font-size:16px}
  #jmf-header .jmf-caret{float:right;margin-top:8px}
  /* on mobile, show submenus inline (always expanded, indented) */
  #jmf-header .jmf-sub{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;border-top:0;min-width:0;padding:0 0 6px;
    background:#faf6f5;border-radius:0}
  #jmf-header .jmf-sub a{padding:10px 8px 10px 26px;font-size:15px}
}

/* ============================== FOOTER ============================== */
#jmf-footer{background:#622936;color:#ece3de;margin-top:0}
#jmf-footer a{color:#f1e7e3;text-decoration:none}
#jmf-footer a:hover{color:#fff;text-decoration:underline}
#jmf-footer h3{
  color:#fff;font-size:15px;letter-spacing:.6px;text-transform:uppercase;
  margin:0 0 14px;font-weight:700}

#jmf-footer .jmf-foot-main{
  max-width:1200px;margin:0 auto;padding:46px 24px 30px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
#jmf-footer .jmf-foot-logo{display:block;height:84px;width:auto;margin-bottom:16px}
#jmf-footer .jmf-foot-addr{margin:0;font-size:14px;line-height:1.7}
#jmf-footer .jmf-foot-addr strong{color:#fff;display:inline-block;margin-bottom:4px}

#jmf-footer ul{list-style:none;margin:0;padding:0}
#jmf-footer .jmf-foot-contact li,
#jmf-footer .jmf-foot-links li{margin:0 0 11px;font-size:14px}

#jmf-footer .jmf-foot-disclaimer{
  border-top:1px solid rgba(255,255,255,.16)}
#jmf-footer .jmf-foot-disclaimer p{
  max-width:1200px;margin:0 auto;padding:22px 24px;
  font-size:12px;line-height:1.7;color:#d8c8c3}

#jmf-footer .jmf-foot-bottom{background:rgba(0,0,0,.18)}
#jmf-footer .jmf-foot-bottom p{
  max-width:1200px;margin:0 auto;padding:16px 24px;
  font-size:12.5px;color:#e8dcd7;text-align:center}

@media (max-width:760px){
  #jmf-footer .jmf-foot-main{grid-template-columns:1fr;gap:30px;padding:34px 22px 26px}
  #jmf-footer .jmf-foot-bottom p{font-size:11.5px;line-height:1.8}
}
