:root{
  --nav-toast-right-gap: 65px;
  --nav-toast-bottom-gap: 12px;
}

.toast-container {
  width: auto;
}

/* 固定位置の基本設定 */
.nav-toast-container{
  position: fixed;
  z-index: 1090;
  pointer-events: none;
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
}

/* トーストの入退場 */
.toast.nav-toast{
  display: block !important; /* Bootstrap の display: none を上書き */
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important; /* デフォルトは none */
  margin: 0 !important;
  opacity: 0 !important;
  transform: translateY(24px) !important;
  transition: transform .36s cubic-bezier(.22,1,.36,1), opacity .36s ease-out !important;
}
.toast.nav-toast.is-pending{
  opacity: 0 !important;
  transform: translateY(24px) !important;
  pointer-events: none !important;
}
.toast.nav-toast.show{
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}
.toast.nav-toast.hide{
  opacity: 0 !important;
  transform: translateY(24px) !important;
  pointer-events: none !important;
}
@media (prefers-reduced-motion:reduce){
  .toast.nav-toast{
    transition: none !important;
  }
}

/* カード本体 */
.card-toast{
  --toast-width: 25rem;
  --toast-pad: 30px 15px 15px 15px;
  --thumb: 128px;
  --radius: 18px;
  --gap-x: 16px;
  --gap-y: 10px;
  --title-lines: 2;

  position: relative;
  box-sizing: border-box;
  width: min(var(--toast-width), calc(100vw - var(--nav-toast-right-total) - 12px));
  max-width: calc(100vw - var(--nav-toast-right-total) - 12px);
  padding: var(--toast-pad);
  border-radius: var(--radius);

  display: grid;
  grid-template-areas: "image date" "image title";
  grid-template-columns: auto 1fr;
  grid-template-rows: auto 1fr;
  column-gap: var(--gap-x);
  row-gap: var(--gap-y);

  background:#fff;
  color:#414241;
  border:2px solid #C4A57B;
  box-shadow:0 0 0 2px rgba(196,165,123,.2), 0 0 10px 4px rgba(0,0,0,.05);
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);

  cursor: pointer;
  transition: box-shadow .18s ease, border-color .18s ease, transform .18s ease;
}
@supports (width: 1dvw){
  .card-toast{
    width: min(var(--toast-width), calc(100dvw - var(--nav-toast-right-total) - 12px));
    max-width: calc(100dvw - var(--nav-toast-right-total) - 12px);
  }
}
.card-toast:hover{ transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.12); }
.card-toast:active{ transform: translateY(-1px); }
.card-toast:focus-visible{ outline: 0px; outline-offset: 0px; }

/* 画像・メタ領域 */
.card-toast__image-wrapper{ grid-area: image; }
.card-toast__image{ width: var(--thumb); height: var(--thumb); object-fit: contain; border-radius: 12px; display:block; }
.card-toast__date{ grid-area: date; align-self: start; }
.card-toast__title{ grid-area: title; margin: 0; }

/* 閉じるボタン */
.nav-toast__close{
  position: absolute; top: 6px; right: 6px;
  width: clamp(28px, 2.5vw, 36px); height: clamp(28px, 2.5vw, 36px);
  display:inline-flex; align-items:center; justify-content:center;
  border:0; background:transparent; border-radius:9999px; color:currentColor; cursor:pointer; z-index:3;
}
.nav-toast__close:hover{ background: rgba(0,0,0,.06); }

/* 見出し＋補助ラベル（縦積み） */
.card-toast__meta{ grid-area: date; align-self: start; padding-right: 40px; padding-top:10px; }
.card-toast__meta .front_page__float__text__01{
  display:flex; flex-direction:column-reverse; align-items:flex-start; gap:6px;
  font-size:20px; font-weight:700; line-height:27px; letter-spacing:.1em; margin:0; color:#414241;
}
.card-toast__meta .front_page__float__text__01__icon{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:5px 8px; background:#fff; border-radius:24px; border:1px solid currentColor;
  outline:0px;outline-offset: 0px; 
}
.card-toast__meta .front_page__float__text__01__icon__inner{
  color:inherit; font-size:12px; font-weight:500; line-height:1; letter-spacing:.15em; white-space:nowrap;
}

/* バッジ（カード上にはみ出し） */
.card-toast__badge{ 
  position:absolute; 
  left:14px; 
  top:-15px; 
  z-index:20; 
  pointer-events:auto;
  animation: pulse 4s ease-in-out infinite;
  transform-origin: center center;
  transition: transform 0.3s ease-out;
}

