
.fd *,.fd *::before,.fd *::after{margin:0;padding:0;box-sizing:border-box;}
.fd a{text-decoration:none;}


/* ════════════════════════════════════════════
   FOOTER D — FULL GREEN TAKEOVER (Enhanced)
   ════════════════════════════════════════════ */

.fd{
  background:#6BB416;
  position:relative;
  overflow:hidden;
  font-family:'DM Sans',sans-serif;
}

/* giant watermark bg text */
.fd::before{
  content:'MRGREENDC';
  position:absolute;
  bottom:-24px;left:50%;transform:translateX(-50%);
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(100px,16vw,220px);
  letter-spacing:-4px;
  color:rgba(0,0,0,0.07);
  white-space:nowrap;
  pointer-events:none;user-select:none;
  line-height:1;
}

.fd-inner{position:relative;z-index:1;}

/* —— HERO ROW —— */
.fd-hero{
  padding:24px 64px 28px;
  border-bottom:1px solid rgba(0,0,0,0.1);
  display:grid;
  grid-template-columns:1fr auto;
  gap:48px;
  align-items:end;
}

h2.fd-big,
.fd h2.fd-big,
.fd-hero h2.fd-big,
footer.fd h2.fd-big,
footer h2.fd-big{
  font-family:'Bebas Neue',sans-serif !important;
  font-size:clamp(54px,10.5vw,135px) !important;
  letter-spacing:-3px !important;
  line-height:0.88 !important;
  color:#0a0a0a !important;
  margin:0 !important;
  padding:0 !important;
  max-width:none !important;
  min-height:auto !important;
}

