/* public_html/portal/assets/css/app.css */

:root {
    --km-text-main: #2f3437;
    --km-text-muted: #64748b;
    --km-brand-portal: #0f2f5f;
    --km-brand-navi: #145a3a;
    --km-brand-current: #212529;
    --pta2-border: rgba(15, 23, 42, 0.12);
    --pta2-border-strong: rgba(15, 23, 42, 0.18);
    --pta2-surface: #ffffff;
    --pta2-surface-soft: #f8fafc;
    --pta2-text: #111827;
    --pta2-muted: #64748b;
    --pta2-accent: #ffedd5;
    --pta2-accent-strong: #fb923c;
    --pta2-timed: #dbeafe;
    --pta2-timed-strong: #60a5fa;
    --pta2-left-rail-width: 3.5rem;
    --pta2-a-height: 6.5rem;
    --pta2-a-pad-inline: 0.25rem;
    --pta2-a-pad-block: 0.25rem;
    --pta2-a-gap: 0.125rem;
    --pta2-a-bar-height: 0.875rem;
    --pta2-b-gap: 0.375rem;
    --pta2-b-pad-inline: 0.25rem;
    --pta2-hour-height: 3rem;
    --pta2-radius: 0.25rem;
    --pta2-bar-radius: var(--pta2-radius);
    --pta2-grid-stroke: rgba(15, 23, 42, 0.08);
    --portal-tooltip-bg: var(--bs-body-bg);
    --portal-tooltip-color: var(--bs-body-color);
    --portal-tooltip-border-color: var(--bs-border-color);
    --portal-tooltip-font-size: 0.8125rem;
    --portal-tips-icon-color: var(--bs-secondary-color);
    --portal-tips-icon-hover-color: var(--bs-body-color);
    --portal-detail-field-label-color: var(--bs-secondary-color);
    --portal-detail-field-value-color: var(--bs-body-color);
    --portal-detail-field-divider-color: var(--bs-border-color-translucent);
}


body {
    min-height: 100vh;
    color: var(--km-text-main);
}

body.portal-navi-public {
    --km-brand-current: var(--km-brand-navi);
}

body.portal-navi-public .btn-dark {
    --bs-btn-bg: var(--km-brand-current);
    --bs-btn-border-color: var(--km-brand-current);
    --bs-btn-hover-bg: #0f472e;
    --bs-btn-hover-border-color: #0f472e;
    --bs-btn-active-bg: #0b3824;
    --bs-btn-active-border-color: #0b3824;
    --bs-btn-disabled-bg: var(--km-brand-current);
    --bs-btn-disabled-border-color: var(--km-brand-current);
}

body.portal-navi-public .portal-header .bi {
    color: var(--km-brand-current);
}


/* 2026-05-21 JST / 00678 / Portal Section Switcher Row Package. */
.portal-section-switcher-row {
    display: flex;
    align-items: flex-end;
    gap: 0.5rem;
}

.portal-section-switcher-dropdown-slot {
    flex: 0 0 20%;
    min-inline-size: 0;
}

.portal-section-switcher-tabs-slot {
    display: flex;
    align-items: flex-end;
    gap: 0.375rem;
    flex: 1 1 0;
    min-inline-size: 0;
}

[data-section-switcher-mode="tabs_only_full"] .portal-section-switcher-tabs-slot {
    flex-basis: 100%;
}

.portal-section-switcher-dropdown-btn {
    --bs-btn-bg: var(--km-brand-current);
    --bs-btn-border-color: var(--km-brand-current);
    --bs-btn-color: #fff;
    --bs-btn-hover-bg: var(--km-brand-current);
    --bs-btn-hover-border-color: var(--km-brand-current);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--km-brand-current);
    --bs-btn-active-border-color: var(--km-brand-current);
    --bs-btn-active-color: #fff;
}


/* 2026-05-21 JST / 00681 / Switcher Row補助説明をTooltip化。 */
.portal-section-switcher-dropdown-control-row {
    display: flex;
    align-items: stretch;
    gap: 0.5rem;
    inline-size: 100%;
}

.portal-section-switcher-dropdown-control {
    flex: 1 1 auto;
    min-inline-size: 0;
}

/* 2026-05-21 JST / 00684 / SP用infoアイコンは対象Dropdownの右上付近に添える。 */
.portal-section-switcher-info-btn {
    appearance: none;
    -webkit-appearance: none;
    flex: 0 0 auto;
    align-self: flex-start;
    inline-size: auto;
    block-size: auto;
    min-inline-size: 0;
    min-block-size: 0;
    margin: 0.25rem 0 0 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--portal-tips-icon-color);
    line-height: 1;
    box-shadow: none;
}

.portal-section-switcher-info-btn:hover,
.portal-section-switcher-info-btn:focus,
.portal-section-switcher-info-btn:active {
    border: 0;
    background: transparent;
    color: var(--portal-tips-icon-hover-color);
    box-shadow: none;
}

.portal-section-switcher-info-btn:focus-visible {
    outline: 0.125rem solid currentColor;
    outline-offset: 0.1875rem;
}

.portal-section-switcher-info-btn .bi {
    display: block;
    font-size: 1rem;
    line-height: 1;
}

@media (max-width: 767.98px) {
    .portal-section-switcher-row .portal-section-switcher-dropdown-control {
        flex: 0 1 75%;
    }
}

/* 2026-05-21 JST / 00680 / Keep active dropdown items aligned with the switcher tone. */
.portal-section-switcher-row .dropdown-item.active,
.portal-section-switcher-row .dropdown-item:active {
    color: #fff;
    background-color: var(--km-brand-current);
}

.portal-section-switcher-row .dropdown-item.active .bi,
.portal-section-switcher-row .dropdown-item:active .bi {
    color: inherit;
}

.portal-section-switcher-tab {
    --bs-btn-bg: var(--bs-body-bg);
    --bs-btn-border-color: var(--bs-border-color);
    --bs-btn-color: var(--bs-secondary-color);
    --bs-btn-hover-bg: var(--bs-light-bg-subtle);
    --bs-btn-hover-border-color: var(--bs-border-color);
    --bs-btn-hover-color: var(--bs-body-color);
    --bs-btn-active-bg: var(--km-brand-current);
    --bs-btn-active-border-color: var(--km-brand-current);
    --bs-btn-active-color: #fff;
    flex: 1 1 0;
    min-inline-size: 0;
    padding-block: 0.25rem;
    line-height: 1.2;
}

