body { font-family: 'Pretendard', sans-serif; }
.server-card:hover { transform: translateY(-4px); box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); }
.panel-overlay { animation: fadeIn 0.2s ease-out; }
.panel-content { animation: scaleIn 0.2s ease-out; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes scaleIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.dark .apexcharts-tooltip-title, .dark .apexcharts-tooltip-text { color: #1f2937; }
.draggable-item { cursor: grab; }
.dragging { opacity: 0.5; background-color: #3b82f6 !important; border: 2px dashed #93c5fd; }

#issue-tracker-panel {
    transition: transform 0.3s ease-in-out;
}
#issue-tracker-panel.is-open {
    transform: translateX(0);
}
@keyframes card-fade-in {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.issue-card.animate-fade-in {
    animation: card-fade-in 0.4s ease-out forwards;
}

#loading-overlay {
    opacity: 1;
    transition: opacity 0.5s ease-out;
}
.aurora-bg {
    background: radial-gradient(ellipse at top, #1e293b, #0f172a),
    radial-gradient(ellipse at bottom, #38bdf8, #0f172a);
    background-size: 200% 200%;
    animation: aurora 10s ease-in-out infinite;
}
@keyframes aurora {
    0% { background-position: 50% 0%; }
    50% { background-position: 50% 100%; }
    100% { background-position: 50% 0%; }
}
.modern-spinner {
    width: 48px;
    height: 48px;
    border: 3px solid #67e8f9;
    border-bottom-color: transparent;
    border-radius: 50%;
    display: inline-block;
    animation: spin 1s linear infinite;
}
@keyframes spin {
    to { transform: rotate(360deg); }
}
@keyframes pulse-red {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7); }
    50% { box-shadow: 0 0 0 5px rgba(239, 68, 68, 0); }
}
.animate-pulse-red {
    animation: pulse-red 2s infinite;
}

@keyframes pulse-blue {
    0%, 100% { box-shadow: 0 0 0 0 rgba(59, 130, 246, 0.7); }
    50% { box-shadow: 0 0 0 5px rgba(59, 130, 246, 0); }
}
.animate-pulse-blue {
    animation: pulse-blue 2s infinite;
    box-shadow: 0 0 0 0 rgba(59, 130, 246, 0.7);
}

.accordion-chevron {
    transition: transform 0.2s ease-in-out;
}
details[open] > summary .accordion-chevron {
    transform: rotate(90deg);
}

/* --- Beam Pulse Animation (강력한 에너지 맥박) --- */
@keyframes pulse-beam {
    0%, 100% { opacity: 1; transform: scaleY(1); box-shadow: 0 0 20px #22c55e, 0 0 10px #22c55e inset; }
    50% { opacity: 0.8; transform: scaleY(0.95); box-shadow: 0 0 10px #22c55e, 0 0 5px #22c55e inset; }
}
.animate-pulse-beam {
    animation: pulse-beam 3s ease-in-out infinite;
    transform-origin: top;
}

/* --- Kiosk Elements Position & Layering --- */

#kiosk-status-line,
#kiosk-datetime-bar,
#kiosk-top-bar,
#kiosk-bottom-bar {
    transform: translateY(-100%);
    transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1); /* 탄성 있는 등장 효과 */
}

#kiosk-bottom-bar {
    transform: translateY(100%);
    background-color: rgba(15, 23, 42, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

/* 1. Status Beam (최상단) */
/* 2026-02-04: 키오스크 모드에서 초록색 상태바 숨김 */
/* body.kiosk-mode #kiosk-status-line {
    transform: translateY(0);
} */

/* 2. Datetime Bar (Beam 아래) */
/* 2026-02-04: 상태바 숨김으로 인해 top: 0으로 변경 */
#kiosk-datetime-bar {
    top: 0;
}
body.kiosk-mode #kiosk-datetime-bar {
    transform: translateY(0);
}

