/* ============================================================
   ALZIS for MEN — Jimdo 独自CSS 完全版
   レスポンシブ / 1カラム / ハンバーガーナビ対応
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Noto+Serif+JP:wght@300;400&family=Montserrat:wght@300;400&display=swap');

/* ---- Variables ---- */
:root {
  --bg:     #131313;
  --bg2:    #272625;
  --cream:  #E6E2D4;
  --tan:    #D0C9AC;
  --khaki:  #ACA68D;
  --sage:   #8A8571;
  --hover:  #f0ece0;
  --rule:   rgba(145,141,124,0.21);
  --serif:  'Garamond', 'Noto Serif JP', 'ヒラギノ明朝 ProN', '游明朝', YuMincho, serif;
  --disp:   'Garamond', sans-serif;
  --max-w:  720px;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  background: var(--bg) !important;
  background-image: none !important;
  padding: 0 !important;
  margin: 0 !important;
  color: var(--cream);
  font-family: var(--serif);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
}

body p {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 300;
  line-height: 2.2;
  letter-spacing: 0.09em;
  color: var(--khaki);
}

a:link, a:visited {
  color: var(--tan);
  text-decoration: none;
}
a:hover {
  color: var(--hover);
  text-decoration: none;
}
a:active {
  color: var(--hover);
}

/* ============================================================
   CONTAINER
   ============================================================ */
#container {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  background: var(--bg) !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ============================================================
   HEADER
   ============================================================ */
#header {
  width: 100% !important;
  max-width: var(--max-w) !important;
  padding-top: 50px !important;
  padding-bottom: 40px !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  text-align: center !important;
  border-bottom: none !important;
  position: relative !important;
}

#header::after {
  content: none !important;
  display: none !important;
}

#header img {
  max-width: 220px !important;
  width: 55% !important;
  height: auto !important;
  display: block !important;
  margin: 0 auto !important;
}

#header h1,
#header a {
  font-family: var(--disp) !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.5em !important;
  color: var(--cream) !important;
  text-align: center !important;
  line-height: 1.8 !important;
  text-decoration: none !important;
  width: 100% !important;
  display: block;
}

/* ============================================================
   NAVIGATION — デスクトップ
   ============================================================ */
#navigation {
  width: 100% !important;
  max-width: var(--max-w);
  float: none !important;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--bg);
}

.alzis-hamburger-bar {
  display: none;
}

ul.mainNav1 {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  list-style: none;
  padding: 0 !important;
  margin: 0 !important;
}

ul.mainNav1 li {
  float: none !important;
  display: block !important;
  margin: 0 !important;
}

ul.mainNav1 li a,
ul.mainNav2 li a {
  font-family: var(--serif) !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.28em !important;
  color: var(--cream) !important;
  text-decoration: none !important;
  display: block !important;
  padding: 18px 18px !important;
  background: transparent !important;
  background-image: none !important;
  width: auto !important;
  height: auto !important;
  position: relative;
  transition: color 0.4s;
}

ul.mainNav1 li a::after,
ul.mainNav2 li a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 1px;
  background: var(--tan);
  transition: width 0.45s ease;
}

ul.mainNav1 li a:hover {
  color: var(--hover) !important;
  background: transparent !important;
  background-image: none !important;
}

ul.mainNav1 li a:hover::after,
ul.mainNav1 li a.current::after {
  width: 60%;
}

ul.mainNav1 li a.current {
  color: var(--tan) !important;
  font-weight: 300 !important;
}

#navigation ul.mainNav2 {
  display: none !important;
}

/* ============================================================
   NAVIGATION — スマホ（768px以下）
   ============================================================ */
@media (max-width: 768px) {

  #navigation {
    position: relative;
  }

  #navigation ul.mainNav1 {
    display: none !important;
    flex-direction: column !important;
    background: var(--bg2);
    border-top: 1px solid var(--rule);
  }

  #navigation ul.mainNav1.is-open {
    display: flex !important;
  }

  #navigation ul.mainNav1 li {
    width: 100%;
    border-bottom: 1px solid rgba(172,166,141,0.08);
  }

  #navigation ul.mainNav1 li:last-child {
    border-bottom: none;
  }

  ul.mainNav1 li a {
    padding: 16px 24px !important;
    letter-spacing: 0.28em !important;
    font-size: 11px !important;
    transition: color 0.3s, padding-left 0.3s !important;
  }

  ul.mainNav1 li a:hover,
  ul.mainNav1 li a.current {
    padding-left: 32px !important;
  }

  ul.mainNav1 li a::after {
    display: none;
  }

  .alzis-hamburger-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
  }

  .alzis-cur-page {
    font-family: var(--serif);
    font-size: 11px;
    font-weight: 300;
    letter-spacing: 0.28em;
    color: var(--tan);
    padding: 16px 0;
  }

  .alzis-hamburger {
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 16px 0;
    background: none;
    border: none;
  }

  .alzis-hamburger span {
    display: block;
    height: 1px;
    background: var(--cream);
    transition: all 0.4s ease;
  }

  .alzis-hamburger span:nth-child(1) { width: 22px; }
  .alzis-hamburger span:nth-child(2) { width: 16px; }
  .alzis-hamburger span:nth-child(3) { width: 22px; }

  .alzis-hamburger.is-open span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
    width: 22px;
  }
  .alzis-hamburger.is-open span:nth-child(2) {
    opacity: 0;
    width: 0;
  }
  .alzis-hamburger.is-open span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
    width: 22px;
  }
}