.portal-section-switcher-tab.active {
    color: var(--bs-btn-active-color);
    background-color: var(--bs-btn-active-bg);
    border-color: var(--bs-btn-active-border-color);
}

.portal-section-switcher-right-text {
    display: flex;
    align-items: center;
    min-block-size: 1.9375rem;
}

@media (max-width: 767.98px) {
    .portal-section-switcher-row {
        flex-direction: column;
        align-items: stretch;
    }

    .portal-section-switcher-dropdown-slot,
    .portal-section-switcher-tabs-slot,
    [data-section-switcher-mode="tabs_only_full"] .portal-section-switcher-tabs-slot {
        flex: 0 0 auto;
        inline-size: 100%;
    }

    [data-section-switcher-dropdown-enabled="0"] {
        display: none;
    }

    .portal-section-switcher-tabs-slot {
        flex-wrap: wrap;
    }

    .portal-section-switcher-tab {
        flex: 0 0 calc(50% - 0.1875rem);
    }
}

body.pta2-overlay-open {
    overflow: hidden;
}

.card {
    overflow: hidden;
}

/* 2026-05-19 JST / 00651 / Allow SSC Console section dropdown to escape the shell card. */
[data-role="ssc-console-section-shell"] {
    overflow: visible;
}

.badge {
    font-weight: 500;
}

/* 2026-05-02 JST / 00348 / Portal Display Chip commonization */
[data-portal-display-chip="1"] {
    display: inline-flex;
    align-items: center;
    min-height: 1.375rem;
    border-radius: var(--bs-border-radius);
    line-height: 1.15;
    vertical-align: baseline;
}

code {
    word-break: break-all;
}

.portal-toast {
    min-width: 18rem;
    max-width: min(32rem, calc(100vw - 2rem));
}

.portal-toast .portal-toast-message {
    white-space: pre-line;
}

.master-key-office-list {
    max-height: 20rem;
    overflow: auto;
}

.portal-header {
    position: sticky;
    top: 0;
    z-index: 1030;
}

.portal-user-name {
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.2;
}

.portal-auth-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    padding: 0.375rem 0.625rem;
    border-radius: 9999px;
    background: #212529;
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.portal-office-crest {
    inline-size: 2.5rem;
    block-size: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: #212529;
    text-decoration: none;
}

.portal-office-crest img {
    inline-size: 2rem;
    block-size: 2rem;
    object-fit: cover;
    object-position: center;
    display: block;
}

.portal-header-icon-btn {
    inline-size: 2.5rem;
    block-size: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: #212529;
    text-decoration: none;
}

.portal-header-icon-btn:hover,
.portal-office-crest:hover {
    color: #212529;
    opacity: 0.72;
}

.portal-header-icon-btn i {
    font-size: 1.375rem;
    line-height: 1;
}

.portal-time-axis-filter-offcanvas .btn,
.portal-time-axis [data-role="time-axis-nav"] .btn,
.portal-time-axis [data-role="view-switch-group"] .btn {
    border-radius: 9999px;
}


.portal-time-axis-filter-empty {
    color: var(--pta2-muted);
    font-size: 0.875rem;
}

.portal-time-axis-filter-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.portal-time-axis-filter-option {
    display: flex;
    align-items: center;
    gap: 0.875rem;
}

