/* ManilaLab Home Safe UI v30
   ブレークポイント設計:
   ≥1500px : カード3枚表示（大画面のみ）
   768〜1499px : カード2枚表示（MacBook・タブレット横）
   ≤767px : カード1枚表示（スマホ・タブレット縦）
*/
.mlhs-section{font-family:'Noto Sans JP',sans-serif;color:#fff;width:100%;}
.mlhs-section *{box-sizing:border-box;}

/* ── カルーセル ── */
.mlhs-carousel{padding:0;margin:0;background:transparent;overflow-x:hidden;overflow-y:visible;width:100%;position:relative;}
.mlhs-carousel__stage{position:relative;width:100%;overflow-x:clip;overflow-y:visible;}
.mlhs-carousel__track{display:flex;gap:0;overflow-x:auto;overflow-y:visible;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:0 0 6px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;user-select:none;width:100%;}
.mlhs-carousel__track::-webkit-scrollbar{display:none;}
.mlhs-carousel__track.is-dragging{cursor:grabbing;scroll-behavior:auto;}

/* ── カード（新デザイン: 横長・クリーム背景・写真右飛び出し） ── */
.mlhs-card{
  flex:0 0 50%;max-width:50%;min-width:50%;
  scroll-snap-align:start;
  position:relative;
  text-decoration:none !important;
  display:flex;
  flex-direction:column;
  /* 写真が上に飛び出す分のパディング */
  padding-top:44px;
  transition:transform .18s ease, box-shadow .18s ease;
}
.mlhs-card:hover,.mlhs-card:focus{transform:translateY(-2px);text-decoration:none !important;}

/* カード本体（角なし・高さ均一化） */
.mlhs-card__surface{
  flex:1;
  display:flex;
  flex-direction:column;
  background:#fff8f0;
  border-radius:0;
  overflow:visible;
  box-shadow:0 4px 16px rgba(104,31,0,.14);
  position:relative;
  transition:box-shadow .18s ease;
}
.mlhs-card:hover .mlhs-card__surface{box-shadow:0 10px 28px rgba(104,31,0,.20);}

/* メインエリア（横2分割: 左テキスト・右写真） */
.mlhs-card__main{
  flex:1;
  display:flex;
  align-items:stretch;
  min-height:180px;
  padding:16px 16px 0 20px;
  position:relative;
}

/* 左エリア（テキスト） */
.mlhs-card__copy{
  flex:1 1 0;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding-right:10px;
  padding-bottom:12px;
  min-width:0;
}
.mlhs-card__copy-inner{display:flex;flex-direction:column;gap:0;}

/* バッジ＋日時 */
.mlhs-card__toprow{
  display:flex;flex-direction:column;align-items:flex-start;gap:4px;
  margin-bottom:10px;
}
.mlhs-ribbon{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 12px;
  border-radius:4px;
  font-size:12px;font-weight:900;line-height:1;
  color:#fff;white-space:nowrap;flex-shrink:0;
}
.mlhs-ribbon--upcoming{background:#e86000;}
.mlhs-ribbon--archive{background:#1a6faf;}
.mlhs-ribbon--live{background:#d42020;}
.mlhs-ribbon--closed{background:#888;}
.mlhs-ribbon span{position:relative;z-index:1;color:#fff;}

.mlhs-date{
  display:flex;flex-direction:column;gap:1px;
  margin:0;
}
.mlhs-date__ymd{
  font-size:13px;font-weight:800;line-height:1.3;
  color:#333;white-space:nowrap;
}
.mlhs-date__time{
  font-size:13px;font-weight:800;line-height:1.3;
  color:#e86000;white-space:nowrap;
}

/* タイトル（全文表示・JS自動縮小） */
.mlhs-title{
  font-size:26px;line-height:1.3;font-weight:900;
  color:#e86000;margin:0 0 10px;
  letter-spacing:-0.02em;
  overflow:hidden;
  word-break:break-all;
}

/* グラデーションアンダーライン */
.mlhs-card__underline{
  height:4px;
  background:linear-gradient(to right,#e86000 0%,rgba(232,96,0,0) 85%);
  width:100%;margin-bottom:8px;flex-shrink:0;
}

/* ハッシュタグ（ピル型バッジ・オレンジ） */
.mlhs-hashtags{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px;}
.mlhs-hashtag{
  display:inline-block;
  font-size:11px;font-weight:700;
  color:#e86000;
  background:#fff3eb;
  border:1px solid #f0c49a;
  border-radius:999px;
  padding:2px 9px;
  line-height:1.5;
  white-space:nowrap;
}

/* 右エリア（写真＋講師情報） */
.mlhs-card__aside{
  flex:0 0 175px;
  position:relative;
  display:flex;flex-direction:column;
  align-items:flex-end;justify-content:flex-end;
  padding-bottom:14px;
}

/* 講師写真（上辺から飛び出す丸写真） */
.mlhs-speaker__photo{
  position:absolute;
  top:-44px;   /* padding-topと同じ量だけ上にはみ出す */
  right:10px;
  width:155px;height:155px;
  border-radius:50%;overflow:hidden;
  border:4px solid #fff;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
  background:#ddd;
  flex-shrink:0;
}
.mlhs-speaker__photo img{width:100%;height:100%;object-fit:cover;display:block;}
.mlhs-speaker__photo--fallback{
  display:flex;align-items:center;justify-content:center;
  font-size:40px;font-weight:900;color:#aaa;
  background:#eee;
}

/* 講師肩書・氏名（写真右下に重なる） */
.mlhs-speaker__meta{
  position:relative;z-index:5;
  text-align:right;
  background:rgba(255,255,255,.88);
  padding:3px 8px 4px;
  max-width:165px;
}
.mlhs-speaker__role{font-size:10px;color:#555;line-height:1.4;margin:0;display:block;font-weight:400;white-space:normal;overflow:visible;word-break:break-all;}
.mlhs-speaker__name{font-size:16px;font-weight:900;color:#111;line-height:1.2;margin:0;display:block;white-space:nowrap;}

/* 複数講師レイアウト */
.mlhs-card__main--multi .mlhs-card__copy{padding-right:0;}
.mlhs-speakers{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:4px;align-items:flex-start;}
.mlhs-speaker-item{display:flex;align-items:center;gap:6px;min-width:0;}
.mlhs-speaker-item .mlhs-speaker__photo{
  position:static;top:auto;right:auto;
  width:48px;height:48px;border:2px solid rgba(255,255,255,.9);
}
.mlhs-speaker-item .mlhs-speaker__photo--fallback{font-size:18px;}
.mlhs-speaker-item__meta{min-width:0;text-align:left;}
.mlhs-speaker-item .mlhs-speaker__name{font-size:14px;}
.mlhs-speaker-item .mlhs-speaker__role{font-size:10px;}
.mlhs-speaker-item .mlhs-speaker__meta{background:none;padding:0;text-align:left;}

/* フッター */
.mlhs-card__footer{
  background:#ffffff;border-top:1px solid #ecddd2;
  text-align:center;padding:10px 0 11px;
  font-size:15px;font-weight:900;letter-spacing:.02em;
  color:#e86000 !important;
  display:flex;align-items:center;justify-content:center;min-height:40px;
}


.mlhs-card__main--multi{grid-template-columns:1fr;}
.mlhs-card__copy--full{min-height:0;}
.mlhs-speakers{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:4px;align-items:flex-start;}
.mlhs-speaker-item{display:flex;align-items:center;gap:6px;min-width:0;}
.mlhs-speaker-item .mlhs-speaker__photo{width:48px;height:48px;flex-shrink:0;border:2px solid rgba(255,255,255,.9);}
.mlhs-speaker-item .mlhs-speaker__photo--fallback{font-size:18px;}
.mlhs-speaker-item__meta{min-width:0;text-align:left;}
.mlhs-speaker-item .mlhs-speaker__name{font-size:14px;font-weight:900;line-height:1.15;text-shadow:0 2px 8px rgba(0,0,0,.14);}
.mlhs-speaker-item .mlhs-speaker__role{font-size:10px;font-weight:700;line-height:1.3;white-space:normal;overflow:visible;word-break:break-all;}

/* ── コントロール ── */
.mlhs-carousel__controls{display:flex;justify-content:center;align-items:center;gap:14px;padding:12px 0 0;}
.mlhs-carousel__dots{display:flex;justify-content:center;gap:14px;padding:0;align-items:center;line-height:0;}
.mlhs-carousel__dot{width:12px;height:12px;flex:0 0 12px;display:block;border-radius:50%;border:0;appearance:none;-webkit-appearance:none;background:#d0d0d0;opacity:1;cursor:pointer;transition:background .18s ease, transform .18s ease;box-shadow:none;padding:0;}
.mlhs-carousel__dot.is-active{background:#e86000;transform:scale(1.05);}
.mlhs-carousel__arrow{position:static;transform:none;width:28px;height:28px;border-radius:999px;border:0;background:rgba(232,96,0,.14);color:#e86000;font-size:15px;font-weight:900;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:none;cursor:pointer;z-index:1;transition:background .18s ease, transform .18s ease;}
.mlhs-carousel__arrow:hover,.mlhs-carousel__arrow:focus{background:rgba(232,96,0,.22);transform:scale(1.06);}
.mlhs-carousel__arrow--prev{margin-right:2px;}
.mlhs-carousel__arrow--next{margin-left:2px;}

/* ── 一覧 ── */
.mlhs-list{padding:18px 0 0;background:transparent;width:100%;}
.mlhs-list__inner{padding:0;width:100%;}
.mlhs-list__head{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin:0 0 18px;text-align:center;}
.mlhs-list__title{font-size:28px;font-weight:900;line-height:1.2;color:#111;margin:0 0 10px;text-align:center;}
.mlhs-list__sub{font-size:13px;color:#6b5a50;font-weight:700;margin:0;text-align:center;}
.mlhs-list__rows{display:flex;flex-direction:column;gap:0;width:100%;border-top:1px solid #f0ddd0;}
.mlhs-list__item{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;padding:10px 0;width:100%;background:#fff;text-decoration:none !important;color:#111 !important;border-bottom:1px solid #f0ddd0;transition:background .18s ease;}
.mlhs-list__item:hover,.mlhs-list__item:focus{background:#fff8f2;text-decoration:none !important;color:#111 !important;}
.mlhs-list__status-date{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:6px 8px;padding-left:4px;padding-top:2px;}
.mlhs-list__date{font-size:13px;font-weight:800;color:#111;line-height:1.4;letter-spacing:.01em;white-space:nowrap;}
.mlhs-list__status{display:flex;align-items:center;}
.mlhs-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 14px;border-radius:999px;font-size:11px;font-weight:900;color:#fff;white-space:nowrap;box-shadow:0 4px 10px rgba(0,0,0,.10);}
.mlhs-pill--upcoming{background:#e86000;}
.mlhs-pill--archive{background:linear-gradient(135deg,#5890ff 0%,#2260dc 52%,#1238a0 100%);}
.mlhs-list__session{min-width:0;}
.mlhs-list__session-title{font-size:18px;font-weight:900;line-height:1.3;color:#111;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.mlhs-list__content{display:none;}
.mlhs-list__speaker{min-width:0;}
.mlhs-list__speaker-name{font-size:16px;font-weight:900;line-height:1.3;color:#111;margin:0 0 2px;}
.mlhs-list__speaker-role{font-size:13px;line-height:1.4;color:#444;font-weight:700;margin:0;white-space:normal;overflow:visible;word-break:break-all;}

/* ── 複数講師 (リスト) ── */
.mlhs-list__speaker-item{margin-bottom:4px;}
.mlhs-list__speaker-item--sub{padding-top:4px;border-top:1px solid #f0ddd0;margin-top:4px;}

/* ── メンバーCTA ── */
.mlhs-member{font-family:'Noto Sans JP',sans-serif;max-width:1100px;margin:40px auto 0;padding:0 16px;}
.mlhs-member__box{background:linear-gradient(135deg,#fff8f2 0%,#ffffff 60%,#fff1e5 100%);border:1px solid #f0d7c1;box-shadow:0 18px 36px rgba(118,63,10,.10);border-radius:22px;padding:28px 30px;display:grid;grid-template-columns:1.4fr .9fr;gap:24px;align-items:center;}
.mlhs-member__title{font-size:28px;font-weight:900;line-height:1.25;color:#111;margin:0 0 10px;}
.mlhs-member__text{font-size:14px;line-height:1.85;color:#5c534d;margin:0;}
.mlhs-member__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;}
.mlhs-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-size:14px;font-weight:900;text-decoration:none !important;transition:transform .2s ease, box-shadow .2s ease;}
.mlhs-btn:hover,.mlhs-btn:focus{transform:translateY(-2px);text-decoration:none !important;}
.mlhs-btn--primary{background:#e86000;color:#fff !important;box-shadow:0 12px 24px rgba(232,96,0,.24);}
.mlhs-btn--ghost{background:#fff;color:#111 !important;border:1px solid #ecd3bd;}

/* ────────────────────────────────
   大画面（≥1500px）: 3枚表示
──────────────────────────────── */
@media (min-width: 1500px){
  .mlhs-card{flex:0 0 calc(100% / 3);max-width:calc(100% / 3);min-width:calc(100% / 3);}
  .mlhs-title{font-size:28px;}
  .mlhs-speaker__name{font-size:18px;}
  .mlhs-speaker__photo{width:165px;height:165px;}
  .mlhs-card__aside{flex:0 0 180px;}
  .mlhs-card__footer{font-size:16px;}
  .mlhs-list__item{grid-template-columns:auto 1fr auto;gap:8px;}
  .mlhs-list__session-title{font-size:20px;}
  .mlhs-list__speaker-name{font-size:16px;}
}

/* ────────────────────────────────
   タブレット縦〜小型ノート（768px〜1499px）: 2枚表示 ← 主力
   ※ MacBook Air 13" (1280px) はここ
──────────────────────────────── */
/* 2枚表示はデフォルト(50%)なのでcard幅変更なし */
/* aspect-ratio 16/9 で 1280px/2=640px × 360px → 十分な高さ */

/* ────────────────────────────────
   スマホ（≤767px）: 1枚表示
──────────────────────────────── */
@media (max-width: 767px){
    /* カルーセル（スマホ）: 横並び維持・写真は右・飛び出しなし */
  .mlhs-card{flex:0 0 100%;max-width:100%;min-width:100%;padding-top:0;}
  /* カード本体 */
  .mlhs-card__surface{display:flex;flex-direction:column;overflow:visible;}
  /* メインエリア：横並びそのまま */
  .mlhs-card__main{
    flex-direction:row;
    min-height:140px;
    padding:14px 0 0 14px;
    align-items:stretch;
    position:relative;
  }
  /* 左テキスト：縦中央配置（タイトル短い場合） */
  .mlhs-card__copy{flex:1;display:flex;flex-direction:column;padding-right:6px;padding-bottom:10px;justify-content:center;gap:8px;}
  /* 右：写真エリア */
  .mlhs-card__aside{
    flex:0 0 110px;
    width:110px;
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    justify-content:flex-end;
    padding-bottom:8px;
    padding-right:0;
  }
  /* 写真：カード右端・上端揃え・飛び出しなし */
  .mlhs-speaker__photo{
    position:absolute;
    top:0;
    right:0;
    width:110px;
    height:110px;
    border:3px solid #fff;
    margin:0;
  }
  /* 講師名：写真右下オーバーレイ */
  .mlhs-speaker__meta{
    position:relative;z-index:5;
    text-align:right;
    background:rgba(255,255,255,.90);
    padding:3px 7px 4px;
    max-width:110px;
  }
  .mlhs-speaker__role{font-size:9px;text-align:right;white-space:normal;overflow:visible;word-break:break-all;}
  .mlhs-speaker__name{font-size:13px;text-align:right;white-space:nowrap;}
  .mlhs-title{font-size:18px;}
  /* (２) バッジ直下に日時（縦並び）- 写真の後ろに隠れない */
  .mlhs-card__toprow{gap:4px;margin-bottom:6px;} /* flex-direction:column はデフォルトから継承 */
  .mlhs-date{flex-direction:row;gap:4px;flex-wrap:wrap;}
  .mlhs-date__ymd{font-size:11px;font-weight:800;}
  .mlhs-date__time{font-size:11px;font-weight:800;}
  .mlhs-ribbon{font-size:11px;padding:3px 8px;}
  .mlhs-card__footer{font-size:13px;min-height:34px;padding:6px 8px;}
  /* 複数講師スマホ */
  .mlhs-speaker-item .mlhs-speaker__photo{position:static;top:auto;right:auto;width:40px;height:40px;}
  .mlhs-speaker-item .mlhs-speaker__name{font-size:12px;}
  /* 一覧 */
  .mlhs-list__head{display:block;}
  .mlhs-list__title{font-size:18px;margin-bottom:4px;}
  .mlhs-list__sub{font-size:10px;}
  .mlhs-list__head{margin:0 0 12px;}
  /* スマホ一覧：3行レイアウト（区切り線なし）
     1行目: バッジ＋日時 （左揃え）
     2行目: タイトル    （左揃え）
     3行目: 講師名・肩書き（右寄せ） */
  .mlhs-list__item{
    display:flex;
    flex-direction:column;
    gap:3px;
    padding:10px 8px;
    border-bottom:none;
  }
  .mlhs-list__status-date{
    display:flex;flex-direction:row;align-items:center;
    gap:6px;flex-wrap:nowrap;
    /* border-bottom なし */
  }
  .mlhs-list__date{font-size:12px;font-weight:800;white-space:nowrap;color:#111;}
  .mlhs-list__session{padding:0;}
  .mlhs-list__session-title{font-size:14px;padding-left:0;color:#111;}
  /* 3行目：講師名・肩書きを右寄せ */
  .mlhs-list__speaker{
    display:flex;flex-direction:row;align-items:baseline;
    gap:4px;
    justify-content:flex-end;  /* 右寄せ */
    text-align:right;
    /* border-top なし */
  }
  .mlhs-list__speaker-name{font-size:12px;font-weight:900;white-space:nowrap;text-align:right;margin:0;color:#444;}
  .mlhs-list__speaker-role{font-size:11px;font-weight:600;white-space:normal;text-align:right;margin:0;color:#888;word-break:break-all;}
  /* メンバーCTA */
  .mlhs-member{padding:0 14px;}
  .mlhs-member__box{grid-template-columns:1fr;padding:22px 18px;}
  .mlhs-member__actions{justify-content:flex-start;}
  .mlhs-member__title{font-size:22px;}
}

/* ── PC カルーセルカード：ハッシュタグは先頭1件のみ表示（v35互換） ── */
@media (min-width: 768px) {
  .mlhs-card .mlhs-hashtags .mlhs-hashtag:nth-child(n+2) {
    display: none;
  }
}
