@charset "UTF-8";
/* ============================================================
   Recruit Floating Banner
   - TOPページ→/recruit2/ 採用LPへの右端フローティング動線
   - パルスアニメ＋オレンジ系グラデ＋縦書き「採用情報」
   - height 直接指定、位置は top 20%（やや上寄せ）
   ============================================================ */

.recruit-fb{
  position: fixed;
  right: 0;
  top: 20%;
  z-index: 9990;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 135px;
  padding: 8px 6px;
  background: linear-gradient(180deg, #ff8b3d 0%, #ed6b1f 55%, #d85510 100%);
  color: #fff !important;
  text-decoration: none !important;
  border-radius: 8px 0 0 8px;
  box-shadow: -4px 6px 16px rgba(216,85,16,.35),
              0 0 0 0 rgba(237,107,31,.45);
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", sans-serif;
  transition: transform .25s ease, box-shadow .25s ease;
  animation: recruit-fb-pulse 2.5s ease-in-out infinite;
}
.recruit-fb:hover{
  transform: translateX(-4px);
  box-shadow: -6px 8px 22px rgba(216,85,16,.55);
  animation-play-state: paused;
}
.recruit-fb:focus-visible{
  outline: 3px solid #ffd56b;
  outline-offset: -3px;
}
.recruit-fb__icon{
  font-size: 18px;
  line-height: 1;
  margin-bottom: 6px;
  color: #fff;
}
.recruit-fb__title{
  display: block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .15em;
  writing-mode: vertical-rl;
  text-orientation: upright;
  line-height: 1.4;
  text-shadow: 0 1px 2px rgba(0,0,0,.18);
}

@keyframes recruit-fb-pulse{
  0%, 100%{
    box-shadow: -4px 6px 16px rgba(216,85,16,.35),
                0 0 0 0 rgba(237,107,31,.50);
  }
  50%{
    box-shadow: -4px 6px 16px rgba(216,85,16,.45),
                0 0 0 10px rgba(237,107,31,0);
  }
}

/* SP（768px以下） */
@media (max-width: 768px){
  .recruit-fb{
    width: 48px;
    height: 110px;
    padding: 7px 5px;
    border-radius: 6px 0 0 6px;
  }
  .recruit-fb__icon{
    font-size: 15px;
    margin-bottom: 5px;
  }
  .recruit-fb__title{
    font-size: 11px;
    letter-spacing: .1em;
  }
}

/* 極小（360px以下） */
@media (max-width: 360px){
  .recruit-fb{ width: 42px; height: 100px; padding: 6px 4px; }
  .recruit-fb__icon{ font-size: 13px; margin-bottom: 4px; }
  .recruit-fb__title{ font-size: 10px; letter-spacing: .08em; }
}

/* 印刷時は非表示 */
@media print{
  .recruit-fb{ display: none !important; }
}

/* prefers-reduced-motion: アニメーション無効 */
@media (prefers-reduced-motion: reduce){
  .recruit-fb{ animation: none; }
}