.portal-time-axis-filter-option-text {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.portal-time-axis-filter-option-title {
    font-size: 0.9375rem;
    font-weight: 400;
}

.portal-time-axis-filter-option-sub {
    color: var(--pta2-muted);
    font-size: 0.75rem;
}

.portal-time-axis-filter-switch {
    position: relative;
    display: inline-flex;
    inline-size: 1.75rem;
    block-size: 1rem;
    flex: 0 0 auto;
    overflow: hidden;
}

.portal-time-axis-filter-switch-input {
    opacity: 0;
    inline-size: 0;
    block-size: 0;
}

.portal-time-axis-filter-switch-slider {
    position: absolute;
    inset: 0;
    border-radius: 9999px;
    background: #cbd5e1;
    transition: background-color 0.2s ease;
}

.portal-time-axis-filter-switch-slider::before {
    content: '';
    position: absolute;
    inset-block-start: 0.125rem;
    inset-inline-start: 0.125rem;
    inline-size: 0.75rem;
    block-size: 0.75rem;
    border-radius: 9999px;
    background: #ffffff;
    transition: transform 0.2s ease;
    box-shadow: 0 0.125rem 0.375rem rgba(15, 23, 42, 0.18);
}

.portal-time-axis-filter-switch-input:checked + .portal-time-axis-filter-switch-slider {
    background: #0f172a;
}

.portal-time-axis-filter-switch-input:checked + .portal-time-axis-filter-switch-slider::before {
    transform: translateX(0.75rem);
}

.pta2-root {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.pta2-weekday-row,
.pta2-date-row,
.pta2-a-row,
.pta2-b-row {
    display: grid;
    grid-template-columns: repeat(var(--pta2-cols, 7), minmax(0, 1fr));
    gap: 0;
}

.pta2-date-row {
    overflow: visible;
}

.pta2-weekday-row.has-rail,
.pta2-date-row.has-rail {
    grid-template-columns: var(--pta2-left-rail-width) repeat(var(--pta2-cols, 7), minmax(0, 1fr));
}

.pta2-main,
.pta2-month-week {
    display: grid;
    grid-template-columns: var(--pta2-left-rail-width) minmax(0, 1fr);
    gap: 0;
}

.pta2-main {
    --pta2-a-current-height: var(--pta2-a-height);
}

.pta2-main.is-a-expanded {
    --pta2-a-current-height: max(var(--pta2-a-height), calc((var(--pta2-a-levels, 1) * var(--pta2-a-bar-height)) + ((var(--pta2-a-levels, 1) - 1) * var(--pta2-a-gap)) + (var(--pta2-a-pad-block) * 2)));
}

.pta2-main-body,
.pta2-main-body--month {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.pta2-weekday-cell,
.pta2-date-cell,
.pta2-a-cell,
.pta2-b-cell,
.pta2-week-index {
    background: var(--pta2-surface);
    color: var(--pta2-text);
}

.pta2-weekday-row {
    margin-block-end: 0.25rem;
}

.pta2-weekday-cell {
    text-align: center;
    color: var(--pta2-muted);
    font-size: 0.8125rem;
    font-weight: 700;
    padding-block: 0.125rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pta2-date-row-spacer {
    display: none;
}

.pta2-weekday-row.has-rail .pta2-date-row-spacer,
.pta2-date-row.has-rail .pta2-date-row-spacer {
    display: block;
}

.pta2-date-cell {
    border: 0;
    border-radius: 0;
    padding: 0.375rem 0;
    display: grid;
    grid-template-rows: 1.25rem;
    align-items: center;
    justify-items: center;
    background: transparent;
    text-align: center;
    position: relative;
    overflow: visible;
}

.pta2-date-number {
    font-weight: 700;
    font-size: 0.9375rem;
}

.pta2-left-rail {
    position: relative;
    display: grid;
    grid-template-rows: var(--pta2-a-current-height, var(--pta2-a-height)) var(--pta2-b-gap) auto;
    align-items: stretch;
    min-width: 0;
    --pta2-rail-btn-size: 2rem;
    --pta2-rail-btn-x: -0.5rem;
}

.pta2-left-rail--week {
    display: flex;
    flex-direction: column;
}

.pta2-rail-btn {
    grid-column: 1;
    grid-row: 1;
    justify-self: end;
    align-self: start;
    translate: var(--pta2-rail-btn-x) 0;
    border: 0;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: var(--pta2-rail-btn-size);
    block-size: var(--pta2-rail-btn-size);
    border-radius: 0;
    color: var(--pta2-muted);
    padding: 0;
    margin: 0;
    z-index: 1;
}

.pta2-rail-a-btn {
    align-self: start;
}

.pta2-rail-b-btn {
    align-self: end;
}

.pta2-time-axis {
    grid-row: 3;
    position: relative;
}

.pta2-time-axis[hidden] {
    display: none;
}

.pta2-time-axis-grid {
    position: relative;
    block-size: calc((var(--pta2-hour-count, 24) * var(--pta2-hour-height)) + 0.5rem);
}

.pta2-time-label {
    position: absolute;
    inset-inline-end: 0;
    color: var(--pta2-muted);
    font-size: 0.6875rem;
    transform: translateY(-50%);
    line-height: 1;
    white-space: nowrap;
}

.pta2-a-row {
    position: relative;
    align-items: stretch;
    border: 1px solid var(--pta2-border);
    border-radius: var(--pta2-radius);
    overflow: hidden;
    min-block-size: var(--pta2-a-height);
}

.pta2-a-range-layer {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(var(--pta2-cols, 7), minmax(0, 1fr));
    pointer-events: none;
}

.pta2-a-range-layer .pta2-event-bar,
.pta2-a-range-layer .pta2-month-timed-stack {
    pointer-events: auto;
}


.pta2-a-cell {
    position: relative;
    z-index: 1;
    grid-row: 1;
    min-block-size: var(--pta2-a-height);
    block-size: var(--pta2-a-height);
    border: 0;
    border-inline-start: 1px solid var(--pta2-border);
    border-radius: 0;
    padding: var(--pta2-a-pad-block) var(--pta2-a-pad-inline);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 0.375rem;
    text-align: left;
    overflow: hidden;
}

.pta2-a-row.is-expanded,
.pta2-a-row.is-expanded .pta2-a-cell {
    min-block-size: var(--pta2-a-current-height, max(var(--pta2-a-height), calc((var(--pta2-a-levels, 1) * var(--pta2-a-bar-height)) + ((var(--pta2-a-levels, 1) - 1) * var(--pta2-a-gap)) + (var(--pta2-a-pad-block) * 2))));
    block-size: auto;
}

.pta2-a-stack {
    display: flex;
    flex-direction: column;
    gap: var(--pta2-a-gap);
    min-width: 0;
}

.pta2-more-chip {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    color: var(--pta2-muted);
    font-size: 0.6875rem;
    font-weight: 600;
}

.pta2-more-chip--layer {
    z-index: 30;
    align-self: end;
    justify-self: end;
    margin: 0 var(--pta2-a-pad-inline) var(--pta2-a-pad-block) 0;
    padding-inline: 0.125rem;
    border-radius: var(--pta2-radius);
    background: rgba(255, 255, 255, 0.82);
    line-height: 1.15;
    pointer-events: none;
}

.pta2-main-gap {
    block-size: var(--pta2-b-gap);
    flex: 0 0 auto;
}

.pta2-b-row {
    position: relative;
    min-height: calc(var(--pta2-hour-count, 24) * var(--pta2-hour-height));
    border: 1px solid var(--pta2-grid-stroke);
    border-radius: var(--pta2-radius);
    overflow: hidden;
}

.pta2-b-row.is-collapsed {
    display: none;
}

.pta2-b-cell {
    position: relative;
    min-height: calc(var(--pta2-hour-count, 24) * var(--pta2-hour-height));
    border-inline-start: 1px solid var(--pta2-grid-stroke);
}

.pta2-b-cell:first-child {
    border-inline-start: 0;
}

.pta2-b-cell:last-child {
    border-inline-end: 0;
}

.pta2-b-lines,
.pta2-b-events {
    position: absolute;
    inset: 0;
}

.pta2-b-hour-line {
    position: absolute;
    inset-inline: 0;
    border-top: 1px solid var(--pta2-grid-stroke);
}

.pta2-event-bar {
    border: 0;
    background: var(--pta2-accent);
    color: var(--pta2-text);
    border-radius: var(--pta2-bar-radius);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.25rem;
    padding: 0.125rem 0.375rem;
    min-width: 0;
    overflow: hidden;
    text-align: left;
}

.pta2-event-bar--range {
    block-size: var(--pta2-a-bar-height);
    margin-inline: var(--pta2-a-pad-inline);
    padding-block: 0;
    box-shadow: inset 0 0 0 1px rgba(251, 146, 60, 0.18);
}

.pta2-event-bar--timed {
    position: absolute;
    background: var(--pta2-timed);
    box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.25);
    padding-inline: 0.375rem;
}

.pta2-event-bar.is-continued-before {
    border-start-start-radius: 0.25rem;
    border-end-start-radius: 0.25rem;
}

.pta2-event-bar.is-continued-after {
    border-start-end-radius: 0.25rem;
    border-end-end-radius: 0.25rem;
}

.pta2-event-bar-title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.6875rem;
    font-weight: 700;
}

.pta2-event-chip {
    flex: 0 0 auto;
    color: var(--pta2-muted);
    font-size: 0.625rem;
}

.pta2-month-timed-stack {
    z-index: 6;
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    margin-inline: var(--pta2-a-pad-inline);
    min-width: 0;
    overflow: hidden;
}

.pta2-month-timed-item {
    border: 0;
    background: transparent;
    color: #16a34a;
    display: flex;
    align-items: center;
    gap: 0.125rem;
    min-width: 0;
    padding: 0;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.15;
}

.pta2-month-timed-dot {
    inline-size: 0.5rem;
    block-size: 0.5rem;
    border-radius: 9999px;
    background: currentColor;
    flex: 0 0 auto;
}

.pta2-month-timed-title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pta2-month-timed-time {
    flex: 0 0 auto;
}

.pta2-month-body {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.pta2-week-index {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.125rem;
    border: 0;
    background: transparent;
    color: var(--pta2-muted);
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.1;
    text-align: center;
}

.pta2-week-index span {
    display: block;
}

.pta2-week-index span:last-child {
    font-size: 0.6875rem;
    font-weight: 500;
}

.pta2-day-detail-overlay {
    position: fixed;
    inset: 0;
    z-index: 1085;
}

.pta2-day-detail-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.36);
}

.pta2-day-detail-modal {
    position: absolute;
    inset-inline: min(4vw, 2rem);
    inset-block-start: 10vh;
    margin-inline: auto;
    inline-size: min(40rem, calc(100vw - 2rem));
    max-block-size: 80vh;
    overflow: auto;
    border-radius: 1.25rem;
    background: #ffffff;
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.2);
    padding: 1rem;
}

