/* ============================================================
   KMA_AUDIO_FOOTER_BUNDLE_V1 2026-02-16
   - moved from style.css
   ============================================================ */

.audio-player-shell{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  background:rgba(9,15,23,0.96);
  border-top:1px solid rgba(255,255,255,.08);
  box-shadow:0 -18px 40px rgba(0,0,0,.28);
  padding:10px 14px;
}

.audio-player-inner{
  max-width:1100px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:14px;
}

.audio-player-meta{
  flex:1;
  min-width:0;
}

.audio-player-title{
  color: rgba(255,255,255,0.96);
  font-weight:700;
  font-size:14px;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.audio-player-sub{
  color: rgba(255,255,255,0.72);
  font-size:12px;
  opacity:1;
  margin-top:2px;
}

.audio-player-shell audio{
  width: 260px;
  max-width: 42vw;
}

@media (max-width: 768px){
  .audio-player-shell audio{
    width: 100%;
    max-width: 100%;
  }
}
.audio-player-shell.is-collapsed audio{
  display:none;
}

@media (max-width: 768px){
  .audio-player-inner{ max-width:100%; }
  .audio-player-shell.is-collapsed .audio-player-sub{ display:block; }
}

/* 2026-02-01 FIX: 固定フッタープレイヤーにコンテンツが隠れないよう下余白を確保 */
body{
  padding-bottom: 96px;
}


/* AUDIO_FOOTER_NAV_UI_STABLE 2026-02-16
   - Navは常に同じ塊として固定（左右が上に逃げない）
   - disabledは「見た目は薄い・クリック不可」だけに統一
*/
#global-audio-player .audio-player-inner{
  flex-wrap: nowrap;
}

#global-audio-player .audio-player-nav{
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  pointer-events: auto;
}

#global-audio-player .audio-player-nav button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.96);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}

/* NAV_STATE (disabled 表示統一) */
#global-audio-player .audio-player-nav button.is-disabled,
#global-audio-player .audio-player-nav button[disabled],
#global-audio-player .audio-player-nav button[aria-disabled="true"]{
  display: inline-flex;
  opacity: .35;
  pointer-events: none;
}

/* mobile layout */
@media (max-width: 900px){
  #global-audio-player{
    padding: 10px 12px;
  }
  #global-audio-player .audio-player-inner{
    flex-wrap: wrap;
  }
  #global-audio-player .audio-player-meta{
    flex: 1 1 100%;
    min-width: 0;
    display: block;
    margin-bottom: 6px;
  }
  #global-audio-player .audio-player-nav{
    order: 2;
  }
  #global-audio-player #global-audio{
    order: 3;
  }
}




/* AUDIO_NATIVE_CONTROLS_STABLE 2026-02-13
   ネイティブcontrolsは幅が足りない/transform/zoomで表示が間引かれるため、
   変形を無効化し、controlsの幅を最優先で確保する
*/
#global-audio{
  width: 260px;
  max-width: 42vw;
}
@media (max-width: 768px){
  #global-audio{ width: 100%; max-width: 100%; }
}

@media (max-width: 900px){
  #global-audio-player .audio-player-meta{
    flex: 1 1 100%;
    min-width: 0;
    display: block;
    margin-bottom: 6px;
  }
  #global-audio-player .audio-player-nav{
    order: 2;
  }
  #global-audio-player #global-audio{
    order: 3;
  }
}



/* SAFE_AREA_SUPPORT 2026-02-22 */
.audio-player-shell{
  padding-bottom: calc(10px + env(safe-area-inset-bottom));
}

body{
  padding-bottom: calc(96px + env(safe-area-inset-bottom));
}

@media (max-width: 768px){
  body{
    padding-bottom: calc(96px + env(safe-area-inset-bottom));
  }
}

@media (max-width: 768px){
  html.kma-ios-safari .audio-player-shell{
    bottom: -24px;
    padding-bottom: 8px;
    box-shadow: 0 -4px 12px rgba(0,0,0,.18);
    border-top-color: rgba(255,255,255,.06);
  }

  html.kma-ios-safari body{
    padding-bottom: 96px;
  }
}


/* MOBILE_TAP_TARGETS 2026-02-22 */
@media (max-width: 768px){
  #global-audio-player{
    padding-top: 12px;
    padding-left: 12px;
    padding-right: 12px;
  }

  /* タイトルは2行まで表示し、誤タップを減らす */
  #global-audio-player .audio-player-title{
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.25;
    font-size: 15px;
  }
  #global-audio-player .audio-player-sub{
    font-size: 12px;
    margin-top: 4px;
  }

  /* 指で押しやすいサイズへ */
  #global-audio-player .audio-player-nav{
    gap: 10px;
  }
  #global-audio-player .audio-player-nav button{
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: 20px;
  }

  /* native controlsは上下の圧迫を避ける */
  #global-audio{
    min-height: 44px;
  }
}
