@charset "UTF-8";

/*
  Admin mobile overrides.
  PC and tablet styles are protected by the link media attribute and this media query.
*/
@media (max-width: 767.98px) {
  html,
  body {
    min-width: 0;
    width: 100%;
    min-height: 100%;
    overflow-x: hidden;
    background: #f4f7f9;
    color: #203744;
    font-family: "Noto Sans Japanese", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  }

  body {
    margin: 0;
  }

  .body-min-width {
    min-width: 0;
  }

  .dashboard-header .dashboard-header__usage,
  .dashboard-header .dashboard-header__shortcut {
    display: none !important;
  }

  .dashboard-header .container-fluid {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .dashboard-header .nav-open-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin: 0;
    border: 1px solid #d6e0e5;
    border-radius: 7px;
    background: #fff;
    color: #203744;
    font-size: 1rem;
    line-height: 1;
  }

  .dashboard-header .dashboard-header__user-menu {
    margin-left: auto;
  }

  .dashboard-header .dashboard-header__actions {
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
    justify-content: flex-end !important;
  }

  .dashboard-header .dashboard-header__user-menu > .dropdown-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    padding: 0;
  }

  .dashboard-header .dashboard-header__user-menu .comment_avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    object-fit: cover;
  }

  .dashboard-header .dashboard-header__user-dropdown {
    width: min(92vw, 320px);
    max-width: calc(100vw - 24px);
    padding: 12px !important;
    border: 1px solid #d9e3e8;
    border-radius: 10px;
    box-shadow: 0 16px 36px rgba(32, 55, 68, .16);
    box-sizing: border-box;
  }

  .dashboard-header .dashboard-header__user-summary {
    padding: 0 2px 6px;
    color: #526a76;
    font-size: .82rem;
    font-weight: 700;
    line-height: 1.45;
  }

  .dashboard-header__mobile-menu {
    margin: 8px 0 10px;
    padding: 10px 0;
    border-top: 1px solid #e4ebef;
    border-bottom: 1px solid #e4ebef;
  }

  .dashboard-header__mobile-menu-title {
    margin: 0 0 8px;
    color: #203744;
    font-size: .78rem;
    font-weight: 800;
    line-height: 1.2;
  }

  .dashboard-header__mobile-menu-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 38px;
    padding: 8px 10px;
    border-radius: 7px;
    color: #203744;
    font-size: .86rem;
    font-weight: 700;
    line-height: 1.35;
    text-decoration: none;
  }

  .dashboard-header__mobile-menu-link:hover,
  .dashboard-header__mobile-menu-link:focus {
    background: #eef5f7;
    color: #174f63;
    text-decoration: none;
  }

  .dashboard-header__mobile-menu-link i {
    flex: 0 0 18px;
    color: #54717d;
    text-align: center;
  }

  .dashboard-header__mobile-menu-link.is-active {
    background: #fff7ef;
    color: #8a4c08;
  }

  .dashboard-header__mobile-menu-link.is-active i {
    color: #c87318;
  }

  .dashboard-header__mobile-menu-badge {
    width: 8px;
    height: 8px;
    margin-left: auto;
    border-radius: 50%;
    background: #dc3545;
  }

  .dashboard-header .dashboard-header__account-actions {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    min-width: 0;
  }

  .dashboard-header .dashboard-header__user-dropdown .dashboard-header__account-actions .btn {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    min-width: 0 !important;
    box-sizing: border-box;
    min-height: 38px;
    margin: 0 !important;
    padding: .5rem .75rem !important;
    padding-right: .75rem;
    padding-left: .75rem;
    border-radius: 7px !important;
    font-size: .84rem;
    font-weight: 800;
    white-space: normal;
  }

  .heading {
    padding-top: .42rem;
    padding-bottom: .42rem;
    margin-bottom: .75rem;
  }

  .heading > .container-fluid {
    padding-right: 12px !important;
    padding-left: 12px !important;
  }

  .heading > .container-fluid > .row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
  }

  .heading > .container-fluid > .row > [class*="col-"] {
    width: auto;
    max-width: none;
    margin-bottom: 0 !important;
    padding-right: 0;
    padding-left: 0;
  }

  .heading > .container-fluid > .row > [class*="col-"]:first-child {
    flex: 1 1 auto;
    min-width: 0;
  }

  .heading > .container-fluid > .row > [class*="col-"]:last-child {
    display: flex !important;
    flex: 0 0 auto;
    align-items: center;
    justify-content: flex-end !important;
    gap: .35rem;
    max-width: 58%;
    margin-left: auto;
  }

  .heading > .container-fluid > .row > [class*="col-"]:only-child {
    flex: 1 1 auto;
    justify-content: flex-start !important;
    max-width: 100%;
  }

  #subHeader .heading__ttl {
    display: block;
    max-width: 100%;
    padding: .4rem .45rem .4rem 1rem;
    margin-right: 0;
    font-size: .96rem;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transform: none;
  }

  #subHeader .heading__ttl::after {
    width: 5px;
  }

  .heading .btn,
  .heading .dz-remove {
    flex: 0 0 auto;
    min-height: 30px;
    padding: .32rem .5rem;
    font-size: .78rem;
    line-height: 1.2;
    white-space: nowrap;
  }

  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(> .card),
  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(> .dashboard-basic-info),
  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(.right-sidebar),
  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(> .account-section),
  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(> .admin-panel),
  .dashboard-body > .container-fluid > .row > [class*="col-"]:has(> .hint) {
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .dashboard-games .dashboard_sch,
  .dashboard_sch,
  .dashboard-body .card-grid,
  .dashboard-body .account-grid,
  .dashboard-body .template-select-grid,
  .dashboard-body .application-card-list,
  .dashboard-body .competition-card-list,
  .dashboard-body .admin-card-grid {
    display: grid;
    grid-template-columns: 1fr !important;
  }

  .dashboard-basic-info,
  .dashboard-feature .dashboard-games__item,
  .dashboard-games__link-card,
  .card.dashboard-panel,
  .admin-panel,
  .right-sidebar .card {
    width: 100%;
    max-width: 100%;
  }

  .modal-dialog,
  .modal-lg,
  .modal-xl {
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
    margin-right: 12px;
    margin-left: 12px;
  }

  .modal .modal-content {
    max-width: 100%;
  }

  .admin-mobile-limit-modal .modal-dialog {
    width: calc(100% - 24px);
    max-width: 420px;
    margin-right: auto;
    margin-left: auto;
  }

  .admin-mobile-limit-modal .modal-content {
    overflow: hidden;
    border: 0;
    border-radius: 10px;
    box-shadow: 0 18px 40px rgba(22, 46, 58, .22);
  }

  .admin-mobile-limit-modal .modal-header {
    align-items: center;
    padding: .85rem 1rem;
    border-bottom: 1px solid #dfe8ed;
    background: #f3f8fa;
  }

  .modal.admin-mobile-limit-modal .modal-header .modal-title {
    color: #203744 !important;
    font-size: .98rem;
    font-weight: 800;
    line-height: 1.35;
  }

  .modal.admin-mobile-limit-modal .btn-close {
    width: 32px;
    height: 32px;
    padding: 0;
    margin: 0;
    border-radius: 6px;
    background-size: 12px;
    opacity: .75;
  }

  .admin-mobile-limit-modal .modal-body {
    padding: 1rem;
  }

  .admin-mobile-limit-modal .modal-lead {
    margin: 0;
    color: #233b47;
    font-size: .9rem;
    font-weight: 800;
    line-height: 1.65;
  }

  .admin-mobile-limit-modal .modal-note {
    margin: .65rem 0 0;
    color: #607783;
    font-size: .82rem;
    line-height: 1.55;
  }

  .admin-mobile-limit-modal .modal-footer {
    justify-content: center;
    padding: .85rem 1rem 1rem;
    border-top: 1px solid #e7edf0;
  }

  .admin-mobile-limit-modal .modal-footer .btn {
    width: 100%;
    min-height: 38px;
    font-size: .86rem;
    font-weight: 800;
  }

  .admin-table-wrap > .basis-table,
  .card-body > .basis-table,
  .result-table-scroll {
    border: 0 !important;
    background: transparent !important;
  }

  .admin-table-wrap > .basis-table--mobile-cards {
    width: 100%;
    min-width: 0 !important;
  }

  .basis-table--mobile-cards > .basis-table__thead {
    display: none !important;
  }

  .basis-table--mobile-cards > .basis-table__tbody {
    display: flex;
    flex-direction: column;
    gap: .7rem;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 !important;
    border: 0;
    background: transparent;
  }

  .basis-table--mobile-cards > .basis-table__tbody > .basis-table__row {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 0;
    border: 1px solid #dce5ea;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    box-shadow: none;
  }

  .basis-table--mobile-cards > .basis-table__tbody > .basis-table__row:hover {
    background: #fff;
  }

  .basis-table--mobile-cards .basis-table__cell--td {
    display: flex;
    flex: 0 0 auto !important;
    flex-direction: row !important;
    align-items: flex-start;
    justify-content: flex-start;
    gap: .65rem;
    width: 100%;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0;
    padding: .58rem .68rem !important;
    border: 0 !important;
    border-bottom: 1px solid #e7edf0 !important;
    background: #fff;
    color: #263d48;
    font-size: .82rem;
    line-height: 1.45;
    text-align: left !important;
    overflow-wrap: anywhere;
    box-sizing: border-box;
  }

  .basis-table--mobile-cards .basis-table__cell--td::before {
    content: attr(data-label);
    flex: 0 0 5.4rem;
    max-width: 5.4rem;
    color: #617783;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1.45;
    white-space: nowrap;
  }

  .basis-table--mobile-cards .basis-table__cell--td:last-child {
    border-bottom: 0 !important;
  }

  .basis-table--mobile-cards .basis-table__cell--td > * {
    min-width: 0;
  }

  .basis-table--mobile-cards .basis-table__control-wrap {
    display: none !important;
  }

  .basis-table--mobile-cards .control-tablet {
    display: block !important;
    width: 100%;
    padding: .55rem .68rem;
    border-top: 0;
    background: #f7fafb;
  }

  .basis-table--mobile-cards .control-tablet__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .4rem;
    width: 100%;
  }

  .basis-table--mobile-cards .control-tablet__item {
    flex: 0 0 auto;
  }

  .basis-table--mobile-cards .control-tablet__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: .38rem .65rem;
    border: 1px solid #d1dde3;
    border-radius: 6px;
    background: #fff;
    color: #315a68;
    font-size: .78rem;
    font-weight: 800;
    line-height: 1.25;
    text-decoration: none;
  }

  .basis-table--mobile-cards .control-tablet__link:hover,
  .basis-table--mobile-cards .control-tablet__link:focus {
    border-color: #9fb8c2;
    background: #eaf3f6;
    color: #244f61;
    text-decoration: none;
  }

  .basis-table--mobile-cards .basis-table__row--empty {
    border-style: dashed;
  }

  .basis-table--mobile-cards .basis-table__row--empty .basis-table__cell--td {
    justify-content: center;
    border-bottom: 0 !important;
    text-align: center !important;
  }

  .basis-table--mobile-cards .basis-table__row--empty .basis-table__cell--td::before {
    content: none;
  }

  .admin-tabs,
  .competition-cell-tabs,
  .setting-detail-tabs,
  .preliminary-result-tabs {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center;
    justify-content: flex-start;
    gap: .35rem;
    width: 100%;
    padding: .35rem;
    overflow: visible;
  }

  .admin-tab,
  .tab_change,
  .menu_tab,
  .preliminary-result-tab {
    flex: 1 1 calc(50% - .35rem);
    width: auto !important;
    min-width: 0 !important;
    max-width: 100%;
    min-height: 34px;
    padding: .38rem .55rem !important;
    font-size: .76rem;
    line-height: 1.25;
    white-space: normal;
  }

  .admin-tab::before,
  .tab_change::before,
  .menu_tab::before {
    height: .95em;
  }

  .information-index-page,
  .information-type-page,
  .asc-info-page,
  .asc-info-detail-page,
  .asc-notice-page,
  .contact-index-page,
  .application-request-page,
  .recruit-index-page,
  .place-index-page,
  .link-index-page,
  .mail-index-page,
  .mail-auto-page,
  .mail-template-page,
  .history-log-page {
    padding-bottom: 5rem;
  }

  .information-index-page .information-table-wrap,
  .information-type-page .information-type-table-wrap,
  .asc-info-page .admin-table-wrap,
  .asc-notice-page .admin-table-wrap,
  .contact-index-page .admin-table-wrap,
  .application-request-page .admin-table-wrap,
  .recruit-index-page .admin-table-wrap,
  .place-index-page .admin-table-wrap,
  .link-index-page .admin-table-wrap,
  .mail-index-page .admin-table-wrap,
  .mail-auto-page .admin-table-wrap,
  .mail-template-page .admin-table-wrap,
  .history-log-page .admin-table-wrap {
    overflow: visible;
  }

  .staff-index-page {
    padding-bottom: 5rem;
  }

  .staff-index-page .admin-table-wrap {
    overflow: visible;
  }

  .staff-index-page .staff-table-wrap .basis-table {
    width: 100%;
  }

  .staff-index-page .staff-table__image .profile__img {
    width: 42px;
    height: 42px;
  }

  .staff-index-page .staff-table__image .profile_img {
    width: 42px;
    height: 42px;
    object-fit: cover;
  }

  .staff-index-page .staff-action--edit,
  .staff-index-page .staff-action--delete,
  .staff-index-page ~ .control-footer .staff-action--regist {
    display: none !important;
  }

  .staff-index-page ~ .control-footer .inner {
    justify-content: center;
    gap: .45rem;
    padding-right: 12px;
    padding-left: 12px;
  }

  .information-index-page .information-subject-link {
    display: block;
    font-size: .86rem;
    line-height: 1.55;
  }

  .information-index-page .information-type-badge,
  .information-index-page .information-status-badge,
  .information-index-page .information-file-badge {
    min-height: 22px;
    font-size: .72rem;
  }

  .information-muted {
    color: #7a8b93;
    font-size: .78rem;
    font-weight: 700;
  }

  .information-index-page .right-sidebar {
    margin-top: .85rem;
  }

  .information-index-page .select_text {
    width: 100%;
    max-width: 100%;
  }

  .information-index-page .information-action--edit,
  .information-index-page ~ .control-footer .information-action--regist {
    display: none !important;
  }

  .information-type-page .information-type-action--edit,
  .information-type-page ~ .control-footer .information-type-action--regist {
    display: none !important;
  }

  .information-index-page ~ .control-footer .inner,
  .information-type-page ~ .control-footer .inner,
  .recruit-index-page ~ .control-footer .inner,
  .place-index-page ~ .control-footer .inner,
  .link-index-page ~ .control-footer .inner,
  .mail-index-page ~ .control-footer .inner,
  .mail-auto-page ~ .control-footer .inner,
  .mail-template-page ~ .control-footer .inner {
    justify-content: center;
    gap: .45rem;
    padding-right: 12px;
    padding-left: 12px;
  }

  .information-index-page ~ .control-footer .btn,
  .information-type-page ~ .control-footer .btn,
  .recruit-index-page ~ .control-footer .btn,
  .place-index-page ~ .control-footer .btn,
  .link-index-page ~ .control-footer .btn,
  .mail-index-page ~ .control-footer .btn,
  .mail-auto-page ~ .control-footer .btn,
  .mail-template-page ~ .control-footer .btn {
    flex: 1 1 0;
    min-width: 0;
    max-width: 100%;
    padding-right: .5rem;
    padding-left: .5rem;
    font-size: .78rem;
    white-space: normal;
  }

  .application-request-page .admin-tabs {
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    margin-bottom: .7rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .application-request-page .admin-tabs .admin-tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    white-space: nowrap !important;
  }

  .application-request-page .app-request-action--delete {
    display: none !important;
  }

  .application-request-page ~ .control-footer .app-request-action--online-form-setting {
    display: none !important;
  }

  .application-request-page .admin-empty-state,
  .mail-index-page .admin-empty-state,
  .history-log-page .admin-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    width: 100%;
    min-height: 88px;
    padding: 1rem;
    border: 1px dashed #c9d6de;
    border-radius: 8px;
    background: #f8fbfc;
    color: #60717b;
    font-size: .88rem;
    font-weight: 700;
    text-align: center;
  }

  .application-request-page .admin-empty-state i,
  .mail-index-page .admin-empty-state i,
  .history-log-page .admin-empty-state i {
    color: #8ca0aa;
    font-size: 1.15rem;
  }

  .application-index-page .application-tabs {
    display: flex !important;
    flex-wrap: nowrap !important;
    width: 100%;
    max-width: 100%;
    margin-bottom: .7rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .application-index-page .application-tabs .admin-tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    white-space: nowrap !important;
  }

  .application-index-page .application-action--online-form,
  .application-index-page .application-action--edit,
  .application-index-page .application-action--finish,
  .application-index-page .application-action--delete,
  .application-index-page ~ .application-control-footer .application-action--regist {
    display: none !important;
  }

  .asc-info-page .admin-tabs {
    flex-wrap: nowrap !important;
  }

  .asc-info-page .admin-tabs .admin-tab {
    flex: 1 1 0 !important;
    white-space: nowrap;
  }

  .setting-account-page .setting-detail-tabs {
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    width: 100%;
    margin-bottom: .7rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .setting-account-page .setting-detail-tabs .admin-tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    white-space: nowrap !important;
  }

  .setting-account-page .account-action--payment-setting,
  .setting-account-page .account-action--delete {
    display: none !important;
  }

  .dashboard-news .info_type_tab {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .dashboard-news .info_type_tab::-webkit-scrollbar {
    display: none;
  }

  .dashboard-news .info_type_tab .admin-tab {
    flex: 0 0 auto !important;
    min-width: 0 !important;
    padding-right: .5rem !important;
    padding-left: .5rem !important;
    font-size: .72rem;
    white-space: nowrap;
  }

  .competition-detail-page .detail-info-table,
  .competition-detail-page .detail-info-table tbody,
  .competition-detail-page .detail-info-table tr,
  .competition-detail-page .detail-info-table th,
  .competition-detail-page .detail-info-table td {
    display: block;
    width: 100%;
  }

  .competition-detail-page .detail-info-table {
    table-layout: auto;
    min-width: 0 !important;
    border-collapse: separate;
    border-spacing: 0;
  }

  .competition-detail-page .detail-info-table tr {
    border-bottom: 1px solid #dce5ea;
  }

  .competition-detail-page .detail-info-table tr:last-child {
    border-bottom: 0;
  }

  .competition-detail-page .detail-info-table th,
  .competition-detail-page .detail-info-table td {
    min-width: 0;
    border: 0 !important;
    text-align: left !important;
  }

  .competition-detail-page .detail-info-table th {
    padding: .55rem .7rem .45rem !important;
    background: #f3f7f8;
    color: #365568;
    font-size: .76rem;
    font-weight: 800;
  }

  .competition-detail-page .detail-info-table td {
    padding: .58rem .7rem .7rem !important;
    background: #fff;
    color: #2f3f49;
    font-size: .84rem;
    line-height: 1.5;
  }

  .competition-detail-footer .inner {
    justify-content: flex-end;
    gap: .4rem;
    padding-right: 12px;
    padding-left: 12px;
  }

  .competition-detail-footer .control-footer__item {
    flex: 0 0 auto;
  }

  .competition-detail-footer .competition-detail-footer__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    min-width: 42px;
    padding: 0 !important;
    border-radius: 6px !important;
    font-size: .95rem;
    line-height: 1;
  }

  .competition-detail-footer .competition-detail-footer__btn i {
    margin: 0 !important;
  }

  .competition-detail-footer .competition-detail-footer__btn span {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
  }

  .competition-detail-footer .competition-detail-action--games,
  .competition-detail-footer .competition-detail-action--edit {
    display: none !important;
  }

  .competition-result-page .result-table-panel > .card-body,
  .competition-result-page .result-tournament-panel > .card-body,
  .competition-result-page .dashboard-panel > .card-body {
    min-width: 0;
    overflow: hidden;
  }

  .competition-result-page .result-table-board {
    width: 100%;
    min-width: 0;
    overflow: hidden;
  }

  .competition-result-page .result-table-scroll,
  .competition-result-page .result-table-board .table_wrapp,
  .competition-result-page #tournament_area,
  .competition-result-page .result-tournament-area {
    display: block;
    width: 100% !important;
    max-width: 100%;
    min-width: 0;
    margin-right: 0 !important;
    margin-left: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .competition-result-page #tournament_area,
  .competition-result-page .result-tournament-area {
    height: auto !important;
    padding: .65rem;
    border: 1px solid #dce5ea !important;
    border-radius: 8px;
    background: #fff;
  }

  .competition-result-page .result-table-scroll > table,
  .competition-result-page .result-table-board .table_wrapp > table,
  .competition-result-page .ranking_table,
  .competition-result-page .reague_table,
  .competition-result-page .standing_table {
    width: max-content;
    min-width: 640px;
    max-width: none;
  }

  .competition-result-page #tournament_area svg,
  .competition-result-page .result-tournament-area svg {
    display: block;
    min-width: 640px;
    max-width: none;
  }

  .competition-index-page .competition-filter {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: .55rem;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: .75rem;
    overflow: visible;
  }

  .competition-index-page .competition-filter__tabs {
    display: inline-flex !important;
    flex: 0 0 auto;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center;
    justify-content: flex-start;
    width: auto !important;
    max-width: 100%;
    gap: .32rem;
    padding: .25rem;
  }

  .competition-index-page .competition-filter__tabs .admin-tab,
  .competition-index-page .competition-filter__tabs .menu_tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100%;
    padding: .34rem .58rem !important;
    white-space: nowrap;
  }

  .competition-index-page .competition-filter__controls {
    display: flex;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
  }

  .competition-index-page .competition-filter-control {
    display: none;
    width: 100%;
    min-width: 0;
  }

  .competition-index-page .competition-filter-control.active {
    display: flex;
    align-items: center;
    gap: .45rem;
    width: 100%;
    min-width: 0;
  }

  .competition-index-page .competition-filter-label {
    flex: 0 0 auto;
    margin: 0;
    font-size: .78rem;
    font-weight: 800;
    white-space: nowrap;
  }

  .competition-index-page .competition-filter .form-select-wrap {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    max-width: 100%;
  }

  .competition-index-page .competition-filter .form-select {
    width: 100%;
    min-width: 0;
  }

  .competition-index-page .competition-card-action--guide-create,
  .competition-index-page .competition-card-action--games,
  .competition-index-page .competition-card-action--edit,
  .competition-index-page .competition-card-action--delete {
    display: none !important;
  }

  .competition-index-page ~ .competition-index-control .regist_competition {
    display: none !important;
  }

  .competition-entry-page ~ .control-footer .regist_conf,
  .competition-entry-page ~ .control-footer .btn-disabled {
    display: none !important;
  }

  .competition-result-page ~ .control-footer .finish_conf {
    display: none !important;
  }

  .application-request-page .app-request-payment {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    min-width: 0;
  }

  .application-request-page .app-request-mobile-control {
    display: block !important;
  }

  .application-request-page .app-request-control {
    display: none !important;
  }

  .application-request-page .right-sidebar {
    margin-top: .85rem;
  }

  .recruit-index-page .right-sidebar,
  .place-index-page .right-sidebar,
  .link-index-page .right-sidebar {
    margin-top: .85rem;
  }

  .recruit-index-page .admin-tabs {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    width: 100%;
    max-width: 100%;
    margin-bottom: .7rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .recruit-index-page .admin-tabs .admin-tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    white-space: nowrap !important;
  }

  .recruit-index-page .recruit-action--edit,
  .recruit-index-page .recruit-action--delete,
  .recruit-index-page ~ .recruit-control-footer .recruit-action--regist {
    display: none !important;
  }

  .place-index-page .place-action--edit,
  .place-index-page .place-action--delete,
  .place-index-page ~ .place-control-footer .place-action--regist {
    display: none !important;
  }

  .link-index-page .link-action--edit,
  .link-index-page .link-action--delete,
  .link-index-page ~ .link-control-footer .link-action--regist {
    display: none !important;
  }

  .mail-index-page .admin-tabs {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    width: 100%;
    max-width: 100%;
    margin-bottom: .7rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .mail-index-page .admin-tabs .admin-tab {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    white-space: nowrap !important;
  }

  .mail-index-page .mail-action--regist,
  .mail-index-page .mail-action--edit,
  .mail-index-page .mail-action--delete,
  .mail-index-page ~ .control-footer .mail-action--regist {
    display: none !important;
  }

  .mail-index-page .mail-status-note {
    display: block;
    margin-top: .15rem;
    font-size: .72rem;
    line-height: 1.4;
  }

  .heading > .container-fluid > .row > .mail-auto-heading-text {
    display: none !important;
  }

  .heading > .container-fluid > .row > [class*="col-"].mail-auto-heading-text:last-child {
    display: none !important;
  }

  .mail-auto-page .toggle-switch {
    flex: 0 0 auto;
  }

  .mail-auto-page .mail-auto-action--setting,
  .mail-auto-page .mail-auto-action--edit,
  .mail-auto-page .mail-auto-action--delete,
  .mail-auto-page ~ .control-footer .mail-auto-action--regist {
    display: none !important;
  }

  .mail-template-page .mail-template-action--edit,
  .mail-template-page .mail-template-action--delete,
  .mail-template-page ~ .control-footer .mail-template-action--regist {
    display: none !important;
  }

  body.page-competition-result_regist .result-regist-page.container-fluid {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding-right: 12px;
    padding-left: 12px;
  }

  body.page-competition-result_regist .result-regist-page #edit_form > .row {
    --bs-gutter-x: 0;
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-left: 0;
  }

  body.page-competition-result_regist .result-regist-page #edit_form > .row > .col-12,
  body.page-competition-result_regist .result-regist-panel,
  body.page-competition-result_regist .game_container,
  body.page-competition-result_regist .game_container > .inner {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    box-sizing: border-box;
  }

  body.page-competition-result_regist .result-regist-page .game_container {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }

  body.page-competition-result_regist .result-regist-page .game_container > .inner {
    padding: .85rem !important;
  }

  body.page-competition-result_regist .result-regist-winner {
    justify-content: flex-start;
    margin-bottom: .7rem;
    padding: .55rem !important;
  }

  body.page-competition-result_regist .result-regist-winner > .result-regist-winner__field {
    flex: 1 1 auto !important;
    flex-basis: auto !important;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    gap: .45rem;
    justify-content: flex-start;
  }

  body.page-competition-result_regist .result-regist-winner .result-regist-select-field {
    flex: 1 1 0 !important;
    flex-basis: 0 !important;
    min-width: 0;
  }

  body.page-competition-result_regist .result-regist-winner .form-select {
    width: 100% !important;
    min-width: 0 !important;
  }

  .mail-auto-page .mail-auto-error-label {
    min-height: 24px;
    font-size: .72rem;
  }

  .history-log-page {
    padding-top: 0;
  }

  #subHeader .form-select-wrap {
    flex: 1 1 0;
    min-width: 0;
    margin-right: .35rem !important;
  }

  #subHeader .form-select-wrap .form-select {
    width: 100%;
    min-width: 0;
  }

  #subHeader .month_change {
    flex: 0 0 auto;
    min-height: 34px;
    padding: .35rem .65rem;
    font-size: .78rem;
  }

  .control-tablet__link--disabled {
    border-color: #d8e0e4 !important;
    background: #eef2f4 !important;
    color: #8a9aa3 !important;
    pointer-events: none;
  }

  .place-index-page .place-admin-thumb {
    width: 72px;
    height: 54px;
  }

  .place-index-page .place-admin-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .link-index-page .basis-table__cell--sort {
    display: none !important;
  }

  #user_list_modal .basis-table--assign {
    min-width: 0 !important;
  }

  #user_list_modal .basis-table--assign .app-assign-list__action .control-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: .38rem .65rem;
    border: 1px solid #d1dde3;
    border-radius: 6px;
    background: #fff;
    color: #315a68;
    font-size: .78rem;
    font-weight: 800;
    line-height: 1.25;
    text-decoration: none;
  }

  .share-url-modal .modal-dialog {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    margin-right: 12px !important;
    margin-left: 12px !important;
  }

  .share-url-modal .modal-content {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .share-url-modal .modal-header {
    justify-content: flex-start;
    min-height: 44px;
    padding: .72rem 2.7rem .72rem .85rem;
  }

  .share-url-modal .modal-header .modal-title {
    max-width: 100%;
    font-size: .92rem;
    line-height: 1.35;
  }

  .share-url-modal .modal-body {
    padding: .75rem;
    overflow-x: hidden;
  }

  .share-url-modal__grid {
    flex-direction: column !important;
    gap: .65rem;
    width: 100%;
    min-width: 0;
  }

  .share-url-modal__grid + .share-url-modal__grid {
    margin-top: .75rem;
    padding-top: .75rem;
  }

  .share-url-modal__item {
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    border-radius: 7px;
  }

  .share-url-modal__item-header {
    min-height: 36px;
    padding: .55rem .65rem;
    font-size: .82rem;
  }

  .share-url-modal__item-body {
    gap: .45rem;
    padding: .65rem;
  }

  .share-url-modal .select_text {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    font-size: .78rem;
  }

  .share-url-modal__qr {
    min-height: 108px;
    max-width: 100%;
    padding: .55rem;
    overflow: hidden;
  }

  .share-url-modal__qr img,
  .share-url-modal__qr canvas,
  .share-url-modal__qr svg {
    display: block;
    max-width: 96px !important;
    max-height: 96px !important;
    width: auto !important;
    height: auto !important;
  }

  .share-url-modal .modal-footer {
    padding: .65rem .75rem;
  }

  .share-url-modal .modal-footer .btn {
    width: 100%;
    min-width: 0;
  }

  .schedule-info-modal .modal-body {
    padding: .75rem;
  }

  .schedule-info-modal .modal-lead {
    padding: .65rem .7rem;
    font-size: .82rem;
    line-height: 1.55;
  }

  .schedule-info-modal__table,
  .schedule-info-modal__table tbody,
  .schedule-info-modal__table tr,
  .schedule-info-modal__table th,
  .schedule-info-modal__table td {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .schedule-info-modal__table tr {
    border-bottom: 1px solid #dce5ea;
  }

  .schedule-info-modal__table tr:last-child {
    border-bottom: 0;
  }

  .schedule-info-modal__table th {
    padding: .48rem .65rem !important;
    border-right: 0 !important;
    border-bottom: 1px solid #dce5ea !important;
    background: #f3f7f8;
    font-size: .74rem;
    line-height: 1.35;
    text-align: left;
  }

  .schedule-info-modal__table td {
    padding: .65rem .7rem !important;
    border-bottom: 0 !important;
    background: #fff;
  }

  .schedule-info-modal__table .sub_text,
  .schedule-info-modal__table .caution {
    margin-bottom: .4rem;
    font-size: .76rem;
    line-height: 1.5;
  }

  .schedule-info-modal__table textarea.form-control {
    min-height: 88px;
    font-size: .84rem;
  }

  .schedule-info-modal .modal-footer {
    flex-wrap: nowrap;
    gap: .45rem;
  }

  .schedule-info-modal .modal-footer .btn {
    flex: 1 1 0;
    min-width: 0;
    padding-right: .5rem;
    padding-left: .5rem;
    font-size: .8rem;
  }

  .schedule-place-card .schedule-table,
  .schedule-place-card .card--comp table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0;
    border: 1px solid #dce5ea;
    border-bottom: 0;
    border-radius: 7px;
    overflow: hidden !important;
    table-layout: fixed;
  }

  .schedule-place-card .card-body,
  .schedule-place-card .place_card,
  .schedule-place-card .sch_table_wrapp,
  .schedule-place-card .wrap,
  .schedule-place-card .game_row,
  .schedule-place-card .card--comp,
  .schedule-place-card .card--comp > .card-body {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    box-sizing: border-box;
  }

  .schedule-place-card .wrap {
    margin-bottom: .65rem !important;
  }

  .schedule-place-card .game_row {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }

  .schedule-place-card .card--comp {
    flex: 0 0 100% !important;
  }

  .schedule-place-card .schedule-table thead,
  .schedule-place-card .card--comp table thead {
    display: none !important;
  }

  .schedule-place-card .schedule-table tbody,
  .schedule-place-card .schedule-table tr,
  .schedule-place-card .schedule-table td,
  .schedule-place-card .card--comp table tbody,
  .schedule-place-card .card--comp table tr,
  .schedule-place-card .card--comp table td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .schedule-place-card .schedule-table tr,
  .schedule-place-card .card--comp table tr {
    border-bottom: 1px solid #dce5ea;
  }

  .schedule-place-card .schedule-table td,
  .schedule-place-card .card--comp table td {
    position: relative;
    min-height: 0;
    padding: 0 !important;
    border: 0 !important;
    text-align: left;
    overflow: hidden;
    overflow-wrap: anywhere;
  }

  .schedule-place-card .schedule-table td::before,
  .schedule-place-card .card--comp table td::before {
    display: block;
    padding: .42rem .55rem;
    border-bottom: 1px solid #dce5ea;
    background: #f4f8fa;
    color: #526a76;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1.35;
  }

  .schedule-place-card .schedule-table td > *,
  .schedule-place-card .card--comp table td > * {
    margin: .52rem .6rem;
    max-width: calc(100% - 1.2rem);
  }

  .schedule-place-card .result_list,
  .schedule-place-card .record_list,
  .schedule-place-card .schedule-record-result {
    width: auto !important;
    max-width: calc(100% - 1.2rem) !important;
    min-width: 0 !important;
    overflow: hidden;
  }

  .schedule-place-card .result_list .team,
  .schedule-place-card .schedule-record-result__name {
    min-width: 0 !important;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .schedule-place-card .result_list .list_center {
    flex: 0 0 auto;
    min-width: 2.8rem !important;
  }

  .schedule-place-card .schedule-table td:nth-child(1)::before,
  .schedule-place-card .card--comp table td:nth-child(1)::before {
    content: "日程ID";
  }

  .schedule-place-card .schedule-table td:nth-child(2)::before,
  .schedule-place-card .card--comp table td:nth-child(2)::before {
    content: "クラス";
  }

  .schedule-place-card .schedule-table td:nth-child(3)::before,
  .schedule-place-card .card--comp table td:nth-child(3)::before {
    content: "大会名";
  }

  .schedule-place-card .schedule-table td:nth-child(4)::before,
  .schedule-place-card .card--comp table td:nth-child(4)::before {
    content: "結果";
  }

  .schedule-place-card .schedule-table td:nth-child(5)::before,
  .schedule-place-card .card--comp table td:nth-child(5)::before {
    content: "備考";
  }

  #game_add_modal .confirm-table,
  #game_edit_modal .confirm-table {
    display: block;
    width: 100%;
    min-width: 0 !important;
    border: 1px solid #dce5ea;
    border-bottom: 0;
    border-radius: 7px;
    overflow: hidden;
  }

  #game_add_modal .confirm-table tbody,
  #game_add_modal .confirm-table tr,
  #game_add_modal .confirm-table th,
  #game_add_modal .confirm-table td,
  #game_edit_modal .confirm-table tbody,
  #game_edit_modal .confirm-table tr,
  #game_edit_modal .confirm-table th,
  #game_edit_modal .confirm-table td {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #game_add_modal .confirm-table tr,
  #game_edit_modal .confirm-table tr {
    border-bottom: 1px solid #dce5ea;
  }

  #game_add_modal .confirm-table th,
  #game_edit_modal .confirm-table th {
    padding: .45rem .6rem !important;
    border: 0 !important;
    border-bottom: 1px solid #dce5ea !important;
    background: #f4f8fa;
    color: #526a76;
    font-size: .74rem;
    font-weight: 800;
    line-height: 1.35;
    text-align: left;
  }

  #game_add_modal .confirm-table td,
  #game_edit_modal .confirm-table td {
    padding: .58rem .65rem !important;
    border: 0 !important;
    background: #fff;
    text-align: left;
  }

  #game_add_modal .confirm-table td.d-flex,
  #game_edit_modal .confirm-table td.d-flex {
    display: flex !important;
    flex-wrap: wrap;
    gap: .55rem;
  }

  #game_add_modal .confirm-table .form-date,
  #game_add_modal .confirm-table .form-select-wrap,
  #game_add_modal .confirm-table .form-control,
  #game_add_modal .confirm-table textarea,
  #game_edit_modal .confirm-table .form-date,
  #game_edit_modal .confirm-table .form-select-wrap,
  #game_edit_modal .confirm-table .form-control,
  #game_edit_modal .confirm-table textarea {
    max-width: 100% !important;
  }

  .schedule-place-card .schedule-table,
  .schedule-place-card .card--comp table {
    display: table !important;
    width: 100% !important;
    min-width: 0 !important;
    table-layout: fixed;
    border-collapse: separate;
    border-spacing: 0;
  }

  .schedule-place-card .schedule-table thead,
  .schedule-place-card .card--comp table thead {
    display: table-header-group !important;
  }

  .schedule-place-card .schedule-table tbody,
  .schedule-place-card .card--comp table tbody {
    display: table-row-group !important;
  }

  .schedule-place-card .schedule-table tr,
  .schedule-place-card .card--comp table tr {
    display: table-row !important;
  }

  .schedule-place-card .schedule-table th,
  .schedule-place-card .schedule-table td,
  .schedule-place-card .card--comp table th,
  .schedule-place-card .card--comp table td {
    display: table-cell !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: .42rem .35rem !important;
    border-right: 0 !important;
    border-bottom: 1px solid #e7edf0 !important;
    font-size: .68rem;
    line-height: 1.35;
    vertical-align: middle;
    overflow-wrap: anywhere;
  }

  .schedule-place-card .schedule-table th,
  .schedule-place-card .card--comp table th {
    background: #f4f8fa;
    color: #526a76;
    font-size: .64rem;
    font-weight: 800;
    white-space: normal;
  }

  .schedule-place-card .schedule-table td::before,
  .schedule-place-card .card--comp table td::before {
    display: none !important;
    content: none !important;
  }

  .schedule-place-card .schedule-table td > *,
  .schedule-place-card .card--comp table td > * {
    max-width: 100% !important;
    margin: 0 !important;
  }

  .schedule-place-card .result_list {
    display: flex;
    align-items: center;
    gap: .15rem;
  }

  .schedule-place-card .result_list .team {
    flex: 1 1 0;
    font-size: .66rem;
  }

  .schedule-place-card .result_list .list_center {
    flex: 0 0 auto;
    min-width: 2.2rem !important;
    padding: .1rem .18rem;
    font-size: .68rem;
  }

  .admin-mobile-error {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 16px;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(244, 247, 249, .96)),
      radial-gradient(circle at 50% 0%, rgba(31, 111, 136, .16), transparent 48%);
  }

  .admin-mobile-error .error__container {
    width: 100%;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
    padding: 28px 20px 24px;
    border: 1px solid #dce5ea;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 14px 38px rgba(32, 55, 68, .12);
  }

  .admin-mobile-error .error__img {
    width: min(180px, 58vw);
    height: auto;
    margin: 0;
  }

  .admin-mobile-error .error__txt {
    width: 100%;
  }

  .admin-mobile-error .error__mg {
    margin: 0 0 12px;
    color: #203744;
    font-size: 1.25rem;
    font-weight: 800;
    line-height: 1.45;
    letter-spacing: 0;
  }

  .admin-mobile-error .error__desc {
    display: flex;
    justify-content: center;
    gap: .4rem;
    margin: 0 0 10px;
    color: #526a76;
    font-size: .92rem;
    font-weight: 500;
    line-height: 1.7;
    text-align: left;
  }

  .admin-mobile-error .error__desc + .error__desc {
    display: block;
    color: #6d8490;
    font-size: .84rem;
    text-align: center;
  }

  .admin-mobile-error .error__icon {
    flex: 0 0 auto;
    margin-top: .28em;
    color: #d48a2f;
  }

  .admin-mobile-error .error__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    min-height: 42px;
    margin-top: 12px;
    padding: .55rem 1rem;
    border: 1px solid #1f6f88;
    border-radius: 7px !important;
    background: #1f6f88;
    color: #fff;
    font-size: .9rem;
    font-weight: 800;
    line-height: 1.2;
    text-decoration: none;
  }

  .admin-mobile-error .error__btn:hover,
  .admin-mobile-error .error__btn:focus {
    background: #174f63;
    border-color: #174f63;
    color: #fff;
    text-decoration: none;
  }
}