/* 3. Title Bar (Datetime Bar 아래) */
/* 2026-02-04: kiosk-top-bar 완전 숨김 */
#kiosk-top-bar {
    top: 4rem;
}
/* body.kiosk-mode #kiosk-top-bar {
    transform: translateY(0);
} */
body.kiosk-mode #kiosk-bottom-bar {
    transform: translateY(0);
}


/* --- Kiosk Mode Layout Adjustments --- */
body.kiosk-mode #left-sidebar {
    width: 5rem;
    transform: translateX(0) !important;
}
body.kiosk-mode #left-sidebar .h-16 .ml-2 {
    display: none;
}
body.kiosk-mode #left-sidebar .h-16 .flex.items-center {
    padding-left: 0.75rem;
}
body.kiosk-mode #left-sidebar .h-16 #system-info-btn-desktop {
    display: none;
}
body.kiosk-mode #left-sidebar nav a span,
body.kiosk-mode #left-sidebar nav h3,
body.kiosk-mode #left-sidebar nav #edit-groups-btn {
    display: none;
}
body.kiosk-mode #left-sidebar nav a svg {
    margin-right: 0;
}
body.kiosk-mode #left-sidebar nav a {
    justify-content: center;
}

body.kiosk-mode #left-sidebar .p-4.border-t {
    padding: 0;
    border-top: none;
}
body.kiosk-mode #left-sidebar .p-4.border-t > *:not(#theme-toggle) {
    display: none;
}

body.kiosk-mode .lg\:hidden.h-16 {
    display: none !important;
}
/* 2026-02-04: 공지 배너는 키오스크 모드에서도 유지 */
/* body.kiosk-mode #notice-banner-container {
    display: none !important;
} */

/* 본문 패딩: 헤더 총 높이 */
/* 2026-02-04: datetime-bar(4rem)만 반영 - top-bar 숨김, 빈공간 제거 */
body.kiosk-mode .relative.h-screen.lg\:flex {
    padding-top: 0 !important;
    /*padding-bottom: 6rem;*/
}

/* 2026-02-04: 키오스크 모드에서 헤더 영역 패딩 축소 */
body.kiosk-mode #main-view-container > .flex-shrink-0 {
    padding: 0.5rem 1rem 0 1rem !important;
}
body.kiosk-mode #main-view-container > .flex-shrink-0 .mb-4 {
    margin-bottom: 0.5rem !important;
}
body.kiosk-mode #main-view-container > .flex-shrink-0 h2 {
    font-size: 1.25rem !important;
}

body.kiosk-mode #mobile-menu-btn,
body.kiosk-mode #backdrop {
    display: none;
}

/* --- FAB Positioning --- */
#issue-tracker-fab {
    bottom: 2rem !important;
    right: 2rem !important;
    z-index: 50;
}

#kiosk-mode-fab {
    bottom: 2rem !important;
    right: 7rem !important;
    z-index: 50;
}

body.kiosk-mode #kiosk-mode-fab {
    bottom: 8rem !important;
    right: 2rem !important;
    display: flex !important;
}

#issue-tracker-fab:hover,
#kiosk-mode-fab:hover {
    transform: scale(1.1);
}

body:not(.kiosk-mode) #kiosk-icon-exit { display: none; }
body.kiosk-mode #kiosk-icon-enter { display: none; }
body.kiosk-mode #kiosk-icon-exit { display: block; }

/* --- Kiosk Alert Stats --- */
#kiosk-alert-stats #event-status-center {
    padding: 0;
    cursor: default;
}
#kiosk-alert-stats #event-status-center:hover {
    background-color: transparent;
}
#kiosk-alert-stats .items-center.gap-1 {
    padding: 0.75rem 1.5rem;
    gap: 0.75rem;
}
#kiosk-alert-stats .text-xs {
    font-size: 1.125rem;
    line-height: 1.75rem;
}
#kiosk-alert-stats #alert-count-badge,
#kiosk-alert-stats #notification-count-badge {
    font-size: 1rem;
}