/* パルスアニメーション（2回拡大して戻る、その後3秒休憩） */
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  7.5% {
    transform: scale(1.15);
  }
  15% {
    transform: scale(1);
  }
  22.5% {
    transform: scale(1.1);
  }
  30%, 100% {
    transform: scale(1);
  }
}

/* トースト表示時のみアニメーション */
.toast.nav-toast:not(.show) .card-toast__badge {
  animation: none;
}

/* ホバー時は元のサイズに戻して止める */
.card-toast:hover .card-toast__badge {
  animation: none;
  transform: scale(1);
}

.front_page__float__text__02__badge__inner{
  display:flex; align-items:center; gap:8px; padding:8px 12px;
  background:#e94f2a; color:#fff; border-radius:9999px; box-shadow:0 2px 6px rgba(0,0,0,.08);
  font-family:"Plus Jakarta Sans","Noto Sans JP",system-ui,-apple-system,sans-serif;
  font-size:13px;     line-height: 1.5; font-weight:600; white-space:nowrap; letter-spacing:.15em;
}

/* 価格行 */
.front_page__float__text__03{ position:relative; display:flex; align-items:baseline; gap:10px; }
.front_page__float__text__03 .meta-stack{ display:inline-flex; flex-direction:column; align-items:flex-start; gap:2px; line-height:1; align-self:baseline; }
.front_page__float__text__03 .offprice{
  display:inline-flex; align-items:baseline; gap:3px; color:#888; white-space:nowrap; line-height:1;
  font-family:"Plus Jakarta Sans","Noto Sans JP",system-ui,-apple-system,sans-serif;
}
.front_page__float__text__03 .offprice .yen{ font-size:13px; font-weight:600; }
.front_page__float__text__03 .offprice .num{ font-size:15px; font-weight:600; text-decoration:line-through; text-decoration-thickness:.06em; text-underline-offset:.12em; }
.front_page__float__text__03 .trial{ color:#414241; font-size:14px; font-weight:700; letter-spacing:.56px; line-height:1.3; }

.front_page__float__text__03 .price-block{ display:inline-flex; flex-direction:row; align-items:baseline; gap:6px; align-self:flex-end; }
.front_page__float__text__03 .price{ display:inline-flex; align-items:baseline; line-height:1; font-family:"Plus Jakarta Sans","Noto Sans JP",system-ui,-apple-system,sans-serif; }
.front_page__float__text__03 .price .yen{ color:#e94f2a; font-size:18px; font-weight:600; margin-right:0; }
.front_page__float__text__03 .price .num{ color:#e94f2a; font-size:28px; font-weight:600; line-height:1; }
.front_page__float__text__03 .tax{ margin-top:0; font-size:12px; line-height:1; color:#414241; }


/* ============================
   デスクトップ・タブレット（PC表示）
   iPad Mini (768px), iPad Air (820px), iPad Pro等も含む
   ============================ */
@media (min-width: 600px){
  .toast-container.nav-toast-container{
    --nav-toast-right-total: calc(env(safe-area-inset-right, 52px) + var(--nav-toast-right-gap));
    --nav-toast-bottom-total: calc(env(safe-area-inset-bottom, 0px) + var(--nav-toast-bottom-gap));
    right: var(--nav-toast-right-total) !important;
    bottom: var(--nav-toast-bottom-total) !important;
    left: auto !important;
    width: auto !important;
    max-width: 28rem !important;
    padding: 0 !important;
  }
  
  /* タブレットでもPC同様のカードサイズ */
  .card-toast{
    --toast-width: 25rem;
  }
}

/* ============================
   Mobile Portrait — スマホ縦向き専用
   Galaxy Z Fold (344px)、iPhone、Android全機種対応
   タブレット (600px以上) は除外
   ============================ */
@media (max-width: 599px) and (orientation: portrait){
  :root{
    --mobile-inset: 12px;
    --mobile-bottom-gap: 16px;
  }

  /* コンテナを左右均等な余白で配置 */
  .toast-container.nav-toast-container,
  .toast-container.nav-toast-container.end-0,
  .nav-toast-container.position-fixed{
    position: fixed !important;
    left: var(--mobile-inset) !important;
    right: var(--mobile-inset) !important;
    bottom: calc(env(safe-area-inset-bottom, 0px) + var(--mobile-bottom-gap)) !important;

    /* 幅は自動計算 */
    width: auto !important;
    max-width: none !important;
    box-sizing: border-box !important;

    /* padding は使わない（left/right で余白を作る） */
    padding: 0 !important;
    margin: 0 !important;
  }

  /* Bootstrap上書き */
  .toast.nav-toast{
    display: block !important; /* Bootstrap の display: none を上書き */
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    /* アニメーションを維持 */
    transition: transform .36s cubic-bezier(.22,1,.36,1), opacity .36s ease-out !important;
  }
  .toast.nav-toast.is-pending{
    opacity: 0 !important;
    transform: translateY(24px) !important;
    pointer-events: none !important;
  }
  .toast.nav-toast.show{
    opacity: 1 !important;
    transform: translateY(0) !important;
    pointer-events: auto !important;
  }
  .toast.nav-toast.hide{
    opacity: 0 !important;
    transform: translateY(24px) !important;
    pointer-events: none !important;
  }

  /* カード全幅 */
  .card-toast{
    width: 100% !important;
    max-width: 100% !important;
    column-gap: 14px;
    padding: 24px 14px 14px;
    border-radius: 16px;
  }
  
  .card-toast__image{ 
    width: 96px; 
    height: 96px; 
  }
  
  .nav-toast__close{
    width: 32px;
    height: 32px;
    top: 8px;
    right: 8px;
  }
  
  .card-toast__meta{
    padding-right: 44px;
    padding-top: 6px;
  }
}

/* Galaxy Z Fold 専用（折りたたみ時: 344px × 882px） */
@media (max-width: 400px) and (orientation: portrait){
  :root{
    --mobile-inset: 8px;
    --mobile-bottom-gap: 14px;
  }

  .toast-container.nav-toast-container,
  .toast-container.nav-toast-container.end-0,
  .nav-toast-container.position-fixed{
    left: var(--mobile-inset) !important;
    right: var(--mobile-inset) !important;
  }

  .card-toast{
    padding: 20px 12px 12px;
    column-gap: 12px;
  }
  
  .card-toast__image{
    width: 88px;
    height: 88px;
  }
}

/* 狭い端末（～375px：iPhone SE等） */
@media (max-width: 375px) and (orientation: portrait){
  :root{
    --mobile-inset: 10px;
  }
  
  .card-toast{
    padding: 20px 12px 12px;
    column-gap: 12px;
  }
  
  .card-toast__image{
    width: 88px;
    height: 88px;
  }
}

/* ============================
   Mobile Landscape — スマホ横向き
   タブレット横向きは除外
   ============================ */
@media (max-width: 599px) and (orientation: landscape){
  :root{
    --landscape-inset: 16px;
    --landscape-bottom-gap: 12px;
  }
  
  .toast-container.nav-toast-container{
    right: max(env(safe-area-inset-right, 0px), var(--landscape-inset)) !important;
    bottom: calc(env(safe-area-inset-bottom, 0px) + var(--landscape-bottom-gap)) !important;
    left: auto !important;
    
    width: auto !important;
    max-width: calc(100vw - max(env(safe-area-inset-right, 0px), var(--landscape-inset)) - max(env(safe-area-inset-left, 0px), var(--landscape-inset))) !important;
    
    padding: 0 !important;
  }
  
  .card-toast{
    --toast-width: 22rem;
    width: var(--toast-width) !important;
    max-width: calc(100vw - max(env(safe-area-inset-right, 0px), var(--landscape-inset)) * 2 - 24px) !important;
  }
}

/* ============================
   古いブラウザ対応（iOS Safari 15.3以前など）
   ============================ */
@supports not (width: 1dvw){
  .card-toast{
    width: min(var(--toast-width), calc(100vw - var(--nav-toast-right-total) - 24px));
    max-width: calc(100vw - var(--nav-toast-right-total) - 24px);
  }
}

/* ============================
   アクセシビリティ対応
   ============================ */
@media (prefers-reduced-motion: reduce){
  .toast.nav-toast{
    transition: none !important;
  }
  .card-toast{
    transition: none !important;
  }
  .card-toast__badge{
    animation: none !important;
  }
}

@media (prefers-contrast: high){
  .card-toast{
    border-width: 3px;
  }
}

/*
 ダークモード対応 
@media (prefers-color-scheme: dark){
  .card-toast{
    background: #1a1a1a;
    color: #e0e0e0;
    border-color: #C4A57B;
    box-shadow: 0 0 0 2px rgba(196,165,123,.3), 0 0 16px 6px rgba(0,0,0,.3);
  }
  
  .nav-toast__close:hover{
    background: rgba(255,255,255,.1);
  }
}*/