.pta2-day-detail-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.pta2-day-detail-kicker {
    margin: 0 0 0.125rem;
    color: var(--pta2-muted);
    font-size: 0.75rem;
}

.pta2-day-detail-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.pta2-day-detail-body {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.pta2-day-detail-item {
    border: 1px solid var(--pta2-border);
    background: var(--pta2-surface-soft);
    border-radius: 0.875rem;
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    text-align: left;
}

.pta2-day-detail-item-title {
    font-size: 0.875rem;
    font-weight: 700;
}

.pta2-day-detail-item-meta,
.pta2-day-detail-empty {
    color: var(--pta2-muted);
    font-size: 0.75rem;
}

.pta2-related-apps {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--pta2-border);
}

.pta2-related-apps-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.pta2-related-app-card {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.625rem;
    border: 1px solid var(--pta2-border);
    border-radius: 9999px;
    background: var(--pta2-surface-soft);
    color: var(--pta2-text);
    text-decoration: none;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.15;
}

.pta2-related-app-card:hover {
    color: var(--pta2-text);
    background: #ffffff;
    border-color: var(--pta2-border-strong);
}

@media (max-width: 47.99875rem) {
    .portal-user-name {
        max-width: 8rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .portal-office-crest {
        inline-size: 2.75rem;
        block-size: 2.75rem;
    }

    .portal-office-crest img {
        inline-size: 2.5rem;
        block-size: 2.5rem;
    }

    .pta2-main,
    .pta2-month-week {
        grid-template-columns: 3rem minmax(0, 1fr);
        gap: 0;
    }

    .pta2-weekday-row,
    .pta2-date-row,
    .pta2-a-row,
    .pta2-b-row {
        gap: 0;
    }

    .pta2-weekday-cell {
        font-size: 0.75rem;
    }

    .pta2-date-cell {
        padding: 0.375rem 0.5rem;
    }

    .pta2-date-number {
        font-size: 0.875rem;
    }

    .pta2-time-label {
        font-size: 0.625rem;
    }
}

.pta2-a-row > .pta2-a-cell:first-child {
    border-inline-start: 0;
}


/* 2026-04-25 JST Time Axis: filter summary chips */
.portal-time-axis-filter-summary {
    font-size: 0.75rem;
}

.portal-time-axis-filter-summary-line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.25rem;
}

.portal-time-axis-filter-chip {
    display: inline-flex;
    align-items: center;
    max-inline-size: 14rem;
    padding: 0.125rem 0.5rem;
    border: 1px solid var(--pta2-border);
    border-radius: 9999px;
    background: var(--pta2-surface-soft);
    color: var(--pta2-text);
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}


.portal-time-axis-filter-chip.is-muted {
    color: var(--pta2-muted);
    background: var(--pta2-surface-soft);
}

.portal-time-axis-filter-trigger {
    border: 0;
    background: transparent;
    inline-size: auto;
    block-size: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0;
    padding: 0.125rem;
}

.portal-time-axis .portal-time-axis-filter-trigger:hover {
    background: transparent;
}


/* 2026-04-25 JST Time Axis: B-area timed event readability / Google Calendar-like overlap */
.pta2-event-bar--timed {
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.125rem;
    padding: 0.1875rem 0.25rem;
    line-height: 1.2;
}

.pta2-event-bar--timed .pta2-event-bar-title {
    white-space: normal;
    line-height: 1.2;
    font-size: 0.6875rem;
}

.pta2-event-bar--timed .pta2-event-chip {
    display: none;
}

/* 2026-04-25 JST Time Axis: B-area Google Calendar-like cascade overlap */
:root {
    --pta2-b-overlap-step: 0.875rem;
}

.pta2-event-bar--timed.is-overlap {
    box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.32), -0.125rem 0 0 rgba(255, 255, 255, 0.86);
}