/* --- Theme Toggle Button Adjustments --- */
body:not(.kiosk-mode) #theme-toggle {
    position: static;
    width: 100%;
    height: auto;
    background-color: transparent;
    color: inherit;
    border-radius: 0.375rem;
    box-shadow: none;
    display: flex !important;
    align-items: center;
    justify-content: initial;
    z-index: auto;
    padding: 0.5rem 0.75rem;
    margin: 0;
}
body:not(.kiosk-mode) #theme-toggle svg {
    width: 1.25rem;
    height: 1.25rem;
    margin-right: 0.75rem !important;
}
body:not(.kiosk-mode) #theme-toggle span {
    display: inline !important;
}
body:not(.kiosk-mode) #theme-toggle:hover {
    background-color: #f3f4f6;
    color: inherit;
    transform: none;
}
.dark body:not(.kiosk-mode) #theme-toggle:hover {
    background-color: #374151;
    color: white;
}

body.kiosk-mode #theme-toggle {
    position: fixed !important;
    bottom: calc(7.5rem + 4rem + 1rem) !important;
    right: calc(4rem + 1.5rem + 12rem) !important;
    width: 3rem !important;
    height: 3rem !important;
    background-color: #4f46e5 !important;
    color: white !important;
    border-radius: 9999px !important;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 40 !important;
    transition: all 0.2s ease-in-out !important;
    padding: 0 !important;
    margin: 0 !important;
}
body.kiosk-mode #theme-toggle:hover {
    background-color: #4338ca !important;
    transform: scale(1.1) !important;
}
body.kiosk-mode #theme-toggle svg {
    width: 1.5rem !important;
    height: 1.5rem !important;
    margin-right: 0 !important;
}
body.kiosk-mode #theme-toggle span {
    display: none !important;
}

/* --- Hide Kiosk Elements in Normal Mode --- */
body:not(.kiosk-mode) #kiosk-status-line,
body:not(.kiosk-mode) #kiosk-datetime-bar,
body:not(.kiosk-mode) #kiosk-top-bar,
body:not(.kiosk-mode) #kiosk-bottom-bar,
body:not(.kiosk-mode) #kiosk-mode-fab #kiosk-icon-exit {
    display: none !important;
}

/* --- Misc Styles --- */
.view-container {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.view-layer {
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    width: 100%;
    height: 100%;
}

#view-2d {
    opacity: 1;
    z-index: 10;
    overflow-y: auto;
    position: absolute;
    inset: 0;
}

#view-3d {
    opacity: 0;
    z-index: 0;
    pointer-events: none;
    position: absolute;
    inset: 0;
    background-color: inherit;
}

.view-mode-3d #view-2d {
    opacity: 0;
    pointer-events: none;
    transform: scale(0.98);
}

.view-mode-3d #view-3d {
    opacity: 1;
    z-index: 20;
    pointer-events: auto;
    transform: scale(1);
}

#hardware-spec-panel {
    z-index: 60 !important;
}

#hardware-spec-overlay {
    z-index: 55 !important;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translate3d(0, 10px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.animate-fade-in-up {
    animation: fadeInUp 0.4s ease-out forwards;
}

.custom-scrollbar::-webkit-scrollbar {
    width: 6px;
}
.custom-scrollbar::-webkit-scrollbar-track {
    background: transparent;
}
.custom-scrollbar::-webkit-scrollbar-thumb {
    background-color: rgba(156, 163, 175, 0.5);
    border-radius: 3px;
}
.dark .custom-scrollbar::-webkit-scrollbar-thumb {
    background-color: rgba(75, 85, 99, 0.5);
}

#main-view-container {
    position: relative;
}
#hardware-spec-panel {
    z-index: 60 !important;
    min-height: 300px;
}

.break-keep {
    word-break: keep-all;
    word-wrap: break-word;
}

details > summary {
    list-style: none;
}
details > summary::-webkit-details-marker {
    display: none;
}

