@charset "UTF-8";
/*=================================================================
  common
=================================================================*/
body, html {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-touch-callout: none;
    -moz-user-select: none;
    -khtml-user-select: none;
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    font-family: Verdana, sans-serif;
    font-size: 14px;
    font-weight: 300;
    height: 100%;
    width: 100%;
    margin: 0px 0px 0px 0px;
}
*:not(input){
    -webkit-user-select: none;
}
/*img{
    pointer-events: none;
}*/
.header-margin1 {
  margin-top: 40px;
}

.header-margin2 {
  margin-top: 68px;
}

.header-margin3 {
  margin-top: 120px;
}

.header-margin4 {
  margin-top: 76px;
}

/* ロゴ＋ページタイトル＋1行サブ（仮ログインID 等）。.header-margin4 では本文先頭がヘッダに隠れる場合用 */
.header-margin4-subtitle {
  margin-top: 120px;
}

.header-margin5 {
  margin-top: 120px;
}

.header-margin6 {
  margin-top: 148px;
}

.bi {
  display: inline-block;
  vertical-align: -0.125em;
  fill: currentcolor;
}

.btn-wrap {
  margin: 0 auto;
  text-align: center;
}

a:hover {
  color: #212529;
}
a.text-white:hover {
  color: #fff;
}
a.text-danger:hover {
  color: #dc3545;
}
a.orange:hover {
  color: #ff8000;
}

h2 {
  padding-top: .5em;
  font-size: 16px;
  font-weight: normal;
}

.header-small {
  font-size: 14px;
}

.small {
  font-size: 11px;
}

.orange {
  color: #ff8000;
}

.text-indent {
  text-indent: -1em;
  padding-left: 1em;
}

/* header（レイアウト先頭の1枚のみ。本文内の <header> まで固定表示にしない） */
body > header {
  position: fixed;
  top: 0;
  background-image: url("../image/head.png");
  background-repeat: repeat-x;
  z-index: 99999;
}

/* body>header が z-index:99999 のため、Bootstrap モーダル（既定 ~1055）が背面に回らないよう上書き */
.modal-backdrop {
  z-index: 100040;
}
.modal {
  z-index: 100050;
}

.header__offcanvas-btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin-top: 6px;
  height: 30px;
  font-size: 12.5px;
  font-weight: bold;
  line-height: 1.25;
}
.header__offcanvas-btn:focus {
  -webkit-box-shadow: none;
          box-shadow: none;
}
.header__offcanvas-btn .bi {
  margin-right: .5em;
}
.header__offcanvas-btn .bi::before {
  font-size: 16px;
  font-weight: bold !important;
}

.header-logo {
  background-image: url("../image/rogo.png");
  background-repeat: no-repeat;
  height: 40px;
  text-indent: -9999px;
  background-position: right center;
  display: block;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  .header-logo {
    background-size: 188px 30px;
    background-image: url("../image/rogox2.png");
  }
}
.header-logo a {
  height: 32px;
  text-indent: -9999px;
  display: block;
}

.news-ticker {
  padding-right: 0;
  line-height: 1;
}
.news-ticker .news-ticker__text {
  font-size: 10px;
  color: #fff;
}

.timestamp {
  margin-top: 1px;
  height: 17px;
  background-color: #444;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 0.35rem 0 0.25rem;
  min-width: 5.25rem;
  color: #ccc;
  white-space: nowrap;
  line-height: 1.2;
}