/* —— HOURS BAR —— */
.fd-hours-bar{
  display:flex;align-items:center;justify-content:center;
  gap:32px;
  padding:14px 64px;
  background:rgba(0,0,0,0.08);
  border-bottom:1px solid rgba(0,0,0,0.08);
  font-family:'IBM Plex Mono',monospace;
  font-size:12px;color:#0a0a0a;
}
.fd-hours-bar strong{font-weight:700;}
.fd-hours-bar .fd-hb-sep{width:4px;height:4px;border-radius:50%;background:rgba(0,0,0,0.3);}
.fd-hours-bar a{color:#0a0a0a;font-weight:600;text-decoration:none;transition:color 0.2s;}
.fd-hours-bar a:hover{color:#fff;}
.fd-subtitle{
  font-family:'Bebas Neue',sans-serif !important;
  font-size:clamp(27px,5.25vw,67px) !important;
  letter-spacing:2px !important;
  color:rgba(0,0,0,0.35) !important;
  text-transform:uppercase;
  margin-top:4px !important;
  line-height:1 !important;
}
.fd-big .white{color:#fff !important;}
.fd-big .outline{
  -webkit-text-stroke:2px rgba(0,0,0,0.3) !important;
  color:transparent !important;
}

.fd-hero-right{
  display:flex;flex-direction:column;
  align-items:flex-end;gap:20px;
  flex-shrink:0;min-width:280px;
}

/* —— STARS + RATING —— */
.fd-rating{
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
}

.fd-stars{
  display:flex;align-items:center;gap:3px;
}
.fd-star{
  width:22px;height:22px;
  background:#0a0a0a;
  clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
}

.fd-rating-text{
  font-family:'IBM Plex Mono',monospace;
  font-size:12px;font-weight:500;
  color:rgba(0,0,0,0.5);
  letter-spacing:0.5px;
}
.fd-rating-text strong{color:rgba(0,0,0,0.75);font-weight:700;}

/* phone + address */
.fd-contact-block{
  text-align:right;
}

.fd-phone{
  display:flex;align-items:center;justify-content:flex-end;gap:8px;
  font-family:'Bebas Neue',sans-serif;
  font-size:28px;letter-spacing:1px;
  color:#0a0a0a;
  transition:color 0.2s;
  margin-bottom:4px;
}
.fd-phone:hover{color:#fff;}
.fd-phone svg{opacity:0.5;}

.fd-address-line{
  font-size:13px;color:#0a0a0a;
  font-weight:400;line-height:1.6;
}
.fd-address-line strong{color:#0a0a0a;font-weight:600;}

.fd-tagline{
  font-size:15px;font-weight:300;
  color:rgba(0,0,0,0.6);
  line-height:1.65;max-width:300px;text-align:right;
}

.fd-btns{display:flex;gap:10px;justify-content:flex-end;}

.fd-btn-dark{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:#0a0a0a;
  font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 28px;border-radius:3px;
}
.fd-btn-dark:hover{background:#fff;color:#0a0a0a;}

.fd-btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(0,0,0,0.12);color:rgba(0,0,0,0.55);
  font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 28px;border-radius:3px;
  transition:background 0.2s;
}
.fd-btn-ghost:hover{background:rgba(0,0,0,0.2);}

/* —— MAIN COLUMNS —— */
.fd-cols{
  display:grid;
  grid-template-columns:1fr 1fr 2fr;
  border-top:1px solid rgba(0,0,0,0.08);
}

.fd-col{
  padding:40px 40px;
  border-right:1px solid rgba(0,0,0,0.08);
}
.fd-col:last-child{border-right:none;}

.fd-col-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:#0a0a0a;
  margin-bottom:16px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(0,0,0,0.15);
}

/* mobile accordion chevron */
.fd-col-label .fd-chevron{display:none;}

.fd-col-links{list-style:none;}
.fd-col-links li{margin-bottom:7px;}
.fd-col-links a{
  font-size:14px;color:#0a0a0a;font-weight:400;
  transition:color 0.2s,background 0.2s;display:flex;align-items:center;gap:6px;
}
.fd-col-links a:hover{color:#fff;}

/* —— NEIGHBORHOOD GRID —— */
.fd-nbhd-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.fd-nbhd-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(0,0,0,0.18);
  border:1px solid rgba(0,0,0,0.2);
  border-radius:40px;
  padding:6px 14px;
  font-size:12px;font-weight:500;
  color:#0a0a0a;
  transition:background 0.2s,color 0.2s,border-color 0.2s;
  white-space:nowrap;
}
.fd-nbhd-pill:hover{
  background:#0a0a0a;
  color:#fff;
  border-color:#0a0a0a;
}

/* —— BOTTOM BAR —— */
.fd-bottom{
  background:rgba(0,0,0,0.12);
  padding:18px 64px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
  border-top:1px solid rgba(0,0,0,0.08);
}

.fd-bottom-left{display:flex;align-items:center;gap:24px;}
.fd-copy{
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;color:#0a0a0a;letter-spacing:1px;font-weight:500;
}

.fd-bottom-links{
  display:flex;gap:16px;
}
.fd-bottom-links a{
  font-size:11px;color:#0a0a0a;font-weight:500;
  transition:color 0.2s;letter-spacing:0.5px;
}
.fd-bottom-links a:hover{color:#fff;}

.fd-url{
  font-family:'IBM Plex Mono',monospace;
  font-size:12px;color:#0a0a0a;font-weight:600;
  letter-spacing:0.5px;
}

.fd-socials{display:flex;align-items:center;gap:10px;}
.fd-social{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;
  border-radius:50%;
  background:rgba(0,0,0,0.12);
  color:#0a0a0a;
  transition:background 0.2s,color 0.2s;
}
.fd-social:hover{background:#0a0a0a;color:#6BB416;}
.fd-social svg{width:16px;height:16px;}

.fd-open-badge{
  display:flex;align-items:center;gap:7px;
  font-size:11px;color:#0a0a0a;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;
}
.fd-open-dot{
  width:7px;height:7px;border-radius:50%;
  background:#0a0a0a;
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

/* —— RESPONSIVE —— */
@media(max-width:1100px){
  .fd-cols{grid-template-columns:1fr 1fr;}
  .fd-col:nth-child(2){border-right:none;}
  .fd-hours-bar{flex-wrap:wrap;padding:14px 28px;gap:12px;justify-content:center;text-align:center;}
}
@media(max-width:768px){
  .fd-hero{
    grid-template-columns:1fr;
    padding:48px 28px 36px;
    gap:32px;
  }
  .fd-hero-right{align-items:flex-start;}
  .fd-tagline{text-align:left;}
  .fd-btns{justify-content:flex-start;flex-wrap:wrap;}
  .fd-rating{align-items:flex-start;}
  .fd-contact-block{text-align:left;}
  .fd-phone{justify-content:flex-start;}
  .fd-cols{
    grid-template-columns:1fr;
  }
  .fd-hours-bar{flex-direction:column;gap:8px;padding:16px 28px;}
  .fd-hours-bar .fd-hb-sep{display:none;}
  .fd-col{border-right:none;border-bottom:1px solid rgba(0,0,0,0.08);padding:0;}
  .fd-col:last-child{border-bottom:none;}

  /* accordion */
  .fd-col-label{
    margin-bottom:0;
    padding:18px 28px;
    border-bottom:none;
    cursor:pointer;
    display:flex;align-items:center;justify-content:space-between;
    -webkit-user-select:none;user-select:none;
  }
  .fd-col-label .fd-chevron{
    display:block;
    width:12px;height:12px;
    border-right:2px solid rgba(0,0,0,0.35);
    border-bottom:2px solid rgba(0,0,0,0.35);
    transform:rotate(45deg);
    transition:transform 0.25s;
    flex-shrink:0;
  }
  .fd-col.open .fd-col-label .fd-chevron{
    transform:rotate(-135deg);
  }
  .fd-col-body{
    max-height:0;
    overflow:hidden;
    transition:max-height 0.3s ease, padding 0.3s ease;
    padding:0 28px;
  }
  .fd-col.open .fd-col-body{
    max-height:600px;
    padding:0 28px 20px;
  }

  .fd-bottom{
    padding:18px 28px;
    flex-direction:column;align-items:flex-start;gap:16px;
  }
}