@keyframes fadeInScale {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-fade-in {
    animation: fadeInScale 0.2s ease-out forwards;
}

/* --- Z-Index Management for Kiosk Header --- */
#kiosk-status-line { z-index: 100; }
#kiosk-datetime-bar { z-index: 50; }
#kiosk-top-bar { z-index: 40; }

/* kisok-mode */
/* 키오스크 모드 - 전체 컨테이너 체인 */
body.kiosk-mode {
    overflow: hidden !important;
}

/* 2026-02-04: datetime-bar(64px)만 반영 - top-bar 숨김 */
body.kiosk-mode .view-container {
    height: calc(100vh - 70px) !important;
    overflow: hidden !important;
}

body.kiosk-mode #view-2d {
    height: 100% !important;
    max-height: 100% !important;
    overflow: hidden !important;
    padding: 0.5rem !important;
}

body.kiosk-mode #server-list-grid {
    display: grid !important;
    /* 2026-02-04: 1열 200px → 280px 확대 (리소스 분석 테이블 전체 표시) */
    grid-template-columns: 280px 1fr 300px !important;
    /* row 9개로 세분화 */
    grid-template-rows: repeat(9, 1fr) !important;
    height: 100% !important;
    max-height: 100% !important;
    gap: 0.5rem !important;
    overflow: hidden !important;
}

body.kiosk-mode #server-list-grid > div {
    overflow: hidden !important;
    min-height: 0 !important;
    max-height: 100% !important;
}

/* ===== 1열 (왼쪽) - 280px ===== */
/* 서버 상태 분포: row 1~2 (2칸) */
body.kiosk-mode #total-summary-distribution-card {
    grid-column: 1 !important;
    grid-row: 1 / 3 !important;
}
/* 2026-02-04: 라벨은 원래 위치, 도넛 차트만 중앙 배치 */
body.kiosk-mode #total-summary-distribution-card > div {
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}
body.kiosk-mode #total-summary-distribution-card > div > div:last-child {
    flex: 1 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

/* 리소스 분석: row 3~6 (4칸) */
body.kiosk-mode #resource-stats-card {
    grid-column: 1 !important;
    grid-row: 3 / 7 !important;
}

/* Top 5: row 7~9 (3칸) - 하단 */
body.kiosk-mode #resource-top5-card {
    grid-column: 1 !important;
    grid-row: 7 / 10 !important;
}

/* ===== 2열 (중앙) - 1fr ===== */
/* 리소스 평균 사용률: row 1~2 (2칸) */
body.kiosk-mode #total-summary-avg-card {
    grid-column: 2 !important;
    grid-row: 1 / 3 !important;
}
/* 2026-02-04: 키오스크 모드에서 리소스 평균 사용률 도넛 차트 크기 확대 */
body.kiosk-mode #total-summary-avg-card .w-14.h-14 {
    width: 5.5rem !important;
    height: 5.5rem !important;
}
body.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-xs {
    font-size: 1rem !important;
    font-weight: 700 !important;
}
body.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-\[8px\] {
    font-size: 0.7rem !important;
}

/* 사용률 추이: row 3~7 (5칸) */
body.kiosk-mode #total-summary-chart {
    grid-column: 2 !important;
    grid-row: 3 / 8 !important;
}

/* 분포 현황: row 8~9 (2칸) */
body.kiosk-mode #total-summary-resource-card {
    grid-column: 2 !important;
    grid-row: 8 / 10 !important;
}

/* ===== 3열 (오른쪽) - 300px ===== */
body.kiosk-mode #total-server-list {
    grid-column: 3 !important;
    grid-row: 1 / 10 !important;
}

/* ===== 카드 내부 스타일 조정 ===== */

/* Top 5 카드 내부가 꽉 차도록 */
body.kiosk-mode #resource-top5-card {
    height: 100% !important;
}

body.kiosk-mode #resource-top5-card > div {
    height: 100% !important;
}

body.kiosk-mode #resource-top5-card .flex-1 {
    flex: 1 !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

body.kiosk-mode #resource-top5-card .resource-tab-content {
    height: 100% !important;
}

body.kiosk-mode #resource-top5-card .bg-slate-800\/30 {
    height: 100% !important;
}