.slider-header {
  position: fixed;
  top: 58px;
  padding-top: 1px;
  width: 100%;
  text-align: center;
  color: #fff;
  z-index: 999;
}
.slider-header .slider-control {
  height: 52px;
}
.slider-header .slider-control .prev-arrow {
  float: left;
}
.slider-header .slider-control .next-arrow {
  float: right;
}
.slider-header .slider-control .slide-arrow {
  width: 57px;
  height: 57px;
  padding: 0;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(180deg, #50575e 0%, #2f3439 60%, #1f2327 100%);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-tap-highlight-color: transparent;
}
.slider-header .slider-control .slide-arrow:active {
  transform: translateY(1px);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
.slider-header .slider-control .slide-arrow .bi {
  font-size: 20px;
  line-height: 1;
}
.slider-header .area-name-slider {
  margin: -48px auto 0;
  padding: 0;
  width: 200px;
}
.slider-header .slick-dots {
  position: relative;
  bottom: 10px;
  margin: 0 auto;
  width: 200px;
}
.slider-header .slick-dots li {
  width: 5px;
  height: 5px;
}
.slider-header .slick-dots li:first-of-type {
  margin-left: -10px;
}
.slider-header .slick-dots li button:before {
  content: '●';
  color: #ccc;
  opacity: 1;
}
.slider-header .slick-dots li.slick-active button:before {
  color: #fc8b00;
}

/* sidebar（Offcanvas は背面に modal-backdrop を使うため、.modal-backdrop より前面にする）
-----------------------------------------------------------------*/
.sidebar {
  width: 272px;
  z-index: 100070;
}
.sidebar .offcanvas-body {
  padding: 0;
}
.sidebar .list-group {
  border-radius: 0;
}
.sidebar .list-group .list-group-item .sidebar__list-item-icon {
  flex-shrink: 0;
  margin-right: .5em;
  font-size: 1.25rem;
  line-height: 1;
  width: 1.65rem;
  text-align: center;
  vertical-align: -0.125em;
}

.sidebar__close-btn {
  margin: 1em;
}
.sidebar__close-btn .bi {
  margin-right: .5em;
}

.list-group {
  padding-top: .5rem;
}

/* footer（レイアウト末尾の1枚のみ。本文内の <footer> まで固定表示にしない） */
body > footer {
  position: fixed;
  bottom: 0;
  padding: 0 !important;
  z-index: 99999;
}
footer .navbar {
  padding: 0;
}
footer .nav-link {
  padding: .25em 0;
  width: 20%;
  text-align: center;
  font-size: 12px;
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  border-right: 1px solid #212529;
}
footer .nav-link.active {
  background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%);
  background-image: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%);
}
footer .nav-link:hover {
  color: #fff;
}
footer .nav-link .nav-link__icon {
  max-width: 30px;
  max-height: 30px;
}

/* main-contents
-----------------------------------------------------------------*/
.main-contents {
  padding-bottom: 6em;
}

/* 会員登録・内容紹介（/r/reg, /r/regau）・会員手続き（/r/user/dc 等）— 固定フッターナビ＋safe-area */
.main-contents.reg-page-main,
.main-contents.user-dc-main {
  padding-bottom: calc(6em + 5rem + env(safe-area-inset-bottom, 0px)) !important;
}
.main-contents.reg-page-main.header-margin3,
.main-contents.user-dc-main.header-margin3 {
  margin-top: 90px !important;
}
.reg-page-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.5rem 0.75rem;
  width: 100%;
  text-align: center;
}
.reg-page-actions .btn {
  flex: 0 0 auto;
}

.map-slider {
  margin: 0;
  padding: 0;
}
.map-slider .slick-slide > a {
  display: block;
  width: 100%;
}
.map-slider img {
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 100%;
  height: auto;
}

/*=================================================================
  ホーム（/r 交通 TOP）
=================================================================*/
/* リスト見出し帯・サイドメニュー見出し（TOP のヘッドラインと同一の水色グラデ） */
.app-strip-gradient,
.road-top-strip {
  background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  background-image: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  color: #fff !important;
}
.app-strip-gradient.text-danger {
  color: #dc3545 !important;
}

/* /r/traffic 広域下の路線行：親行と同じフラットな区切り（子だけ角枠にならないようにする） */
#accordion-traffic-top .traffic-index-koiki-sub .list-group-item {
  border-radius: 0;
}

/* 共通: 黒グラデのリスト行（/r/traffic, setting, rail, my など）を縦に広げる */
a.list-group-item.d-flex.align-items-center.text-white.bg-dark.bg-gradient,
a.list-group-item.collapse-head.d-flex.align-items-center.text-white.bg-dark.bg-gradient {
  min-height: 50px;
  padding-top: 0.65rem;
  padding-bottom: 0.65rem;
}

/* /r/traffic の展開後リスト（上り/下り など）を少しだけ広げる */
a.list-group-item.d-flex.align-items-center.justify-content-end {
  min-height: 44px;
  padding-top: 0.55rem;
  padding-bottom: 0.55rem;
}