/* ============================================================
   WRAP
   ============================================================ */
#wrap {
  width: 100% !important;
  max-width: var(--max-w);
  display: flex !important;
  flex-direction: column !important;
  clear: both !important;
  margin: 0 auto !important;
  padding: 0 24px;
}

#content {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 36px 0 72px !important;
  order: 1;
  border-bottom: 1px solid var(--rule);
}

#sidebar {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 36px 0 72px !important;
  order: 2;
}

#sidebar::before {
  display: block;
  font-family: var(--disp);
  font-size: 8px;
  font-weight: 300;
  letter-spacing: 0.5em;
  color: var(--sage);
  margin-bottom: 12px;
  text-align: center;
}

#sidebar::after {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: rgba(172,166,141,0.3);
  margin: 0 auto 40px;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
#content h1 {
  font-family: var(--serif) !important;
  font-size: clamp(18px, 3vw, 22px) !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  color: var(--cream) !important;
  line-height: 1.65 !important;
  margin-bottom: 14px !important;
}

#content h2 {
  font-family: var(--serif) !important;
  font-size: clamp(16px, 2vw, 18px) !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  color: var(--cream) !important;
  line-height: 1.7 !important;
  margin: 56px 0 20px !important;
  padding-top: 56px;
  border-top: 1px solid var(--rule);
}

#content h2:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0 !important;
}

#content h3 {
  font-family: var(--disp) !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  color: var(--tan) !important;
  margin: 40px 0 14px !important;
}

#content p {
  font-family: var(--serif) !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.9 !important;
  color: var(--tan) !important;
  letter-spacing: 0.08em !important;
  margin-bottom: 15px !important;
}

#content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 40px auto;
}

/* ============================================================
   FOOTER
   ============================================================ */
#footer {
  width: 100% !important;
  clear: both !important;
  background: #0e0d0c !important;
  background-image: none !important;
  height: auto !important;
  border-top: 1px solid var(--rule);
  margin-top: 0 !important;
}

#footer .gutter {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 48px 24px !important;
  height: auto !important;
  text-align: center;
}

#footer p,
#footer a,
#footer .gutter {
  font-family: var(--serif) !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  color: var(--tan) !important;
  line-height: 2.2 !important;
}

#footer a {
  color: var(--tan) !important;
}

/* ============================================================
   PAGE LOAD アニメーション — PC
   ============================================================ */
@keyframes alzis-fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

#header {
  animation: alzis-fadeUp 1.5s ease-out both;
  animation-delay: 0.2s;
}

#navigation {
  animation: alzis-fadeUp 1.5s ease-out both;
  animation-delay: 0.4s;
}

#wrap {
  animation: alzis-fadeUp 1.5s ease-out both;
  animation-delay: 0.7s;
}

/* ============================================================
   SCROLL REVEAL — PC
   ============================================================ */
.alzis-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s ease-out, transform 0.9s ease-out;
}

.alzis-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   UTILITY
   ============================================================ */
#sidenavi { display: none !important; }

/* ============================================================
   RESPONSIVE — スマホ
   ============================================================ */
