:root {
  --base-width-sp: 375;
}

/* ハンバーガーメニューの非表示状態 */
.hamburger-menu[hidden] {
  display: none !important;
}

/* ハンバーガーメニュー全体 */
.hamburger-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #FEE600;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: calc(40 / var(--base-width-sp) * 100vw);
  gap: calc(50 / var(--base-width-sp) * 100vw);
  z-index: 2000;
  overflow-y: auto;
  pointer-events: auto;
}

/* 上ブロック */
.hamburger-header {
  width: calc(325 / var(--base-width-sp) * 100vw);
  height: calc(60 / var(--base-width-sp) * 100vw);
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 1000;
}
.hamburger-logo {
  width: calc(119 / var(--base-width-sp) * 100vw);
  height: calc(40 / var(--base-width-sp) * 100vw);
  background: url("../assets/images/logo/sumaizero-logo-charwhite.png") no-repeat center left;
  background-size: contain;
}

.hamburger-close {
  position: relative;
  width: calc(34 / var(--base-width-sp) * 100vw);  /* Figma指定 */
  height: calc(34 / var(--base-width-sp) * 100vw); /* ← 高さも確保 */
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  z-index: 1;
}

.hambuerger-close-line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 0;
  border-top: calc(2 / var(--base-width-sp) * 100vw) solid #231815;
  transform-origin: center;
}

.hambuerger-line-1 {
  transform: translate(-50%, -50%) rotate(30deg);
}

.hambuerger-line-2 {
  transform: translate(-50%, -50%) rotate(-30deg);
}


/* 中ブロック */
.hamburger-links {
  width: calc(300 / var(--base-width-sp) * 100vw);
  display: flex;
  flex-direction: column;
  gap: calc(50 / var(--base-width-sp) * 100vw);
  align-items: flex-start;
}
.hambuerger-main-links,
.hambuerger-policy-links {
  display: flex;
  flex-direction: column;
}
.hambuerger-main-links {
  gap: calc(26 / var(--base-width-sp) * 100vw);
}
.hambuerger-policy-links {
  gap: calc(25 / var(--base-width-sp) * 100vw);
}
.hamburger-links a {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: calc(14 / var(--base-width-sp) * 100vw);
  line-height: 1.5;
  color: #231815;
  text-decoration: none;
  display: flex;
  align-items: center;
  letter-spacing: 0.05em;
}
.hambuerger-policy-links a {
  font-size: calc(12 / var(--base-width-sp) * 100vw);
  font-weight: 500;
}

/* 中央ロゴ */
.hamburger-footer-logo {
  width: calc(180 / var(--base-width-sp) * 100vw);
  height: calc(61 / var(--base-width-sp) * 100vw);
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
}

.hamburger-footer-logo img {
  width: 100%;
  height: auto;
  display: block;
  image-rendering: auto;
  -webkit-backface-visibility: hidden;
  -webkit-transform: translateZ(0); /* Safari対策 */
}


/* 下ブロック */
.hamburger-footer {
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(30 / var(--base-width-sp) * 100vw);
}

.hamburger-footer-info p {
  margin: 0; /* ← これで段落の余白をゼロに */
}
.hamburger-footer-info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(10 / var(--base-width-sp) * 100vw);
  width: calc(233 / var(--base-width-sp) * 100vw);
}
.hamburger-footer-address,
.hamburger-footer-contact {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: calc(12 / var(--base-width-sp) * 100vw);
  font-weight: 700;
  line-height: 1.5;
  color: #231815;
  letter-spacing: 0.05em;
}
.hambuerger-postal-code {
  font-size: calc(14 / var(--base-width-sp) * 100vw);
}
.hamburger-footer-copy {
  font-size: calc(10 / var(--base-width-sp) * 100vw);
  font-weight: 500;
  color: #231815;
  letter-spacing: 0.05em;
  text-align: center;
}