/* 交通ページ カテゴリタブ（広域高速・首都高速・一般道 等）: フォルダ型（下は直角で下帯と隙間なく接続） */
.nav-pills#category .nav-link {
  border: 1px solid transparent;
  box-sizing: border-box;
  border-radius: 0.25rem 0.25rem 0 0;
}
.nav-pills#category .nav-link:not(.active) {
  color: #b0cde8 !important;
  background: transparent !important;
  background-image: none !important;
  border-color: #6b95c2 !important;
}
.nav-pills#category .nav-link:not(.active):hover {
  color: #d8e8f7 !important;
  border-color: #82a8d1 !important;
}
.nav-pills#category .nav-link.active,
.nav-pills#category .show > .nav-link {
  color: #fff !important;
  background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  background-image: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  border-color: #4a7aa3 !important;
  position: relative;
  z-index: 1;
  margin-bottom: -1px;
}

/* content-block（汎用） / headline（互換）
-----------------------------------------------------------------*/
.content-block,
.headline {
  margin-top: 1em;
}
.content-block .headline__icon,
.headline .headline__icon {
  max-width: 118px;
  max-height: 29px;
  margin-bottom: .5em;
}
.content-block .headline__text,
.headline .headline__text {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
  font-size: 12px;
  line-height: 1.2;
}

/* menu-list
-----------------------------------------------------------------*/
.menu-list {
  margin-top: 1em;
}
.menu-list .menu-list__icon {
  flex-shrink: 0;
  margin-right: .5em;
  font-size: 1.75rem;
  line-height: 1;
  width: 2.25rem;
  text-align: center;
}

/* 通行止一覧：地方見出しも TOP と同じグラデ（.app-strip-gradient と同等） */
.kosoku-stop-list .kosoku-stop-section-title {
  background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  background-image: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%) !important;
  color: #fff !important;
}

/* リスト行は白背景、ホバーは薄いグレー */
.kosoku-stop-list .kosoku-stop-row:hover {
  background-color: #f8f9fa !important;
}