@media screen and (max-width: 768px) {

  #mobile-navi, #navi-mobile, .mobile-navi, .navi-mobile,
  #mobile-header, .mobile-header, #jimdo-mobile-header,
  .jimdo-promo, .jimdo-mobile-promo { display: none !important; }

  #container {
    width: 100% !important;
    max-width: 100% !important;
  }

  #header {
    max-width: 100% !important;
    padding-top: 45px !important;
    padding-bottom: 35px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  #header img {
    max-width: 200px !important;
    width: 55% !important;
  }

  #navigation {
    max-width: 100% !important;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
  }

  #navigation ul.mainNav1 {
    display: none !important;
    flex-direction: column !important;
    background: var(--bg2);
    border-top: 1px solid var(--rule);
  }

  #navigation ul.mainNav1.is-open {
    display: flex !important;
  }

  #navigation ul.mainNav1 li {
    width: 100%;
    border-bottom: 1px solid rgba(172,166,141,0.08);
  }

  #navigation ul.mainNav1 li:last-child {
    border-bottom: none;
  }

  ul.mainNav1 li a {
    padding: 16px 24px !important;
    font-size: 12px !important;
    transition: color 0.3s, padding-left 0.35s !important;
  }

  ul.mainNav1 li a:hover,
  ul.mainNav1 li a.current {
    color: var(--tan) !important;
    padding-left: 32px !important;
  }

  ul.mainNav1 li a::after {
    display: none !important;
  }

  .alzis-hamburger-bar {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
  }

  .alzis-cur-page {
    font-family: var(--serif);
    font-size: 11px;
    font-weight: 300;
    letter-spacing: 0.28em;
    color: var(--tan);
    padding: 16px 0;
  }

  .alzis-hamburger {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 16px 0;
    background: none;
    border: none;
  }

  .alzis-hamburger span {
    display: block;
    height: 1px;
    background: var(--cream);
    transition: all 0.4s ease;
  }

  .alzis-hamburger span:nth-child(1) { width: 22px; }
  .alzis-hamburger span:nth-child(2) { width: 16px; }
  .alzis-hamburger span:nth-child(3) { width: 22px; }

  .alzis-hamburger.is-open span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
    width: 22px;
  }
  .alzis-hamburger.is-open span:nth-child(2) {
    opacity: 0; width: 0;
  }
  .alzis-hamburger.is-open span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
    width: 22px;
  }

  #wrap {
    max-width: 100% !important;
    padding: 0 8px;
  }

  #content { padding: 28px 0 52px !important; }
  #sidebar  { padding: 28px 0 52px !important; }

  #content h1 {
    font-size: clamp(22px, 6vw, 30px) !important;
    letter-spacing: 0.12em !important;
    line-height: 1.7 !important;
    margin-bottom: 16px !important;
  }

  #content h2 {
    font-size: clamp(16px, 4.5vw, 20px) !important;
    margin: 44px 0 16px !important;
    padding-top: 44px !important;
  }

  #content h3 {
    font-size: 10px !important;
    margin: 28px 0 10px !important;
  }

  #content p {
    font-size: 12px !important;
    line-height: 1.85 !important;
    letter-spacing: 0.04em !important;
  }

  #content img { margin: 28px auto; }

  #footer .gutter { padding: 36px 20px !important; }

  #footer p,
  #footer a,
  #footer .gutter {
    font-size: 10px !important;
    letter-spacing: 0.1em !important;
  }

  /* スマホのみ — アニメーション移動量を小さく */
  @keyframes alzis-fadeUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .alzis-reveal {
    transform: translateY(20px);
    transition: opacity 2.8s ease-out, transform 2.8s ease-out;
  }
}

/* ============================================================
   スマホ強制上書き — Jimdo干渉対策
   ============================================================ */
@media screen and (max-width: 768px) {

  #navigation > ul,
  #navigation ul.mainNav1,
  #navigation > div > ul {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
  }

  #navigation ul.mainNav1.is-open {
    display: flex !important;
    visibility: visible !important;
    height: auto !important;
    overflow: visible !important;
    opacity: 1 !important;
    flex-direction: column !important;
  }

  .alzis-hamburger-bar {
    display: flex !important;
    visibility: visible !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 20px !important;
  }

  .alzis-hamburger {
    display: flex !important;
    visibility: visible !important;
    flex-direction: column !important;
    gap: 5px !important;
    cursor: pointer !important;
    padding: 16px 0 !important;
    background: none !important;
    border: none !important;
  }
}

/* ============================================================
   カラムブロック縦並び化
   ============================================================ */
@media screen and (max-width: 768px) {

  .j-column, .j-columns, .cc-m-col, .cc-m-columns,
  .j-module-columns, .jimdo-col, [class*="column"] {
    display: block !important;
    width: 100% !important;
    float: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .j-column img, .cc-m-col img, [class*="column"] img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto 16px !important;
  }

  .j-column + .j-column,
  .cc-m-col + .cc-m-col,
  [class*="column"] + [class*="column"] {
    margin-top: 32px !important;
  }
}

/* ============================================================
   Googleマップ フィルター
   ============================================================ */
.j-map iframe,
.cc-m-map iframe,
[class*="map"] iframe,
#content iframe[src*="google.com/maps"],
#content iframe[src*="maps.google"],
#sidebar iframe[src*="google.com/maps"],
#sidebar iframe[src*="maps.google"] {
  filter: grayscale(100%) brightness(0.7) contrast(1.3) sepia(20%) !important;
  border-radius: 2px;
}