body.kiosk-mode #resource-top5-card .custom-scrollbar {
    max-height: 100% !important;
    overflow-y: auto !important;
}

/* --- Kiosk Mode Alert Center --- */
#kiosk-event-status-center-container {
    display: none;
}
body.kiosk-mode #kiosk-event-status-center-container {
    display: block;
}

/* --- Kiosk Mode Notice (inline in datetime bar) --- */
#kiosk-notice-container {
    display: none;
}
body.kiosk-mode #kiosk-notice-container {
    display: flex;
}

/* ===== 2026-02-06: 스탠바이미 (세로 화면) 전용 레이아웃 ===== */
@media (orientation: portrait) {
    /* 세로 화면 + 키오스크 모드일 때만 적용 */
    body.kiosk-mode #server-list-grid {
        /* 새 구조: 상단 배너 + 8개 row */
        grid-template-rows: auto repeat(3, 1fr) auto repeat(4, 1fr) !important;
    }

    /* ===== Row 1: 서버 상태 분포 (1~2열) ===== */
    body.kiosk-mode #total-summary-distribution-card {
        grid-column: 1 / 3 !important;
        grid-row: 1 !important;
        max-height: none !important;
        height: auto !important;
        padding: 0.5rem 1rem !important;
    }

    /* 서버 상태 분포 내부 가로 배치 */
    body.kiosk-mode #total-summary-distribution-card > div {
        height: auto !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 1.5rem !important;
    }

    body.kiosk-mode #total-summary-distribution-card > div > div:first-child {
        flex-shrink: 0 !important;
    }

    body.kiosk-mode #total-summary-distribution-card > div > div:last-child {
        flex: 1 !important;
        justify-content: flex-start !important;
    }

    /* 범례를 가로로 배치 */
    body.kiosk-mode #total-summary-distribution-card .space-y-1 {
        display: flex !important;
        flex-direction: row !important;
        gap: 1.5rem !important;
        flex-wrap: wrap !important;
    }

    body.kiosk-mode #total-summary-distribution-card .space-y-1 > div {
        margin: 0 !important;
    }

    /* ===== Row 2-4: 리소스 분석 (1열) + 리소스 평균 사용률 (2열) ===== */
    body.kiosk-mode #resource-stats-card {
        grid-column: 1 !important;
        grid-row: 2 / 5 !important;
    }

    body.kiosk-mode #total-summary-avg-card {
        grid-column: 2 !important;
        grid-row: 2 / 5 !important;
    }

    /* ===== Row 5: Top 5 (1열) + 분포 현황 (2열) - 같은 줄 ===== */
    body.kiosk-mode #resource-top5-card {
        grid-column: 1 !important;
        grid-row: 5 !important;
    }

    body.kiosk-mode #total-summary-resource-card {
        grid-column: 2 !important;
        grid-row: 5 !important;
    }

    /* ===== Row 6-9: 사용률 추이 차트 (1~2열 전체, 큰 공간) ===== */
    body.kiosk-mode #total-summary-chart {
        grid-column: 1 / 3 !important;
        grid-row: 6 / 10 !important;
    }

    /* ===== 3열: 서버 목록 (전체 높이) ===== */
    body.kiosk-mode #total-server-list {
        grid-column: 3 !important;
        grid-row: 1 / 10 !important;
    }

    /* 리소스 평균 사용률 2x2 그리드 */
    body.kiosk-mode #total-summary-avg-card .flex.items-center.justify-around {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        grid-template-rows: repeat(2, 1fr) !important;
        gap: 0.5rem !important;
        justify-items: center !important;
        align-items: center !important;
    }

    body.kiosk-mode #total-summary-avg-card .w-14.h-14 {
        width: 10rem !important;
        height: 10rem !important;
    }

    body.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-xs {
        font-size: 1.75rem !important;
        font-weight: 700 !important;
    }

    body.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-\[8px\] {
        font-size: 1rem !important;
    }

    /* ===== 2026-02-11: 터치 친화적 스타일 (스탠바이미 인터랙티브) ===== */
    body.kiosk-mode .server-item {
        min-height: 48px !important;
        padding: 12px !important;
        cursor: pointer;
    }

    body.kiosk-mode .chart-tab-btn {
        min-height: 44px !important;
        min-width: 60px !important;
    }

    body.kiosk-mode .server-row {
        min-height: 44px !important;
        cursor: pointer;
    }

    body.kiosk-mode .resource-chart-btn {
        min-height: 48px !important;
        cursor: pointer;
    }
}