.pta2-event-bar--timed.is-overlap .pta2-event-bar-title {
    font-size: 0.625rem;
    white-space: nowrap;
}

.pta2-more-chip--b {
    position: absolute;
    padding: 0.125rem 0.25rem;
    border-radius: var(--pta2-radius);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.28);
    pointer-events: none;
}

@media (max-width: 36rem) {
    :root {
        --pta2-b-overlap-step: 0.5625rem;
    }

    .pta2-event-bar--timed.is-overlap {
        padding-inline: 0.1875rem;
    }

    .pta2-event-bar--timed.is-overlap .pta2-event-bar-title {
        font-size: 0.5625rem;
        letter-spacing: -0.02em;
    }
}

/* 2026-05-02 JST / 00352 / Block7-Main-1A Shift Note period display */
/* 2026-05-02 JST / 00353 / Shift Note period tone and event bar vertical alignment */
/* 2026-05-02 JST / 00354 / Shift Note deadline warning and information area */
:root {
    --pta2-shift-period-nearest: #bfdbfe;
    --pta2-shift-period-nearest-bg: rgba(37, 99, 235, 0.055);
    --pta2-shift-period-open: #dbeafe;
    --pta2-shift-period-open-bg: rgba(37, 99, 235, 0.055);
    --pta2-shift-period-warning: #fde68a;
    --pta2-shift-period-warning-bg: rgba(245, 158, 11, 0.075);
    --pta2-shift-period-special: #fecdd3;
    --pta2-shift-period-special-bg: rgba(225, 29, 72, 0.075);
    --pta2-shift-period-closed: #e5e7eb;
    --pta2-shift-period-closed-bg: rgba(100, 116, 139, 0.09);
    --pta2-shift-period-future: #f1f5f9;
    --pta2-shift-period-future-bg: rgba(100, 116, 139, 0.05);
}

/* 2026-05-09 JST / 00505 rev03 / 申告期間の日付背景は廃止。対象範囲は申告期間バーだけで示す。 */
.pta2-a-cell[data-shift-period-bg] {
    background: transparent;
}

/* 2026-05-09 JST / 00505 rev02 / 締切の近さ・注意喚起は締切日側の背景で示す。 */
.pta2-a-cell[data-shift-deadline-bg="nearest_open"],
.pta2-a-cell[data-shift-deadline-bg="open"] {
    background: rgba(37, 99, 235, 0.1);
}

.pta2-a-cell[data-shift-deadline-bg="deadline_warning"] {
    background: rgba(245, 158, 11, 0.12);
}

.pta2-a-cell[data-shift-deadline-bg="special_deadline"] {
    background: rgba(225, 29, 72, 0.1);
}

.pta2-a-cell[data-shift-deadline-bg="extended"] {
    background: rgba(13, 202, 240, 0.075);
}

.pta2-a-cell[data-shift-deadline-bg="closed"] {
    background: var(--pta2-shift-period-closed-bg);
}

.pta2-event-bar[data-event-kind="shift_note_period"],
.pta2-event-bar[data-event-kind="shift_note_deadline_event"],
.pta2-event-bar[data-event-kind="shift_note_deadline_exception"] {
    min-block-size: var(--pta2-a-bar-height);
    align-items: flex-start;
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-row-span="2"],
.pta2-event-bar[data-event-kind="shift_note_deadline_exception"][data-row-span="2"] {
    block-size: calc(var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-gap));
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-row-span="3"],
.pta2-event-bar[data-event-kind="shift_note_deadline_exception"][data-row-span="3"] {
    block-size: calc(var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-gap) + var(--pta2-a-gap));
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-row-span="4"],
.pta2-event-bar[data-event-kind="shift_note_deadline_exception"][data-row-span="4"] {
    block-size: calc(var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-bar-height) + var(--pta2-a-gap) + var(--pta2-a-gap) + var(--pta2-a-gap));
}

/* 2026-05-09 JST / 00505 rev05 / 特例・締切注意の期間バー色は正規色を維持する。 */
.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="special_deadline"] {
    background: var(--pta2-shift-period-special);
    box-shadow: inset 0 0 0 1px rgba(225, 29, 72, 0.18);
}

.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="deadline_warning"] {
    background: var(--pta2-shift-period-warning);
    box-shadow: inset 0 0 0 1px rgba(245, 158, 11, 0.2);
}

.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="nearest_open"] {
    background: var(--pta2-shift-period-nearest);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.18);
}

.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="open"] {
    background: var(--pta2-shift-period-open);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.12);
}

.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="hidden_grace"],
.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="closed"] {
    background: var(--pta2-shift-period-closed);
    color: var(--pta2-muted);
    box-shadow: inset 0 0 0 1px rgba(100, 116, 139, 0.14);
}

.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="time_vent_extended"],
.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="time_leap_extended"] {
    background: var(--bs-info-bg-subtle);
    color: var(--bs-info-text-emphasis);
    box-shadow: inset 0 0 0 1px rgba(13, 202, 240, 0.18);
}

/* 2026-05-09 JST / 00505 rev03 / 初回猶予は通常申告期間と同じ青系に寄せる。 */
.pta2-event-bar[data-event-kind="shift_note_period"][data-event-status="gate_of_steiner"] {
    background: var(--pta2-shift-period-open);
    color: inherit;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.12);
}

/* 2026-05-09 JST / 00505 rev05 / 特例締切の期間バーは赤、日付背景は締切日だけ。 */
.pta2-event-bar[data-event-kind="shift_note_deadline_exception"] {
    background: var(--pta2-shift-period-special);
    color: var(--bs-danger-text-emphasis);
    box-shadow: inset 0 0 0 1px rgba(225, 29, 72, 0.18);
}


