/* カーニング */
.kerning {
    word-break: auto-phrase;
    color: #4f4f4f;
}

/* breadcrumb背景色 */
.breadcrumb {
    background-color:transparent !important;
  }
/* breadcrumb-item色 */
.breadcrumb-item a {
    color: #4f4f4f;
}

/* ページ内リンクの位置調整 */
.anchor-link {
    scroll-margin-top: 30px;
}

/* ===============================================
   レスポンシブ・タイポグラフィ設定
   =============================================== */

/* --- 基準となるテキスト --- */
/* 本文、リスト、キャプションなど、サイトの基本となるテキスト */
/* 最小16px, 最大18px */
p,
ul li,
figcaption {
    font-size: clamp(1rem, 0.95rem + 0.25vw, 1.125rem); /* 16px, 16.8px, 18px */
    line-height: 1.7;
}


/* --- ボタンのテキスト --- */
/* ボタンの文字は、本文より少しだけ締まったサイズ感に */
/* 最小16px, 最大17px */
a.btn,
button.btn {
    font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem); /* 16px, 16.32px, 17px */
}


/* --- 見出しの階層 (Heading Hierarchy) --- */
/* h5からh1にかけて、段階的に力強くなるように設定 */

/* 見出しレベル5 */
/* 最小17px, 最大20px */
h5.fs {
    font-size: clamp(1.0625rem, 1rem + 0.3125vw, 1.25rem); /* 17px, 18px, 20px */
    line-height: 1.5;
}

/* 見出しレベル4 */
/* 最小18px, 最大22px */
h4.fs {
    font-size: clamp(1.125rem, 1.05rem + 0.375vw, 1.375rem); /* 18px, 19.2px, 22px */
    line-height: 1.4;
}

/* 見出しレベル3 */
/* 最小20px, 最大26px */
h3.fs {
    font-size: clamp(1.25rem, 1.1rem + 0.75vw, 1.625rem); /* 20px, 22.4px, 26px */
    line-height: 1.3;
}

/* 見出しレベル2 */
/* 最小24px, 最大32px */
h2.fs {
    font-size: clamp(1.5rem, 1.25rem + 1.25vw, 2rem); /* 24px, 28px, 32px */
    line-height: 1.2;
}

/* 見出しレベル1 */
/* 最小28px, 最大40px */
h1.fs {
    font-size: clamp(1.75rem, 1.4rem + 1.75vw, 2.5rem); /* 28px, 33.6px, 40px */
    line-height: 1.2;
}

/* footerの位置調整 */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* 画面の高さいっぱいに広がるようにする */
}
  
main {
    flex: 1; /* コンテンツ領域が残りのスペースを埋めるようにする */
}
  
footer {
    margin-top: auto; /* フッターが常に一番下に表示されるようにする */
}

/* step-icon */
.bg-teal {
    background-color: #009688;
}

/* ナビゲーションメニュー(MDBライブラリの上書き) */
.navbar.navbar-light .navbar-toggler-icon {
    background-image: var(--mdb-navbar-toggler-icon-bg);
}

/* 出店者一覧のリンク専用スタイル */
#shutten .vendor-link {
    /* !importantで他のスタイルに負けないように色を強制する */
    color: #4f4f4f !important; /* 君のdark-grey-textの色を直接指定 */
    text-decoration: none !important; /* デフォルトの下線を強制的に消す */
}

/* ホバーした時だけ下線を表示する */
#shutten .vendor-link:hover {
    text-decoration: underline !important;
}

/* ナビゲーションカードのスタイル */
.nav-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: none;
}

.nav-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 1rem 1.5rem rgba(0,0,0,.1) !important;
}

.nav-card .icon-circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #e0f2f1; /* Your site's green color, but lighter */
    color: #009688; /* Your site's main green color */
    transition: background-color 0.3s ease, color 0.3s ease;
}

.nav-card:hover .icon-circle {
    background-color: #009688;
    color: #ffffff;
}

.nav-card:hover .icon-circle {
    background-color: #009688;
    color: #ffffff;
}

  /* 出店者一覧のリンク用カスタムスタイル */
.vendor-link-item {
    display: block;
    color: inherit;
    text-decoration: none;
    padding: 0.5rem;
    margin: -0.5rem;
    border-radius: 0.375rem;
    transition: background-color 0.2s ease-in-out;
}

  /* マウスを乗せた時のスタイル */
.vendor-link-item:hover {
    background-color: rgba(0,0,0,0.05); /* 背景色を薄いグレーにする */
}

/* マウスを乗せた時だけ下線を表示する */
  #shutten .vendor-link:hover {
    text-decoration: underline !important;
}

/* ヒーローセクションの基本スタイル */
#hero {
  min-height: 80vh;
  background-size: cover;
  background-position: center;
}

/* 背景フィルター用のマスク */
#hero .mask {
  background-color: rgba(0, 0, 0, 0.5);
}

/* ロゴを乗せるプレートのスタイル */
#hero .logo-plate {
  /* 親要素(カラム)の幅に対して80%のサイズに設定 */
  width: 80%;

  /* アスペクト比を1:1に保つ（正方形にする） */
  aspect-ratio: 1 / 1;

  /* PC画面で大きくなりすぎないように最大サイズを指定 */
  max-width: 250px;

  background-color: #ffffff; /* 背景を不透明な白に変更 */
  border-radius: 50%; /* 正方形を円にする */
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.1);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

/* イベント終了のお知らせボックス */
.event-ended-notice {
  background-color: rgba(255, 255, 255, 0.9);
  color: #333;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px); /* Safariブラウザ対応 */
}

/* お知らせボックスのタイトル色 */
.event-ended-notice .event-ended-title {
  color: #009688; /* サイトのテーマカラー */
}