/* ===== 2026-02-09: 키오스크 V2 레이아웃 ===== */
/* 리소스 분석 숨김 */
body.kiosk-v2 #resource-stats-card {
    display: none !important;
}
/* 분포 현황 → 1열, row3-6 (세로 배치) */
body.kiosk-v2 #total-summary-resource-card,
body.kiosk-v2.kiosk-mode #total-summary-resource-card {
    grid-column: 1 !important;
    grid-row: 3 / 7 !important;
}
/* 분포 현황 내부: 2열 그리드 → 세로 1열 */
body.kiosk-v2 #total-summary-resource-card .grid-cols-2 {
    grid-template-columns: 1fr !important;
    grid-template-rows: 1fr 1fr !important;
}
/* 사용률 추이 → row3-6 (위로 올려서 분포 현황과 맞춤) */
body.kiosk-v2 #total-summary-chart,
body.kiosk-v2.kiosk-mode #total-summary-chart {
    grid-column: 2 !important;
    grid-row: 3 / 7 !important;
}
/* Top 5 (4종 동시) → 1~2열 span, row7-9 (하단 전체 너비) */
body.kiosk-v2 #resource-top5-card,
body.kiosk-v2.kiosk-mode #resource-top5-card {
    grid-column: 1 / 3 !important;
    grid-row: 7 / 10 !important;
}
/* V2 탭 버튼 확대 */
body.kiosk-v2 .chart-tab-btn {
    padding: 0.5rem 1rem !important;
    font-size: 0.875rem !important;
    font-weight: 700 !important;
    border-radius: 0.5rem !important;
}
body.kiosk-v2 .chart-tab-btn.active {
    box-shadow: 0 0 12px rgba(59, 130, 246, 0.5) !important;
    outline: 2px solid rgba(147, 197, 253, 0.7) !important;
    outline-offset: 1px !important;
}

/* ===== 2026-02-09: 키오스크 V3 레이아웃 ===== */
/* V3: 분포 현황 숨김 (리소스 분석이 대신 표시) */
body.kiosk-v3 #total-summary-resource-card {
    display: none !important;
}
/* V3: 리소스 분석 → 1열, row3-6 */
body.kiosk-v3 #resource-stats-card,
body.kiosk-v3.kiosk-mode #resource-stats-card {
    grid-column: 1 !important;
    grid-row: 3 / 7 !important;
    display: flex !important;
}
/* V3: 사용률 추이 → row3-6 (위로 올림) */
body.kiosk-v3 #total-summary-chart,
body.kiosk-v3.kiosk-mode #total-summary-chart {
    grid-column: 2 !important;
    grid-row: 3 / 7 !important;
}
/* V3: Top 5 (4종) → 1~2열 span, row7-9 */
body.kiosk-v3 #resource-top5-card,
body.kiosk-v3.kiosk-mode #resource-top5-card {
    grid-column: 1 / 3 !important;
    grid-row: 7 / 10 !important;
}
/* V3 탭 버튼 확대 */
body.kiosk-v3 .chart-tab-btn {
    padding: 0.5rem 1rem !important;
    font-size: 0.875rem !important;
    font-weight: 700 !important;
    border-radius: 0.5rem !important;
}
body.kiosk-v3 .chart-tab-btn.active {
    box-shadow: 0 0 12px rgba(59, 130, 246, 0.5) !important;
    outline: 2px solid rgba(147, 197, 253, 0.7) !important;
    outline-offset: 1px !important;
}