.pta2-event-bar[data-event-kind="shift_note_deadline_event"] {
    background: var(--pta2-shift-period-open);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.12);
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="nearest_open"] {
    background: var(--pta2-shift-period-nearest);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.18);
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="deadline_warning"] {
    background: var(--pta2-shift-period-warning);
    box-shadow: inset 0 0 0 1px rgba(245, 158, 11, 0.2);
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="special_deadline"],
.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="deadline_exception"] {
    background: var(--pta2-shift-period-special);
    box-shadow: inset 0 0 0 1px rgba(225, 29, 72, 0.18);
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="time_vent_extended"],
.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="time_leap_extended"] {
    background: var(--bs-info-bg-subtle);
    color: var(--bs-info-text-emphasis);
    box-shadow: inset 0 0 0 1px rgba(13, 202, 240, 0.18);
}

/* 2026-05-09 JST / 00505 rev03 / 初回猶予の締切バーも通常締切と同じ青系に寄せる。 */
.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="gate_of_steiner"] {
    background: var(--pta2-shift-period-open);
    color: inherit;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.12);
}

.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="hidden_grace"],
.pta2-event-bar[data-event-kind="shift_note_deadline_event"][data-event-status="closed"] {
    background: var(--pta2-shift-period-closed);
    color: var(--pta2-muted);
    box-shadow: inset 0 0 0 1px rgba(100, 116, 139, 0.14);
}

/* 2026-05-04 JST / 00397 / PN側TA風カレンダー: 本人の提出済み日別サマリー */
.pta2-event-bar[data-event-kind="shift_note_self_day"][data-event-status="available"] {
    background: var(--bs-success-bg-subtle);
    color: var(--bs-success-text-emphasis);
    box-shadow: inset 0 0 0 1px rgba(25, 135, 84, 0.18);
}

.pta2-event-bar[data-event-kind="shift_note_self_day"][data-event-status="unavailable"] {
    background: var(--bs-danger-bg-subtle);
    color: var(--bs-danger-text-emphasis);
    box-shadow: inset 0 0 0 1px rgba(220, 53, 69, 0.18);
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"][data-event-status="available"] {
    color: var(--bs-success-text-emphasis);
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"][data-event-status="unavailable"] {
    color: var(--bs-danger-text-emphasis);
}


[data-role="shift-note-information-item"] {
    border-inline-start-width: 0.25rem;
}

[data-role="shift-note-information-item"][data-info-kind="special_deadline"] {
    border-inline-start-color: #e11d48;
}

[data-role="shift-note-information-item"][data-info-kind="deadline_warning"] {
    border-inline-start-color: #f59e0b;
}

[data-role="shift-note-information-item"][data-info-kind="manager_message"] {
    border-inline-start-color: #2563eb;
}

/* 2026-05-03 JST / 00369 / Block7-Main-2 Shift Note form shell */
[data-role="shift-note-form-shell"] {
    scroll-margin-top: 1rem;
    margin-bottom: 5rem;
}

[data-role="shift-note-floating-save-bar"] {
    z-index: 1020;
    padding-bottom: max(0.5rem, env(safe-area-inset-bottom));
}

[data-role="shift-note-information-item"][data-action="open-shift-note-period-form"] {
    cursor: pointer;
}

/* 2026-05-03 JST / 00371 / Block7-Main-2 form shell correction */
[data-role="shift-note-time-input-group"] {
    min-width: 0;
}

[data-role="shift-note-time-input-group"] > .form-floating {
    min-width: 0;
}

/* 2026-05-03 JST / 00372 / Block7-Main-2 floating label polish */
[data-role="portal-tip-body"] {
    font-weight: 400;
}

[data-role="shift-note-period-note-input"] {
    min-height: 7rem;
}


/* 2026-05-03 JST / 00373 / Block7-Main-2 compact controls polish */
[data-role="portal-tip-toggle"] {
    font-size: .875rem;
}

[data-role="portal-tip-body"] {
    font-size: .6875rem;
    font-weight: 400;
}

[data-role="shift-note-time-slot-actions"] .btn {
    padding: .2rem .45rem;
    line-height: 1;
}

[data-role="shift-note-time-slot-actions"] .bi {
    font-size: .8125rem;
}

[data-role="shift-note-form-title"] [data-portal-display-chip="1"] {
    min-height: 1.125rem;
    padding: .0625rem .375rem;
    font-size: .75rem;
    line-height: 1.1;
}

[data-role="shift-note-day-list"] [data-role="shift-note-day-row"]:last-child {
    padding-bottom: .25rem !important;
}

/* 2026-05-03 JST / 00375 / Block7-Main-2 final alignment polish */
[data-role="shift-note-time-slot-row"] > .d-flex {
    align-items: center !important;
}

[data-role="shift-note-time-slot-row"] [data-role="portal-tip-toggle"][data-tip-key="shift_note_time"] {
    align-self: flex-start;
    margin-top: .25rem;
}


/* 2026-05-03 JST / 00379 / Block7-Main-2 empty details spacing and NG time help */
[data-role="shift-note-unavailable-time-help"] {
    font-size: .6875rem;
    font-weight: 400;
}

/* 2026-05-04 JST / 00398 / PN側TA風カレンダー: 本人日別イベント表示の実用ラベル化 */
.pta2-event-bar[data-event-kind="shift_note_self_day"] .pta2-event-bar-title,
.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-month-timed-title {
    white-space: normal;
    overflow: hidden;
    text-overflow: clip;
}

/* 2026-05-04 JST / 00399 / PN側TA風カレンダー: 自分の日別申告ラベルは折り返しつつバー領域外は省略する。 */
.pta2-event-bar[data-event-kind="shift_note_self_day"] {
    overflow: hidden;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] {
    overflow: hidden;
}

.pta2-shift-note-self-label {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.1875rem;
    min-width: 0;
}

.pta2-shift-note-self-label .bi {
    flex: 0 0 auto;
    line-height: 1;
}

.pta2-shift-note-self-count,
.pta2-shift-note-self-time {
    min-width: 0;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] {
    justify-content: flex-start;
}


