/* ==========================================================================
   components-footer.css
   フッター（メニュー / 会社情報 / 地図 / コピーライト）
   方針：
   - フッター内だけで完結
   - 数値・色はコックピット管理
   ========================================================================== */

/* ==========================================================================
   01) Footer Base
   ========================================================================== */

.l-footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
}

.l-footer a,
.l-footer p,
.l-footer li,
.l-footer small {
  color: var(--footer-text);
}

/* base.css の p 影響をフッター内で無効化 */
.l-footer p {
  padding: 0;
  padding-block-end: 0;
}

.l-footer a:hover {
  color: var(--footer-link-hover);
}

/* ==========================================================================
   02) Menu
   ========================================================================== */

.l-footer__menuTitle {
  font-size: var(--footer-menu-title-size);
  font-weight: 600;
  margin-bottom: var(--footer-menu-title-gap);
}

.l-footer__menu {
  margin: 0;
  padding: 0;
  list-style: none;
}

.l-footer__menu li {
  margin-bottom: var(--footer-menu-row-gap);
}

/* ==========================================================================
   03) Company Info
   ========================================================================== */

.l-footer__company {
  margin-top: var(--footer-company-top);
  padding-top: var(--footer-company-pad-top);
  padding-bottom: var(--footer-company-pad-bottom);
}

.l-footer__shop-name {
  font-size: var(--footer-shop-size);
  font-weight: 700;
  padding-top: var(--footer-shop-top);
  padding-bottom: var(--footer-shop-bottom);
}

.l-footer__company p {
  margin: 0 0 var(--footer-company-row-gap);
  line-height: var(--footer-company-line);
  padding: 0;
  padding-block-end: 0;
}

.l-footer__access {
  font-size: var(--footer-access-size);
}

.l-footer__tel {
  margin-top: var(--footer-tel-top);
}

.l-footer__tel a {
  font-weight: var(--footer-tel-weight);
  font-size: var(--footer-tel-size);
  letter-spacing: var(--footer-tel-letter);
}

/* ==========================================================================
   04) Copyright
   ========================================================================== */

.l-footer__copyright {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  text-align: center;
  padding-bottom: var(--footer-copyright-bottom);
}

/* ==========================================================================
   05) Layout（60 : 40）
   ========================================================================== */

.l-footer__row--top {
  display: flex;
  flex-direction: row;
  padding-bottom: var(--footer-row-bottom);
}

.l-footer__col--links {
  flex: 0 0 60%;
  display: flex;
  flex-direction: column;
  padding-top: var(--footer-links-top);
}

.l-footer__col--map {
  flex: 0 0 40%;
  padding-top: var(--footer-map-top);
  padding-left: 0px;
  padding-bottom: var(--footer-map-bottom);
  box-sizing: border-box;
}

/* ==========================================================================
   06) Map
   ========================================================================== */

.l-footer__map-frame {
  padding: var(--footer-map-frame-pad);
  border-radius: var(--footer-map-frame-radius);
  background: rgba(255, 255, 255, 0.15);
  overflow: hidden;
  box-sizing: border-box;
}

.l-footer__col--map iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: var(--footer-map-aspect);
  border: 0;
  border-radius: var(--footer-map-radius);
  background: #fff;
}