/* ===== 공통: 키오스크 모드 타이틀/도넛/상태라벨 확대 ===== */
/* 카드 타이틀 확대 */
body.kiosk-mode #server-list-grid h5 {
    font-size: 0.9375rem !important;
    font-weight: 700 !important;
}
/* 서버 상태 분포 - 도넛 차트 확대 */
body.kiosk-mode #total-summary-distribution-card .w-20.h-20 {
    width: 6.5rem !important;
    height: 6.5rem !important;
}
/* 서버 상태 분포 - 중앙 숫자 확대 */
body.kiosk-mode #total-summary-distribution-card .text-base {
    font-size: 1.375rem !important;
    font-weight: 800 !important;
}
/* 서버 상태 분포 - '대' 텍스트 확대 */
body.kiosk-mode #total-summary-distribution-card .text-\[7px\] {
    font-size: 0.625rem !important;
}
/* 서버 상태 분포 - 범례 (정상/경고/위험/다운) 확대 */
body.kiosk-mode #total-summary-distribution-card .text-\[9px\] {
    font-size: 0.75rem !important;
}
body.kiosk-mode #total-summary-distribution-card .space-y-1 {
    gap: 0.375rem !important;
}
/* 범례 아이콘 확대 */
body.kiosk-mode #total-summary-distribution-card .w-1\.5.h-1\.5 {
    width: 0.5rem !important;
    height: 0.5rem !important;
}

/* ===== 2026-02-11: Portrait + V2 전용 레이아웃 (V2 규칙 뒤에 배치하여 우선순위 확보) ===== */
@media (orientation: portrait) {
    /* 그리드: 상태분포→평균→차트(full)→Top5+분포|서버목록 */
    body.kiosk-v2.kiosk-mode #server-list-grid {
        grid-template-rows: auto auto repeat(5, 1fr) 1.5fr 1fr !important;
    }

    /* Row 1: 서버 상태 분포 - full width */
    body.kiosk-v2.kiosk-mode #total-summary-distribution-card {
        grid-column: 1 / -1 !important;
        grid-row: 1 !important;
    }

    /* Row 2: 리소스 평균 사용률 - full width */
    body.kiosk-v2.kiosk-mode #total-summary-avg-card {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        height: auto !important;
        max-height: none !important;
    }

    /* 리소스 평균 내부: 가로 1줄 */
    body.kiosk-v2.kiosk-mode #total-summary-avg-card .flex.items-center.justify-around {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-around !important;
        grid-template-columns: unset !important;
        grid-template-rows: unset !important;
    }

    /* 도넛 크기 (가로 배치) */
    body.kiosk-v2.kiosk-mode #total-summary-avg-card .w-14.h-14 {
        width: 6rem !important;
        height: 6rem !important;
    }
    body.kiosk-v2.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-xs {
        font-size: 1.25rem !important;
        font-weight: 700 !important;
    }
    body.kiosk-v2.kiosk-mode #total-summary-avg-card .w-14.h-14 .text-\[8px\] {
        font-size: 0.75rem !important;
    }

    /* Row 3-7: 차트 - full width */
    body.kiosk-v2.kiosk-mode #total-summary-chart {
        grid-column: 1 / -1 !important;
        grid-row: 3 / 8 !important;
    }

    /* Row 8: Top 5 - col 1-2 */
    body.kiosk-v2.kiosk-mode #resource-top5-card {
        grid-column: 1 / 3 !important;
        grid-row: 8 !important;
    }

    /* Row 9: 분포 현황 - col 1-2 (Top 5 아래, 가로) */
    body.kiosk-v2.kiosk-mode #total-summary-resource-card {
        grid-column: 1 / 3 !important;
        grid-row: 9 !important;
    }

    /* Row 8-9: 서버 목록 - col 3 (Top 5 옆부터) */
    body.kiosk-v2.kiosk-mode #total-server-list {
        grid-column: 3 !important;
        grid-row: 8 / 10 !important;
    }
}