/* 2026-05-04 JST / 00400 / PN月表示Aエリア: 本人日別申告の時間付きイベントも1段バー表示へ統一 */
.pta2-month-timed-item[data-event-kind="shift_note_self_day"] {
    block-size: var(--pta2-a-bar-height);
    min-block-size: var(--pta2-a-bar-height);
    border-radius: var(--pta2-bar-radius);
    padding: 0 0.375rem;
    align-items: center;
    gap: 0.25rem;
    line-height: 1;
    overflow: hidden;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"][data-event-status="available"] {
    background: var(--bs-success-bg-subtle);
    box-shadow: inset 0 0 0 1px rgba(25, 135, 84, 0.18);
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"][data-event-status="unavailable"] {
    background: var(--bs-danger-bg-subtle);
    box-shadow: inset 0 0 0 1px rgba(220, 53, 69, 0.18);
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-month-timed-title,
.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-label {
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: center;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-time {
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/* 2026-05-04 JST / 00401 / PN月表示Aエリア: 本人日別申告ラベルはアイコンを保持し、時刻テキスト側だけ省略する。 */
.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-month-timed-title {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: clip;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-label {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.1875rem;
    inline-size: 100%;
    max-inline-size: 100%;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: clip;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-label .bi {
    flex: 0 0 auto;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-count {
    flex: 0 0 auto;
    min-width: auto;
    overflow: visible;
    white-space: nowrap;
    text-overflow: clip;
}

.pta2-month-timed-item[data-event-kind="shift_note_self_day"] .pta2-shift-note-self-time {
    flex: 1 1 auto;
    min-width: 0;
    max-inline-size: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/* 2026-05-05 JST / 00410 / PN側TA風カレンダー: 同所属他スタッフ提出済み申告の軽量表示 */
/* 2026-05-05 JST / 00411 / 他スタッフ申告バーは透過ではなく不透明な淡色で重なり濃化を防ぐ */
.pta2-event-bar[data-event-kind="shift_note_other_day"] {
    overflow: hidden;
}

.pta2-event-bar[data-event-kind="shift_note_other_day"] .pta2-event-bar-title,
.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-month-timed-title {
    white-space: normal;
    overflow: hidden;
    text-overflow: clip;
}

.pta2-event-bar[data-event-kind="shift_note_other_day"][data-event-status="available"] {
    background: #eef7f2;
    color: var(--bs-success-text-emphasis);
    box-shadow: inset 0 0 0 1px #cfe8db;
}

.pta2-event-bar[data-event-kind="shift_note_other_day"][data-event-status="unavailable"] {
    background: #fdf1f3;
    color: var(--bs-danger-text-emphasis);
    box-shadow: inset 0 0 0 1px #f5cdd3;
}

.pta2-shift-note-staff-name {
    min-width: 0;
    font-weight: 600;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"] {
    block-size: var(--pta2-a-bar-height);
    min-block-size: var(--pta2-a-bar-height);
    border-radius: var(--pta2-bar-radius);
    padding: 0 0.375rem;
    align-items: center;
    gap: 0.25rem;
    line-height: 1;
    justify-content: flex-start;
    overflow: hidden;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"][data-event-status="available"] {
    background: #eef7f2;
    color: var(--bs-success-text-emphasis);
    box-shadow: inset 0 0 0 1px #cfe8db;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"][data-event-status="unavailable"] {
    background: #fdf1f3;
    color: var(--bs-danger-text-emphasis);
    box-shadow: inset 0 0 0 1px #f5cdd3;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-month-timed-title {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: clip;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-shift-note-self-label {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.1875rem;
    inline-size: 100%;
    max-inline-size: 100%;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: clip;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-shift-note-self-label .bi,
.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-shift-note-self-count,
.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-shift-note-staff-name {
    flex: 0 0 auto;
}

.pta2-month-timed-item[data-event-kind="shift_note_other_day"] .pta2-shift-note-self-time {
    flex: 1 1 auto;
    min-width: 0;
    max-inline-size: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}


/* 2026-05-11 JST / 00527-B rev01 / Portal form warning validation */
.form-control.is-warning,
.form-select.is-warning {
    border-color: var(--bs-warning);
}

.form-control.is-warning:focus,
.form-select.is-warning:focus {
    border-color: var(--bs-warning);
    box-shadow: 0 0 0 .25rem rgba(var(--bs-warning-rgb), .25);
}

.warning-feedback {
    display: none;
    width: 100%;
    margin-top: .25rem;
    font-size: .875em;
    color: var(--bs-warning-text-emphasis);
}


/* 2026-05-21 JST / 00681 / Portal Tips補足アイコン色を控えめに統一。 */
[data-role="portal-tip"],
[data-role="portal-tip-toggle"] {
    color: var(--portal-tips-icon-color) !important;
}

[data-role="portal-tip"]:hover,
[data-role="portal-tip"]:focus,
[data-role="portal-tip-toggle"]:hover,
[data-role="portal-tip-toggle"]:focus {
    color: var(--portal-tips-icon-hover-color) !important;
}

/* 2026-05-14 JST / 00564-F / Portal Tips tooltip表示調整。色と文字サイズは共通CSS変数で管理する。 */
.tooltip {
    --bs-tooltip-bg: var(--portal-tooltip-bg);
    --bs-tooltip-color: var(--portal-tooltip-color);
    --bs-tooltip-font-size: var(--portal-tooltip-font-size);
}

.tooltip .tooltip-inner {
    border: var(--bs-border-width) solid var(--portal-tooltip-border-color);
    box-shadow: var(--bs-box-shadow-sm);
}

/* 2026-05-14 JST / 00564-D / Portal Status Row Bar 余白・詳細位置補正（定型申告ルール一覧） */
[data-role="portal-status-row-list"] {
    border-block-start: var(--bs-border-width) solid var(--bs-border-color);
}

[data-portal-status-row="1"] {
    border-block-end: var(--bs-border-width) solid var(--bs-border-color);
}

[data-role="portal-status-row-accent"] {
    width: 0.375rem;
    border-radius: 0.75rem;
    margin-block: 0.5rem;
}

[data-role="portal-status-row-body"] {
    min-width: 0;
}

[data-role="portal-status-row-leading"] {
    min-width: 1.5rem;
    text-align: center;
}

[data-portal-status-row-detail="1"] {
    margin-left: 2.5rem;
}

[data-role="portal-status-row-trailing"] .btn {
    min-width: 1.5rem;
    min-height: 1.5rem;
}

[data-role="portal-tip"][data-tip-display="tooltip"][data-tip-scope="mobile"] {
    min-width: 1.25rem;
    min-height: 1.25rem;
}

/* 2026-05-15 JST / 00576 / Portal Detail Field List Package. */
.portal-detail-field-list {
    color: var(--portal-detail-field-value-color);
}

.portal-detail-field-list__row {
    display: grid;
    grid-template-columns: minmax(6rem, 32%) minmax(0, 1fr);
    gap: 0.75rem;
    padding-block: 0.375rem;
    border-block-end: var(--bs-border-width) dashed var(--portal-detail-field-divider-color);
}

.portal-detail-field-list__row:first-child {
    padding-block-start: 0;
}

.portal-detail-field-list__row:last-child {
    border-block-end: 0;
    padding-block-end: 0;
}

.portal-detail-field-list__label {
    color: var(--portal-detail-field-label-color);
}

.portal-detail-field-list__value {
    color: var(--portal-detail-field-value-color);
    min-width: 0;
}

@media (max-width: 36rem) {
    .portal-detail-field-list__row {
        grid-template-columns: minmax(0, 1fr);
        gap: 0.25rem;
    }
}

/* 2026-05-16 JST / 00619 / Portal Key Value List CommonPart. */
.portal-key-value-list {
    color: var(--portal-detail-field-value-color);
}

.portal-key-value-list__row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding-block: 0.5rem;
    border-block-end: var(--bs-border-width) solid var(--bs-border-color-translucent);
}

.portal-key-value-list__row:first-child {
    padding-block-start: 0;
}

.portal-key-value-list__row:last-child {
    border-block-end: 0;
    padding-block-end: 0;
}

.portal-key-value-list__label {
    color: var(--portal-detail-field-label-color);
    font-size: 0.875em;
    min-width: max-content;
}

.portal-key-value-list__value {
    color: var(--portal-detail-field-value-color);
    font-weight: 600;
    min-width: 0;
    overflow-wrap: anywhere;
    text-align: right;
}

/* 2026-05-19 JST / 00654 / Naviユーザー一覧詳細の開始位置を連絡先検索系のStatus Rowと揃える。 */
[data-role="ssc-navi-user-list-detail"][data-portal-status-row-detail="1"] {
    margin-left: 3.5rem;
}


/* 2026-05-19 JST / 00659 / PN Personal Console機能リストはプレーン寄りにする。 */
.personal-feature-key-value-list .portal-key-value-list__value {
    font-weight: 400;
}

.personal-feature-key-value-list .portal-key-value-list__label {
    min-width: 0;
}

.personal-feature-key-value-list [data-role="personal-scope-request-state"] {
    font-weight: 400;
}


/* 2026-05-19 JST / 00661 / 操作可能なOFFトグルをdisabledに見せない。 */
[data-form="personal-scope-request"] .form-check-input:not(:checked):not(:disabled),
[data-form="ssc-navi-user-office-permission"] .form-check-input:not(:checked):not(:disabled) {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-secondary);
}

/* 2026-05-19 JST / 00663 / Portal Information Area Package. */
.portal-information-area {
    display: grid;
    gap: 0.5rem;
}

.portal-information-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem;
    border: var(--bs-border-width) solid var(--bs-border-color-translucent);
    border-radius: var(--bs-border-radius-lg);
    background-color: var(--bs-body-bg);
}

.portal-information-item--info {
    background-color: var(--bs-info-bg-subtle);
    border-color: var(--bs-info-border-subtle);
}

.portal-information-item--warning,
.portal-information-item--pending {
    background-color: var(--bs-warning-bg-subtle);
    border-color: var(--bs-warning-border-subtle);
}

.portal-information-item--success {
    background-color: var(--bs-success-bg-subtle);
    border-color: var(--bs-success-border-subtle);
}

.portal-information-item--danger {
    background-color: var(--bs-danger-bg-subtle);
    border-color: var(--bs-danger-border-subtle);
}

.portal-information-item--primary {
    background-color: var(--bs-primary-bg-subtle);
    border-color: var(--bs-primary-border-subtle);
}

.portal-information-item--secondary {
    background-color: var(--bs-secondary-bg-subtle);
    border-color: var(--bs-secondary-border-subtle);
}

.portal-information-item__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    min-width: 1.5rem;
    min-height: 1.5rem;
    color: var(--bs-secondary-color);
}

.portal-information-item--info .portal-information-item__icon,
.portal-information-item--primary .portal-information-item__icon {
    color: var(--bs-primary);
}

.portal-information-item--warning .portal-information-item__icon,
.portal-information-item--pending .portal-information-item__icon {
    color: var(--bs-warning-text-emphasis);
}

.portal-information-item--success .portal-information-item__icon {
    color: var(--bs-success-text-emphasis);
}

.portal-information-item--danger .portal-information-item__icon {
    color: var(--bs-danger-text-emphasis);
}

.portal-information-item__icon img {
    width: 1.5rem;
    height: 1.5rem;
    object-fit: contain;
}

.portal-information-item__body {
    min-width: 0;
    flex: 1 1 auto;
}

.portal-information-item__title {
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1.35;
}

.portal-information-item__text {
    color: var(--bs-secondary-color);
    font-size: 0.8125rem;
    line-height: 1.45;
    margin-top: 0.125rem;
}

.portal-information-item__chips {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex-wrap: wrap;
    margin-top: 0.375rem;
}

.portal-information-item__action {
    flex: 0 0 auto;
}

@media (max-width: 36rem) {
    .portal-information-item {
        flex-wrap: wrap;
    }

    .portal-information-item__action {
        width: 100%;
        padding-left: 2.25rem;
    }
}

/* 2026-05-19 JST / 00670 / 申請状態チップを店舗チップ相当のbadge寸法へ戻す。 */
[data-role="personal-scope-request-state-chip"],
[data-role="ssc-navi-user-permission-request-chip"] {
    display: inline-block;
    min-height: 0;
    line-height: 1;
    vertical-align: baseline;
}

[data-role="personal-scope-request-state"],
[data-role="ssc-navi-user-permission-state"] {
    display: inline-flex;
    align-items: baseline;
}