/*=================================================================
  道路
=================================================================*/
.sapa-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.sapa-header h2 {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.sapa-header .btn {
  width: 25%;
  font-size: 12px;
  white-space: nowrap;
}

.reportIcon {
  display: table;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}
.reportIcon li {
  display: block;
  float: left;
  padding: 2px 5px 2px 0;
  min-width: 30px;
  font-size: 11px;
  line-height: 1;
  white-space: nowrap;
}
.reportIcon li span {
  float: left;
  position: relative;
  top: 1px;
  margin: 0 2px 3px 0;
  padding: 0 3px;
  font-size: 8px;
}
.reportIcon li span.black {
  background-color: #111;
}
.reportIcon li span.pink {
  background-color: #ff96ff;
}
.reportIcon li span.red {
  background-color: #e10e0e;
}
.reportIcon li span.yellow {
  background-color: #fcf300;
}
.reportIcon li span.blue {
  background-color: #73aad3;
}
.reportIcon li span.purple {
  background-color: #980098;
}
.reportIcon li span.kon {
  background-color: #0000fe;
}

.sapaTable td > div {
  position: relative;
  height: 100%;
}
.sapaTable td a {
  color: #ccc;
}
.sapaTable td .iconsize img {
  height: 20px;
}
.sapaTable td:first-child, .sapaTable td:last-child {
  width: 28%;
  background: #222;
  font-size: 11px;
  padding: 0px 2px;
  color: #ccc;
  line-height: 1.1;
}
.sapaTable td:first-child p, .sapaTable td:last-child p {
  position: relative;
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 98%;
  height: 20px;
  border: 1px solid #8ddcb4;
  border-radius: 2px;
  background: #00845f;
  background: -webkit-gradient(linear, left top, left bottom, from(#46b394), to(#00845f)) repeat scroll 0 0 #757575 !important;
  background: linear-gradient(#46b394, #00845f) repeat scroll 0 0 #757575 !important;
  text-align: center;
  font-size: 10px;
  line-height: 1.8;
  color: #fff;
  text-shadow: 1px 1px 1px #444;
}
.sapaTable td:first-child {
  text-align: right;
}
.sapaTable td:nth-child(2), .sapaTable td:nth-child(4) {
  width: 20px;
  border-left: 1px solid #bbb;
  border-right: 1px solid #bbb;
}
.sapaTable td:nth-child(2).none, .sapaTable td:nth-child(4).none {
  border: none !important;
}
.sapaTable td:nth-child(2).normal, .sapaTable td:nth-child(4).normal {
  background: #ccc url("../image/normal.gif") repeat top left;
}
.sapaTable td:nth-child(2).black {
  background: -webkit-gradient(linear, left top, right top, from(#111), color-stop(0.2, #555), color-stop(0.3, #555), to(#111));
}
.sapaTable td:nth-child(2).pink {
  background: -webkit-gradient(linear, left top, right top, from(#e426e4), color-stop(0.7, #ff96ff), color-stop(0.8, #ff96ff), to(#e426e4));
}
.sapaTable td:nth-child(2).red {
  background: -webkit-gradient(linear, left top, right top, from(#920000), color-stop(0.7, #e10e0e), color-stop(0.8, #e10e0e), to(#920000));
}
.sapaTable td:nth-child(2).yellow {
  background: -webkit-gradient(linear, left top, right top, from(#ada700), color-stop(0.7, #fcf300), color-stop(0.8, #fcf300), to(#ada700));
}
.sapaTable td:nth-child(2).blue {
  background: -webkit-gradient(linear, left top, right top, from(#04406d), color-stop(0.7, #73aad3), color-stop(0.8, #73aad3), to(#04406d));
}
.sapaTable td:nth-child(2).purple {
  background: -webkit-gradient(linear, left top, right top, from(#6f0c6f), color-stop(0.7, #980098), color-stop(0.8, #980098), to(#6f0c6f));
}
.sapaTable td:nth-child(2).kon {
  background: -webkit-gradient(linear, left top, right top, from(#000070), color-stop(0.7, #0000fe), color-stop(0.8, #0000fe), to(#000070));
}
.sapaTable td:nth-child(4).black {
  background: -webkit-gradient(linear, left top, right top, from(#111), color-stop(0.2, #555), color-stop(0.3, #555), to(#111));
}
.sapaTable td:nth-child(4).pink {
  background: -webkit-gradient(linear, left top, right top, from(#e426e4), color-stop(0.2, #ff96ff), color-stop(0.3, #ff96ff), to(#e426e4));
}
.sapaTable td:nth-child(4).red {
  background: -webkit-gradient(linear, left top, right top, from(#920000), color-stop(0.2, #e10e0e), color-stop(0.3, #e10e0e), to(#920000));
}
.sapaTable td:nth-child(4).yellow {
  background: -webkit-gradient(linear, left top, right top, from(#ada700), color-stop(0.2, #fcf300), color-stop(0.3, #fcf300), to(#ada700));
}
.sapaTable td:nth-child(4).blue {
  background: -webkit-gradient(linear, left top, right top, from(#2c6a98), color-stop(0.2, #73aad3), color-stop(0.3, #73aad3), to(#2c6a98));
}
.sapaTable td:nth-child(4).purple {
  background: -webkit-gradient(linear, left top, right top, from(#6f0c6f), color-stop(0.2, #980098), color-stop(0.3, #980098), to(#6f0c6f));
}
.sapaTable td:nth-child(4).kon {
  background: -webkit-gradient(linear, left top, right top, from(#000070), color-stop(0.2, #0000fe), color-stop(0.3, #0000fe), to(#000070));
}
.sapaTable td:nth-child(3) {
  width: 32%;
  background: #474747;
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  text-shadow: -1px 1px 1px #000 !important;
  line-height: 1.1;
}
.sapaTable td:nth-child(3) p {
  font-weight: normal;
  font-size: 12px;
  color: #ccc;
  width: 45%;
  margin: 0 !important;
}
.sapaTable td:nth-child(3) p.left {
  float: left;
  text-align: left;
  padding: 0 0 0 5px;
}
.sapaTable td:nth-child(3) p.right {
  float: right;
  text-align: right;
  padding: 0 5px 0 0;
}
.sapaTable .jikoR {
  display: block;
  position: absolute;
  bottom: 0px;
  left: 7px;
  z-index: 99999;
}
.sapaTable .jikoL {
  display: block;
  position: absolute;
  bottom: 0px;
  right: 7px;
}
.sapaTable .iconR {
  display: block;
  position: absolute;
  bottom: 5px;
  right: -10px;
  width: 100%;
  text-align: right;
  z-index: 9999;
}
.sapaTable .iconL {
  display: block;
  position: absolute;
  bottom: -5px;
  left: -10px;
  width: 100%;
  text-align: left;
  z-index: 9999;
}
.sapaTable .yellowTxt {
  color: #f2ff86;
}
.sapaTable .greenTxt {
  color: #00b709;
}
.sapaTable .orangeTxt {
  color: #fc8c00;
}

/*=================================================================
  鉄道
=================================================================*/
/*=================================================================
  天気
=================================================================*/
.uv-level1 {
  color: navy;
}

.uv-level2 {
  color: blue;
}

.uv-level3 {
  color: purple;
}

.uv-level4 {
  color: fuchsia;
}

.uv-level5 {
  color: red;
}

/* お天気詳細（/r/weather/info/...） */
.weather-info-page.container-fluid {
  --bs-gutter-x: 0;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.weather-info-page.main-contents {
  margin-top: 60px;
}

.weather-info-page {
  background: transparent;
  overflow-x: hidden;
  max-width: 100%;
}

.weather-info-column {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  align-items: stretch;
  background: #222;
  color: #fff;
  min-height: 100%;
}

.weather-info-page .weather-info-head {
  padding: 0.75rem 0.5rem 0.5rem;
  border-bottom: 1px solid #444;
}

.weather-info-page .weather-info-title {
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  margin: 0;
  color: #fff;
}

.weather-info-page .weather-info-time {
  font-size: 0.8rem;
  color: #ccc;
  text-align: right;
  margin: 0.35rem 0 0;
}

.weather-info-page .weather-info-time .bi {
  margin-right: 0.15rem;
}

.weather-info-page .weather-info-location {
  font-size: 1.05rem;
  font-weight: bold;
  padding: 0.85rem 0.75rem 0.25rem;
  margin: 0;
}

.weather-info-today-lead {
  text-align: center;
  font-size: 1.05rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 0 0.75rem 0.65rem;
  padding: 0 0.75rem;
}

.weather-info-today-lead__prefix {
  color: #fff;
}

.weather-info-today-lead__cond {
  color: #ff9800;
}

.weather-info-page .weather-info-main {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0 0.75rem 1rem;
}

.weather-info-page .weather-info-icon-wrap {
  flex-shrink: 0;
  width: 88px;
  height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #5b6168 0%, #3b4148 55%, #2a2f35 100%);
  border: 1px solid #6b727a;
  border-radius: 4px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), inset 0 -1px 0 rgba(0, 0, 0, 0.28), 0 2px 6px rgba(0, 0, 0, 0.35);
  overflow: hidden;
}

.weather-info-icon-font {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 4rem;
  line-height: 1;
  border-radius: 4px;
}

.weather-info-icon-font .wi {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
  color: #fff;
  border-radius: 4px;
}
.weather-info-icon-font .wi::before {
  position: absolute;
  left: 50%;
  top: 50%;
  font-size: 4rem;
  line-height: 1;
  transform: translate(-50%, calc(-50% + var(--wi-shift-y, 0px)));
}

.weather-info-icon-font .icon-bg-sun {
  background: linear-gradient(180deg, #ffb74d 0%, #f57c00 100%);
}

.weather-info-icon-font .icon-bg-cloud {
  background: linear-gradient(180deg, #4d545c 0%, #2b3036 100%);
}

.weather-info-icon-font .icon-bg-rain {
  background: linear-gradient(180deg, #1976d2 0%, #0d47a1 100%);
}

.weather-info-icon-font .icon-bg-snow {
  background: linear-gradient(180deg, #b3e5fc 0%, #42a5f5 100%);
}

.weather-info-icon-font .icon-bg-info {
  background: linear-gradient(180deg, #6d737a 0%, #3e4349 100%);
  color: #ffd54f;
}
.weather-info-icon-font .wi-day-sunny {
  --wi-shift-y: 2px;
}

.weather-info-icon-font .wi-day-cloudy {
  --wi-shift-y: 1px;
}

.weather-info-icon-font .wi-cloudy {
  --wi-shift-y: 1px;
}

.weather-info-icon-font .wi-day-rain {
  --wi-shift-y: 0px;
}

.weather-info-icon-font .wi-rain {
  --wi-shift-y: 0px;
}

.weather-info-icon-font .wi-showers {
  --wi-shift-y: 0px;
}

.weather-info-icon-font .wi-rain-mix {
  --wi-shift-y: -1px;
}

.weather-info-icon-font .wi-thunderstorm {
  --wi-shift-y: 0px;
}

.weather-info-icon-font .wi-day-snow {
  --wi-shift-y: 1px;
}

.weather-info-icon-font .wi-snow {
  --wi-shift-y: 1px;
}

.weather-info-icon-font .wi-snow-wind {
  --wi-shift-y: 1px;
}

.weather-info-icon-font .wi-strong-wind {
  --wi-shift-y: 0px;
}

.weather-info-icon-font .wi-na {
  --wi-shift-y: 0px;
}

.weather-info-page .weather-info-stats {
  flex: 1;
  min-width: 0;
  font-size: 0.95rem;
  line-height: 1.55;
}

.weather-info-page .weather-info-stats__row {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.weather-info-inline-icon {
  width: 1.25rem;
  text-align: center;
  flex-shrink: 0;
}

.weather-info-inline-icon--rain {
  color: #5dade2;
}

.weather-info-inline-icon--snow {
  color: #b3e5fc;
}

.weather-info-inline-icon--temp {
  color: #ffb74d;
}

.weather-info-inline-icon--wind {
  color: #cfd8dc;
}

.weather-info-inline-icon--uv {
  color: #ffd54f;
  margin-right: 0.15rem;
}

.weather-info-inline-icon--typhoon {
  color: #90caf9;
  margin-right: 0.15rem;
}

.weather-info-inline-icon--warning {
  color: #ffe082;
  margin-right: 0.15rem;
}

.weather-info-page .weather-info-divider {
  height: 1px;
  background: #444;
  margin: 0;
  border: 0;
}

/* UV より上: Myアクセス登録（ボタン風リンク・FAB 外） */
.weather-info-myaccess-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0.65rem 0.75rem 0.5rem;
  padding: 0.55rem 0.85rem;
  font-size: 0.95rem;
  font-weight: normal;
  color: #fff !important;
  text-decoration: none !important;
  border: 1px solid #6c757d;
  border-radius: 0.375rem;
  background: linear-gradient(180deg, #3d4449 0%, #2c3136 100%);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}

.weather-info-myaccess-btn:hover {
  color: #fff !important;
  border-color: #8a9399;
  background: linear-gradient(180deg, #4a5258 0%, #353a40 100%);
}

.weather-info-page a.weather-info-row:hover {
  color: #fff;
  background: #2a2a2a;
}

.weather-info-page .weather-info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 0.75rem;
  font-size: 0.95rem;
  color: #fff;
  text-decoration: none;
  border-bottom: 1px solid #444;
}

.weather-info-page .weather-info-row--button {
  width: 100%;
  background: transparent;
  border-top: 0;
  border-right: 0;
  border-left: 0;
  text-align: left;
}

.weather-info-page .weather-info-row:last-child {
  border-bottom: none;
}

.weather-info-page .weather-info-row--static {
  cursor: default;
}

.weather-info-page .weather-info-row .bi-chevron-right {
  color: #888;
  font-size: 1rem;
}

.weather-info-page .weather-info-menu {
  margin-top: 0.5rem;
  border-top: 1px solid #444;
}

.weather-info-page .weather-info-menu .weather-info-row {
  justify-content: flex-end;
  gap: 0.4rem;
  border-bottom: 1px solid #444;
}

.weather-info-tomorrow-section {
  margin: 0.75rem 0.75rem 1rem;
  padding: 0.75rem 0.65rem 0.85rem;
  background: #2a2a2a;
  border: 1px solid #444;
  border-radius: 4px;
}

.weather-info-tomorrow-section__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: #aaa;
  margin-bottom: 0.5rem;
}

.weather-info-tomorrow-section__head-title {
  font-weight: bold;
  color: #fff;
  font-size: 0.9rem;
}

.weather-info-tomorrow-focus {
  padding: 0;
}

.weather-info-tomorrow-focus__lead {
  text-align: center;
  font-size: 1.05rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 1rem 0 1.25rem;
  padding: 0 0.25rem;
}

.weather-info-tomorrow-focus__lead .tomorrow-prefix {
  color: #fff;
}

.weather-info-tomorrow-focus__lead .tomorrow-condition {
  color: #ff9800;
}

.weather-info-tomorrow-focus__stats {
  font-size: 0.95rem;
  line-height: 1.85;
  color: #eee;
}

.weather-info-tomorrow-focus__stats-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.weather-info-tomorrow-focus__stats-row .bi {
  flex-shrink: 0;
  font-size: 1.1rem;
}

.weather-info-tomorrow-focus__stats-row .bi-umbrella-fill {
  color: #64b5f6;
}

.weather-info-tomorrow-focus__stats-row .bi-arrow-up-circle-fill {
  color: #ef5350;
}

.weather-info-tomorrow-focus__stats-row .bi-arrow-down-circle-fill {
  color: #42a5f5;
}

.weather-uv-modal .modal-dialog {
  max-width: 560px;
  margin: 1rem auto;
}

.weather-uv-modal .modal-content {
  position: relative;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  background: #fff;
}

.weather-uv-modal .modal-body {
  padding: 0;
  position: relative;
  background: #fff;
}

.weather-uv-modal .uv-explain-column {
  width: 100%;
  background: #fff;
}

.weather-uv-modal .uv-explain-header {
  position: relative;
  padding-right: 2.75rem;
  background: #313237;
  color: #fff;
  text-align: center;
  margin: 0;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
}

.weather-uv-modal .uv-explain-header__title {
  font-size: 1rem;
  font-weight: bold;
  margin: 0;
}

.weather-uv-modal .uv-explain-body {
  width: 100%;
  box-sizing: border-box;
  background: #fff;
}

.weather-uv-modal .uv-explain-row {
  padding: 1rem 1rem;
  border-bottom: 1px solid #bbb;
  font-size: 0.95rem;
  line-height: 1.65;
  color: #222;
  box-sizing: border-box;
  width: 100%;
}

.weather-uv-modal .uv-explain-body .uv-explain-row:last-child {
  border-bottom: none;
}

.weather-uv-modal .uv-explain-level {
  font-weight: bold;
}

.weather-uv-modal .uv-explain-level--1 {
  color: #001a80;
}

.weather-uv-modal .uv-explain-level--2 {
  color: #0027b3;
}

.weather-uv-modal .uv-explain-level--3 {
  color: #7a1ea1;
}

.weather-uv-modal .uv-explain-level--4 {
  color: #d000ff;
}

.weather-uv-modal .uv-explain-level--5 {
  color: #e40000;
}

.weather-uv-modal .uv-explain-footer {
  background: #333;
  color: #fff;
  text-align: right;
  font-size: 0.85rem;
  padding: 0.65rem 1rem;
  margin: 0;
  box-sizing: border-box;
  width: 100%;
}

.weather-uv-modal .uv-modal-close {
  position: absolute;
  right: 0.35rem;
  top: 0.45rem;
  z-index: 20;
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 1.5rem;
  font-weight: normal;
  line-height: 1;
  padding: 0.1rem 0.35rem;
  cursor: pointer;
}

/* Ｍｙエリア「地方体系」モーダル（天気 UV 解説モーダルと同系の枠・ヘッダー・閉じる） */
.myarea-pref-modal .modal-dialog {
  max-width: min(92vw, 640px);
  margin: 1rem auto;
}

.myarea-pref-modal .modal-content {
  position: relative;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  background: #fff;
}

.myarea-pref-modal .modal-body {
  padding: 0;
  position: relative;
  background: #212529;
}

.myarea-pref-modal__header {
  position: relative;
  padding-right: 2.75rem;
  background: #313237;
  color: #fff;
  text-align: center;
  margin: 0;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
}

.myarea-pref-modal__title {
  font-size: 1rem;
  font-weight: bold;
  margin: 0;
}

.myarea-pref-modal__close {
  position: absolute;
  right: 0.35rem;
  top: 0.45rem;
  z-index: 20;
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 1.5rem;
  font-weight: normal;
  line-height: 1;
  padding: 0.1rem 0.35rem;
  cursor: pointer;
}

.myarea-pref-modal__iframe {
  width: 100%;
  border: 0;
  display: block;
  min-height: 55vh;
  height: 70vh;
  background: #212529;
}

/*=================================================================
  マップ
=================================================================*/
/* マップ一覧
-----------------------------------------------------------------*/
.map-list {
  --bs-gutter-x: .5rem;
  --bs-gutter-y: .5rem;
  margin-top: 0;
}
.map-list .map-list-item {
  text-decoration: none;
}
.map-list .map-list-item .map-list-item-header {
  margin-bottom: .25em;
  padding: 0 .25em;
  background-color: #FFF8DC;
  font-size: 12px;
}
.map-list .map-list-item .map-list-item-image img {
  width: 100%;
}

/* マップ詳細
-----------------------------------------------------------------*/
.map-detail {
  margin-top: 0;
}
.map-detail img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

/*=================================================================
  渋滞予測
=================================================================*/
.calendar table {
  margin: 0 auto;
  font-size: 16px;
}
.calendar table tr td {
  padding: 8px;
  border: 1px solid #212529;
  text-align: center;
}

/*=================================================================
  FAB / スピードダイアル（路線・地図などのフッターリンク・全ビューポート共通）
-----------------------------------------------------------------*/
.sd-layer {
    position: fixed;
    inset: 0;
    z-index: 99998;
    pointer-events: none;
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.22s ease;
    will-change: transform, opacity;
  }

  .sd-layer--hidden {
    transform: translate3d(0, 110vh, 0);
    opacity: 0;
    pointer-events: none !important;
  }

  .sd-layer--hidden .sd-root,
  .sd-layer--hidden .sd-backdrop {
    pointer-events: none !important;
  }

  .sd-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.42);
    cursor: pointer;
    pointer-events: auto;
  }

  .sd-backdrop[hidden] {
    display: none !important;
  }

  .sd-root {
    position: fixed;
    right: calc(1.25rem + env(safe-area-inset-right, 0px));
    bottom: calc(5rem + env(safe-area-inset-bottom, 0px));
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
    pointer-events: auto;
  }

  /* 上に行が積み、各段は「ラベル（左）＋丸アイコン（右）」 */
  .sd-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, visibility 0.2s;
  }

  .sd-root--open .sd-actions {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .sd-action {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    text-decoration: none !important;
    opacity: 0;
    transform: translate3d(0, 10px, 0);
    transition: opacity 0.22s ease, transform 0.24s cubic-bezier(0.34, 1.2, 0.64, 1);
  }

  .sd-root--open .sd-action {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }

  .sd-root--open .sd-action:nth-child(1) {
    transition-delay: 0.04s;
  }

  .sd-root--open .sd-action:nth-child(2) {
    transition-delay: 0.09s;
  }

  .sd-root--open .sd-action:nth-child(3) {
    transition-delay: 0.14s;
  }

  .sd-root--open .sd-action:nth-child(4) {
    transition-delay: 0.19s;
  }

  .sd-root--open .sd-action:nth-child(5) {
    transition-delay: 0.24s;
  }

  .sd-action__label {
    max-width: min(13rem, calc(100vw - 6rem));
    padding: 0.46rem 0.78rem;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.5;
    font-family: inherit;
    color: #212529 !important;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 0.35rem;
    box-shadow: 0 0.1rem 0.45rem rgba(0, 0, 0, 0.28);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .sd-action__disc {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.2rem;
    height: 3.2rem;
    flex-shrink: 0;
    border-radius: 50%;
    font-size: 1.4rem;
    line-height: 1;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.25);
    box-shadow: 0 0.2rem 0.55rem rgba(0, 0, 0, 0.4);
  }

  .sd-action__disc--primary {
    background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%);
  }

  .sd-action__disc--secondary {
    background: linear-gradient(180deg, #6c757d 0%, #495057 50%, #3d4449 100%);
  }

  .sd-action:active .sd-action__label {
    filter: brightness(0.96);
  }

  .sd-action:active .sd-action__disc {
    filter: brightness(1.1);
  }

  .sd-fab {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    text-decoration: none;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: 0 0.2rem 0.65rem rgba(0, 0, 0, 0.45);
  }

  .sd-fab--toggle {
    border: 0;
    padding: 0;
    cursor: pointer;
  }

  /* TOP 帯（.app-strip-gradient）と同系の水色グラデ */
  .sd-fab--primary {
    width: 4rem;
    height: 4rem;
    background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%);
    font-size: 1.8rem;
    line-height: 1;
  }

.sd-fab:active {
  filter: brightness(1.08);
}

/* /r/traffic/{area}/{name}（#koiki-collapse-n 等）: md 以上でもエリア道路トップへ FAB */
@media (min-width: 768px) {
  .traffic-area-exit-fab {
    position: fixed;
    right: calc(1.25rem + env(safe-area-inset-right, 0px));
    bottom: calc(5rem + env(safe-area-inset-bottom, 0px));
    z-index: 99998;
    pointer-events: none;
  }

  .traffic-area-exit-fab__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    text-decoration: none;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: 0 0.2rem 0.65rem rgba(0, 0, 0, 0.45);
    font-size: 1.8rem;
    line-height: 1;
    background: linear-gradient(180deg, #82a8d1 0%, #6b95c2 50%, #5b87b4 100%);
    pointer-events: auto;
  }

  .traffic-area-exit-fab__link:active {
    filter: brightness(1.08);
  }
}

/*# sourceMappingURL=common.css.map */