@charset "UTF-8";
/**
 * GeoView-3D Main Styles (Product B)
 *
 * Cesium 기반 3D 뷰어의 레이아웃 보정 및 KRDS 프레임워크 오버라이드.
 * sgpLayout.jsp의 기존 KRDS/SGP 프레임워크 클래스를 기반으로 하며,
 * 제품 고유 보정(레이아웃 격리, 로딩 스크린, 페이지네이션 등)만 포함한다.
 *
 * @see sgp/thm/thm_common.css (원본 패턴)
 */

/* ========================================
   CSS Custom Properties
   ======================================== */
:root {
    /* 색상 */
    --gv3d-bg-dark: #0a162b;
    --gv3d-bg-overlay: rgba(10, 22, 43, 0.85);
    --gv3d-color-primary: #2196F3;
    --gv3d-color-primary-light: #64B5F6;
    --gv3d-color-primary-bg: rgba(33, 150, 243, 0.12);
    --gv3d-color-accent: #FFC107;
    --gv3d-color-danger: #f04452;
    --gv3d-color-success: #4CAF50;
    --gv3d-color-text: #ffffff;
    --gv3d-color-text-sub: rgba(255, 255, 255, 0.75);
    --gv3d-color-text-muted: #aaaaaa;
    --gv3d-color-text-disabled: #5a616a;
    --gv3d-color-border: rgba(255, 255, 255, 0.15);
    --gv3d-color-border-dark: rgba(255, 255, 255, 0.08);

    /* 레이아웃 */
    --gv3d-header-height: 52px;
    --gv3d-footer-height: 32px;
    --gv3d-sidebar-width: 320px;
    --gv3d-dashboard-width: 400px;
    --gv3d-panel-width: 360px;
    --gv3d-toolbar-size: 40px;

    /* z-index 계층 */
    --gv3d-z-map: 1;
    --gv3d-z-footer: 50;
    --gv3d-z-panel: 100;
    --gv3d-z-toolbox: 100;
    --gv3d-z-header: 200;
    --gv3d-z-modal: 500;
    --gv3d-z-overlay: 500;
    --gv3d-z-loading: 9999;

    /* 트랜지션 */
    --gv3d-transition-fast: 0.2s ease;
    --gv3d-transition-normal: 0.3s ease;

    /* 그림자 */
    --gv3d-shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.25);
    --gv3d-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.35);
    --gv3d-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.45);

    /* 둥근 모서리 */
    --gv3d-radius-sm: 4px;
    --gv3d-radius-md: 8px;
    --gv3d-radius-lg: 12px;
}


/* ========================================
   Reset & Base
   ======================================== */
html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    font-family: 'Pretendard', 'Noto Sans KR', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 14px;
    color: var(--gv3d-color-text);
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


/* ========================================
   레이아웃 래퍼
   ======================================== */
#wrap,
.map_layout,
.map_canvas {
    height: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 0 !important;
}


/* ========================================
   Map Canvas & Cesium Container
   ======================================== */
#cesiumContainer,
#cesiumContainer2 {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

/* #map 레이아웃 격리 - 외부 요소 영향 차단 */
#map {
    position: relative;
    flex: 1;
    width: 100%;
    height: 100%;
    overflow: hidden;
    contain: size layout style;
    display: block;
}


/* ========================================
   Loading Screen
   ======================================== */
#cesiumLoadingScreen {
    position: absolute;
    inset: 0;
    z-index: var(--gv3d-z-loading);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--gv3d-bg-dark);
    transition: opacity var(--gv3d-transition-normal);
}

#cesiumLoadingScreen.is-hidden {
    opacity: 0;
    pointer-events: none;
}

.gv3d-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--gv3d-color-border);
    border-top-color: var(--gv3d-color-primary);
    border-radius: 50%;
    animation: gv3d-spin 0.8s linear infinite;
}

@keyframes gv3d-spin {
    to { transform: rotate(360deg); }
}


/* ========================================
   KRDS Modal Overrides
   ======================================== */

/* 백드롭 숨기기 - 패널 형태이므로 배경 어둡게 하지 않음 */
.krds-modal.gv3d-panel .modal-back {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* 모달 콘텐츠 기본 스타일링 */
.krds-modal.gv3d-panel .modal-conts {
    padding: 16px 20px;
    color: var(--gv3d-color-text);
}

.krds-modal.gv3d-panel .modal-conts .list-zone {
    margin-bottom: 16px;
    background: transparent;
}

.krds-modal.gv3d-panel .modal-conts .item-box {
    background: transparent;
}

/* 모달 표시 상태 */
.krds-modal.gv3d-panel.modal-show {
    display: block !important;
}

.krds-modal.gv3d-panel.modal-hidden {
    display: none !important;
}


/* ========================================
   Pagination (KRDS override)
   ======================================== */
.krds-pagination.small {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    row-gap: 6px;
    column-gap: 8px;
}

.krds-pagination.small .page-navi.prev,
.krds-pagination.small .page-navi.next {
    order: 1;
}

.krds-pagination.small .page-links {
    order: 2;
    flex-basis: 100%;
    display: flex;
    justify-content: center;
}


/* ========================================
   Common Utility
   ======================================== */
.gv3d-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.gv3d-hidden {
    display: none !important;
}


/* ========================================
   Animations
   ======================================== */
@keyframes gv3d-fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes gv3d-slideUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes gv3d-slideIn {
    from {
        opacity: 0;
        transform: translateX(-10px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes gv3d-slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


/* ========================================
   Responsive (Tablet+)
   ======================================== */
@media (min-width: 768px) {
    :root {
        --gv3d-sidebar-width: 360px;
        --gv3d-dashboard-width: 420px;
        --gv3d-panel-width: 400px;
    }
}
