/* ══════════════════════════════════════════════════════════
   Gnews CSS  |  /html/gnews/css/gnews.css
   그누보드5 /html/gnews/ 독립 설치형 뉴스 테마
   ══════════════════════════════════════════════════════════ */

/* ── CSS 변수 ─────────────────────────────────────────── */
:root {
    /* 색상 – 이 블록만 수정하면 전체 테마 색 변경 가능 */
    --gn-red:        #d32f2f;
    --gn-red-dark:   #b71c1c;
    --gn-navy:       #0d1b2a;
    --gn-navy-mid:   #1b2a3b;
    --gn-accent:     #f5a623;
    --gn-accent2:    #4caf50;

    /* 텍스트 */
    --gn-text:       #1a1a1a;
    --gn-text-sub:   #555;
    --gn-text-mute:  #888;
    --gn-text-light: #aaa;

    /* 배경 / 표면 */
    --gn-bg:         #f3f4f6;
    --gn-surface:    #ffffff;
    --gn-border:     #e2e4e8;

    /* 구조 */
    --gn-container:  1260px;
    --gn-sidebar:    298px;
    --gn-radius:     6px;
    --gn-shadow:     0 1px 6px rgba(0,0,0,.08);
    --gn-shadow-md:  0 4px 16px rgba(0,0,0,.11);
    --gn-shadow-lg:  0 8px 32px rgba(0,0,0,.14);

    /* 폰트 */
    --gn-font-body:    'Noto Sans KR', sans-serif;
    --gn-font-title:   'DM Serif Display', 'Noto Sans KR', serif;
    --gn-font-display: 'Bebas Neue', sans-serif;

    /* 전환 */
    --gn-tr: .2s ease;
}

/* ── 리셋 ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body { font-family: var(--gn-font-body); background: var(--gn-bg); color: var(--gn-text); line-height: 1.65; word-break: keep-all; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ── 컨테이너 ─────────────────────────────────────────── */
.gn-container { max-width: var(--gn-container); margin: 0 auto; padding: 0 20px; }

/* ══════════════════════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════════════════════ */
.gn-topbar { background: var(--gn-navy); color: #8090a0; font-size: .75rem; padding: 5px 0; border-bottom: 1px solid #1e2d3d; }
.gn-topbar-inner { display: flex; justify-content: space-between; align-items: center; }
.gn-date { color: #607080; }
.gn-topbar-right a { color: #8090a0; margin-left: 14px; transition: color var(--gn-tr); }
.gn-topbar-right a:hover { color: #fff; }

/* ══════════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════════ */
.gn-header { background: var(--gn-surface); border-bottom: 3px solid var(--gn-red); padding: 14px 0; position: sticky; top: 0; z-index: 200; box-shadow: var(--gn-shadow-md); }
.gn-header-inner { display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center; }

/* 로고 */
.gn-logo a { display: inline-block; }
.gn-logo-main { font-family: var(--gn-font-display); font-size: 2.5rem; color: var(--gn-navy); letter-spacing: 2px; line-height: 1; display: block; }
.gn-logo-main em { color: var(--gn-red); font-style: normal; }
.gn-logo-sub { font-size: .62rem; color: var(--gn-text-mute); letter-spacing: 4px; text-transform: uppercase; margin-top: 2px; display: block; }

/* 헤더 배너 */
.gn-header-banner { text-align: center; }
.gn-ad-placeholder { border: 1.5px dashed var(--gn-border); background: #fafafa; height: 90px; display: flex; align-items: center; justify-content: center; color: var(--gn-text-light); font-size: .72rem; border-radius: var(--gn-radius); letter-spacing: 1px; }

/* 헤더 검색 */
.gn-hs-wrap { display: flex; border: 2px solid var(--gn-border); border-radius: 24px; overflow: hidden; transition: border-color var(--gn-tr); }
.gn-hs-wrap:focus-within { border-color: var(--gn-red); }
.gn-hs-input { padding: 8px 16px; border: none; outline: none; font-size: .88rem; width: 200px; font-family: inherit; background: transparent; }
.gn-hs-btn { padding: 8px 14px; background: var(--gn-red); color: #fff; transition: background var(--gn-tr); display: flex; align-items: center; }
.gn-hs-btn:hover { background: var(--gn-red-dark); }

/* ══════════════════════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════════════════════ */
.gn-nav { background: var(--gn-navy); position: sticky; top: 79px; z-index: 199; }
.gn-nav-inner { display: flex; align-items: center; position: relative; }
.gn-nav-list { display: flex; flex: 1; }
.gn-nav-link {
    display: block;
    padding: 13px 17px;
    color: #b0bec5;
    font-size: .88rem;
    font-weight: 500;
    letter-spacing: .2px;
    transition: color var(--gn-tr), background var(--gn-tr);
    position: relative;
}
.gn-nav-link::after {
    content: '';
    position: absolute;
    bottom: 0; left: 50%; right: 50%;
    height: 3px;
    background: var(--gn-red);
    transition: left .22s, right .22s;
}
.gn-nav-link:hover,
.gn-nav-link.is-active { color: #fff; }
.gn-nav-link:hover::after,
.gn-nav-link.is-active::after { left: 0; right: 0; }

/* 모바일 토글 */
.gn-nav-toggle { display: none; padding: 12px 8px; color: #fff; flex-direction: column; gap: 5px; }
.gn-nav-toggle span { display: block; width: 22px; height: 2px; background: #fff; transition: .3s; }
.gn-nav-toggle.is-open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.gn-nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.gn-nav-toggle.is-open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

.gn-mobile-search-btn { display: none; color: #b0bec5; padding: 12px; margin-left: auto; }
.gn-mobile-search-wrap { display: none; background: #162032; padding: 10px 16px; }
.gn-mobile-search-form { display: flex; gap: 6px; }
.gn-mobile-search-form input { flex: 1; padding: 9px 12px; border: 1px solid #2a3f52; background: #0d1b2a; color: #fff; border-radius: var(--gn-radius); font-family: inherit; font-size: .85rem; outline: none; }
.gn-mobile-search-form button { padding: 9px 16px; background: var(--gn-red); color: #fff; border-radius: var(--gn-radius); font-size: .82rem; font-weight: 600; }
.gn-mobile-search-wrap.is-open { display: block; }

/* ══════════════════════════════════════════════════════════
   BREAKING NEWS TICKER
══════════════════════════════════════════════════════════ */
.gn-ticker-bar { display: flex; align-items: center; background: #fff; border-bottom: 1px solid var(--gn-border); overflow: hidden; height: 36px; }
.gn-ticker-label { background: var(--gn-red); color: #fff; font-size: .72rem; font-weight: 700; letter-spacing: 2px; padding: 0 14px; height: 100%; display: flex; align-items: center; flex-shrink: 0; white-space: nowrap; }
.gn-ticker-outer { flex: 1; overflow: hidden; position: relative; }
.gn-ticker-inner { display: inline-flex; gap: 60px; white-space: nowrap; animation: gnTicker 28s linear infinite; }
.gn-ticker-item a { font-size: .82rem; color: var(--gn-text-sub); padding: 0 4px; }
.gn-ticker-item a::before { content: '●'; color: var(--gn-red); margin-right: 8px; font-size: .5rem; vertical-align: middle; }
.gn-ticker-item a:hover { color: var(--gn-red); }
@keyframes gnTicker { 0% { transform: translateX(100vw); } 100% { transform: translateX(-100%); } }

/* ══════════════════════════════════════════════════════════
   HERO SLIDER
══════════════════════════════════════════════════════════ */
.gn-slider { position: relative; height: 520px; background: var(--gn-navy); overflow: hidden; }
.gn-slider-track { width: 100%; height: 100%; position: relative; }
.gn-slide { position: absolute; inset: 0; opacity: 0; transition: opacity .65s ease; }
.gn-slide.is-active { opacity: 1; z-index: 1; }
.gn-slide-bg {
    width: 100%; height: 100%;
    background-size: cover; background-position: center;
    transform: scale(1.06);
    transition: transform 7s ease;
    background-color: var(--gn-navy-mid);
}
.gn-slide.is-active .gn-slide-bg { transform: scale(1); }
.gn-slide-scrim { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.35) 55%, transparent 100%); }
.gn-slide-body { position: absolute; bottom: 56px; left: 56px; max-width: 580px; color: #fff; z-index: 2; }
.gn-slide-cat-badge {
    display: inline-block; padding: 4px 12px;
    font-size: .7rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
    border-radius: 2px; margin-bottom: 14px; color: #fff;
    transition: opacity var(--gn-tr);
}
.gn-slide-cat-badge:hover { opacity: .85; color: #fff; }
.gn-slide-title { font-family: var(--gn-font-title); font-size: 2rem; line-height: 1.3; margin-bottom: 12px; text-shadow: 0 2px 10px rgba(0,0,0,.4); }
.gn-slide-title a { color: #fff; }
.gn-slide-title a:hover { color: rgba(255,255,255,.88); }
.gn-slide-excerpt { font-size: .88rem; color: rgba(255,255,255,.78); margin-bottom: 14px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gn-slide-meta { font-size: .75rem; color: rgba(255,255,255,.55); display: flex; gap: 14px; }

/* 슬라이더 컨트롤 */
.gn-slider-arrow {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 40px; height: 40px;
    background: rgba(255,255,255,.18); color: #fff; border-radius: 50%;
    font-size: 15px; display: flex; align-items: center; justify-content: center;
    z-index: 10; backdrop-filter: blur(4px);
    transition: background var(--gn-tr), transform var(--gn-tr);
}
.gn-slider-arrow:hover { background: var(--gn-red); }
.gn-slider-arrow.prev { left: 20px; }
.gn-slider-arrow.next { right: 20px; }
.gn-slider-dots { position: absolute; bottom: 18px; right: 24px; display: flex; gap: 6px; z-index: 10; }
.gn-dot { width: 8px; height: 8px; border-radius: 4px; background: rgba(255,255,255,.35); transition: width .25s, background .25s; }
.gn-dot.is-active { width: 24px; background: #fff; }

/* ══════════════════════════════════════════════════════════
   MAIN LAYOUT
══════════════════════════════════════════════════════════ */
.gn-main-wrap { padding: 28px 20px; }
.gn-main-grid { display: grid; grid-template-columns: 1fr var(--gn-sidebar); gap: 28px; align-items: start; }

/* ══════════════════════════════════════════════════════════
   NEWS SECTION
══════════════════════════════════════════════════════════ */
.gn-section { margin-bottom: 38px; }
.gn-section-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; border-bottom: 1px solid var(--gn-border); padding-bottom: 10px; }
.gn-section-title {
    font-family: var(--gn-font-title); font-size: 1.25rem;
    color: var(--gn-navy);
    border-left: 4px solid var(--cat-color, var(--gn-red));
    padding-left: 12px;
    display: flex; align-items: center; gap: 6px;
}
.gn-section-icon { font-size: 1rem; }
.gn-more-link { font-size: .77rem; color: var(--gn-text-mute); border: 1px solid var(--gn-border); padding: 4px 10px; border-radius: 20px; transition: all var(--gn-tr); }
.gn-more-link:hover { border-color: var(--gn-red); color: var(--gn-red); }

.gn-section-body { display: grid; grid-template-columns: 1fr 256px; gap: 18px; align-items: start; }

/* 메인 카드 (대형) */
.gn-card-lg { background: var(--gn-surface); border-radius: var(--gn-radius); overflow: hidden; box-shadow: var(--gn-shadow); transition: box-shadow var(--gn-tr), transform var(--gn-tr); }
.gn-card-lg:hover { box-shadow: var(--gn-shadow-md); transform: translateY(-2px); }
.gn-card-img-wrap { display: block; aspect-ratio: 16/9; overflow: hidden; }
.gn-card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.gn-card-lg:hover .gn-card-img-wrap img { transform: scale(1.04); }
.gn-card-no-img { width: 100%; aspect-ratio: 16/9; background: color-mix(in srgb, var(--cat-color, var(--gn-red)) 12%, white); display: flex; align-items: center; justify-content: center; font-size: 3.5rem; }
.gn-card-info { padding: 16px; }
.gn-cat-badge { font-size: .68rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; }
.gn-card-title { font-family: var(--gn-font-title); font-size: 1.1rem; line-height: 1.45; margin: 7px 0 9px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gn-card-title a:hover { color: var(--gn-red); }
.gn-card-excerpt { font-size: .83rem; color: var(--gn-text-sub); line-height: 1.6; margin-bottom: 10px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gn-card-meta { font-size: .72rem; color: var(--gn-text-light); display: flex; gap: 12px; }

/* 서브 뉴스 목록 */
.gn-sub-list { background: var(--gn-surface); border-radius: var(--gn-radius); box-shadow: var(--gn-shadow); overflow: hidden; }
.gn-sub-item { display: flex; gap: 10px; padding: 11px 13px; border-bottom: 1px solid var(--gn-border); align-items: flex-start; transition: background var(--gn-tr); }
.gn-sub-item:last-child { border-bottom: none; }
.gn-sub-item:hover { background: #f9fafb; }
.gn-sub-thumb { flex-shrink: 0; width: 72px; height: 52px; border-radius: 4px; overflow: hidden; display: block; }
.gn-sub-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.gn-sub-item:hover .gn-sub-thumb img { transform: scale(1.06); }
.gn-sub-text { flex: 1; min-width: 0; }
.gn-sub-title { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; font-size: .83rem; font-weight: 500; line-height: 1.45; color: var(--gn-text); margin-bottom: 4px; }
.gn-sub-title:hover { color: var(--gn-red); }
.gn-sub-date { font-size: .7rem; color: var(--gn-text-light); }

/* ══════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════ */
.gn-sidebar { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 110px; }

.gn-widget { background: var(--gn-surface); border-radius: var(--gn-radius); box-shadow: var(--gn-shadow); padding: 16px 18px; }
.gn-widget-head { font-size: .92rem; font-weight: 700; color: var(--gn-navy); padding-bottom: 12px; margin-bottom: 13px; border-bottom: 2px solid var(--gn-border); display: flex; align-items: center; gap: 5px; }
.gn-widget-icon { font-size: .95rem; }
.gn-widget-more { margin-left: auto; font-size: .7rem; color: var(--gn-text-light); border: 1px solid var(--gn-border); padding: 2px 8px; border-radius: 10px; transition: all var(--gn-tr); }
.gn-widget-more:hover { border-color: var(--gn-red); color: var(--gn-red); }

/* 검색 위젯 */
.gn-widget-search { padding: 12px; }
.gn-sb-search-wrap { display: flex; border: 2px solid var(--gn-border); border-radius: var(--gn-radius); overflow: hidden; transition: border-color var(--gn-tr); }
.gn-sb-search-wrap:focus-within { border-color: var(--gn-red); }
.gn-sb-input { flex: 1; padding: 9px 12px; border: none; outline: none; font-size: .85rem; font-family: inherit; background: transparent; }
.gn-sb-search-btn { padding: 9px 13px; background: var(--gn-red); font-size: 1rem; transition: background var(--gn-tr); }
.gn-sb-search-btn:hover { background: var(--gn-red-dark); }

/* 인기뉴스 */
.gn-popular-list { display: flex; flex-direction: column; gap: 7px; }
.gn-popular-item { display: flex; align-items: flex-start; gap: 9px; }
.gn-rank { width: 22px; height: 22px; border-radius: 4px; background: var(--gn-border); color: var(--gn-text-mute); font-size: .7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.gn-rank.top3 { background: var(--gn-red); color: #fff; }
.gn-popular-title { font-size: .8rem; line-height: 1.4; color: var(--gn-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gn-popular-title:hover { color: var(--gn-red); }

/* 로그인 위젯 */
.gn-widget-member { }
.gn-sb-login { display: flex; flex-direction: column; gap: 9px; }
.gn-form-input { padding: 9px 11px; border: 1.5px solid var(--gn-border); border-radius: var(--gn-radius); font-size: .85rem; font-family: inherit; outline: none; transition: border-color var(--gn-tr); width: 100%; }
.gn-form-input:focus { border-color: var(--gn-red); }
.gn-form-check-sm { font-size: .77rem; display: flex; align-items: center; gap: 5px; color: var(--gn-text-sub); }
.gn-sb-login-links { text-align: center; font-size: .75rem; color: var(--gn-text-light); }
.gn-sb-login-links a { color: var(--gn-text-mute); margin: 0 3px; }
.gn-sb-login-links a:hover { color: var(--gn-red); }

.gn-member-info { text-align: center; }
.gn-member-avatar { width: 52px; height: 52px; background: linear-gradient(135deg, var(--gn-red), #ff6b6b); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 700; margin: 0 auto 10px; }
.gn-member-name { font-weight: 700; font-size: .95rem; }
.gn-member-id { font-size: .75rem; color: var(--gn-text-mute); margin: 2px 0 12px; }
.gn-member-btns { display: flex; gap: 7px; justify-content: center; }

/* 커뮤니티 */
.gn-comm-list { display: flex; flex-direction: column; }
.gn-comm-list li { display: flex; flex-direction: column; padding: 7px 0; border-bottom: 1px solid #f3f4f6; gap: 3px; }
.gn-comm-list li:last-child { border-bottom: none; }
.gn-comm-title { font-size: .81rem; color: var(--gn-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.gn-comm-title:hover { color: var(--gn-red); }
.gn-comm-meta { font-size: .68rem; color: var(--gn-text-light); }
.gn-comm-meta em { color: var(--gn-red); font-style: normal; }

/* 뉴스레터 */
.gn-widget-newsletter { background: linear-gradient(140deg, var(--gn-navy), #162032); }
.gn-widget-newsletter .gn-widget-head { color: #fff; border-color: rgba(255,255,255,.12); }
.gn-newsletter-desc { font-size: .8rem; color: rgba(255,255,255,.6); margin-bottom: 12px; line-height: 1.6; }
.gn-newsletter-input { padding: 9px 12px; border: none; border-radius: var(--gn-radius); width: 100%; font-family: inherit; font-size: .82rem; background: rgba(255,255,255,.13); color: #fff; outline: none; margin-bottom: 8px; }
.gn-newsletter-input::placeholder { color: rgba(255,255,255,.4); }
.gn-newsletter-input:focus { background: rgba(255,255,255,.2); }

/* 카테고리 */
.gn-cat-list { display: flex; flex-direction: column; }
.gn-cat-item { display: flex; align-items: center; gap: 8px; padding: 8px 2px; font-size: .83rem; color: var(--gn-text); border-bottom: 1px solid #f3f4f6; transition: color var(--gn-tr); }
.gn-cat-list li:last-child .gn-cat-item { border-bottom: none; }
.gn-cat-item:hover { color: var(--gn-red); }
.gn-cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.gn-cat-arrow { margin-left: auto; color: var(--gn-text-light); }

/* ══════════════════════════════════════════════════════════
   BUTTONS (공통)
══════════════════════════════════════════════════════════ */
.gn-btn { display: inline-flex; align-items: center; justify-content: center; padding: 9px 18px; border-radius: var(--gn-radius); font-size: .85rem; font-weight: 600; transition: all var(--gn-tr); border: 1.5px solid transparent; cursor: pointer; font-family: inherit; }
.gn-btn-primary { background: var(--gn-red); color: #fff; }
.gn-btn-primary:hover { background: var(--gn-red-dark); color: #fff; }
.gn-btn-accent { background: var(--gn-accent); color: #fff; }
.gn-btn-accent:hover { filter: brightness(.92); color: #fff; }
.gn-btn-dark { background: var(--gn-navy); color: #fff; }
.gn-btn-dark:hover { background: #22334f; color: #fff; }
.gn-btn-outline { border-color: var(--gn-border); color: var(--gn-text-mute); }
.gn-btn-outline:hover { border-color: var(--gn-red); color: var(--gn-red); }
.gn-btn-full { width: 100%; }
.gn-btn-sm { padding: 6px 12px; font-size: .78rem; }

/* ══════════════════════════════════════════════════════════
   LOGIN MODAL
══════════════════════════════════════════════════════════ */
.gn-modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 9000; align-items: center; justify-content: center; backdrop-filter: blur(3px); }
.gn-modal-overlay.is-open { display: flex; }
.gn-modal-box { background: #fff; border-radius: 12px; padding: 32px; width: 380px; max-width: calc(100vw - 32px); position: relative; box-shadow: 0 24px 64px rgba(0,0,0,.22); animation: gnModalIn .26s ease; }
@keyframes gnModalIn { from { transform: translateY(-18px) scale(.96); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }
.gn-modal-close { position: absolute; top: 14px; right: 18px; font-size: 1.6rem; color: var(--gn-text-mute); line-height: 1; transition: color var(--gn-tr); }
.gn-modal-close:hover { color: var(--gn-red); }
.gn-modal-title { font-family: var(--gn-font-title); font-size: 1.5rem; color: var(--gn-navy); margin-bottom: 22px; }
.gn-login-form { display: flex; flex-direction: column; gap: 12px; }
.gn-form-group { display: flex; flex-direction: column; gap: 5px; }
.gn-form-group label { font-size: .78rem; font-weight: 600; color: var(--gn-text-sub); }
.gn-form-group input { padding: 11px 13px; border: 1.5px solid var(--gn-border); border-radius: var(--gn-radius); font-size: .9rem; font-family: inherit; outline: none; transition: border-color var(--gn-tr); }
.gn-form-group input:focus { border-color: var(--gn-red); }
.gn-form-check { font-size: .8rem; display: flex; align-items: center; gap: 6px; }
.gn-modal-links { text-align: center; font-size: .78rem; color: var(--gn-text-light); margin-top: 4px; }
.gn-modal-links a { color: var(--gn-text-sub); margin: 0 5px; }
.gn-modal-links a:hover { color: var(--gn-red); }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.gn-footer { background: var(--gn-navy); color: #6b7e90; margin-top: 50px; }
.gn-footer-top { border-bottom: 1px solid rgba(255,255,255,.07); padding: 40px 0; }
.gn-footer-grid { display: grid; grid-template-columns: 220px 1fr; gap: 40px; max-width: var(--gn-container); margin: 0 auto; padding: 0 20px; }
.gn-footer-logo { font-family: var(--gn-font-display); font-size: 2.2rem; color: #fff; letter-spacing: 2px; display: inline-block; margin-bottom: 6px; }
.gn-footer-logo em { color: var(--gn-red); font-style: normal; }
.gn-footer-brand p { font-size: .78rem; color: #4a6070; margin-top: 3px; }
.gn-footer-desc { margin-top: 10px !important; line-height: 1.7; }
.gn-footer-nav { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.gn-footer-nav-col h4 { font-size: .82rem; font-weight: 700; color: #8090a0; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 10px; }
.gn-footer-nav-col li { margin-bottom: 6px; }
.gn-footer-nav-col a { font-size: .78rem; color: #4a6070; transition: color var(--gn-tr); }
.gn-footer-nav-col a:hover { color: #fff; }
.gn-footer-bottom { padding: 18px 0; }
.gn-footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; max-width: var(--gn-container); margin: 0 auto; padding: 0 20px; flex-wrap: wrap; gap: 8px; }
.gn-footer-policy { display: flex; gap: 10px; font-size: .75rem; }
.gn-footer-policy a { color: #4a6070; }
.gn-footer-policy a:hover { color: #8090a0; }
.gn-copyright { font-size: .74rem; color: #354555; }
.gn-copyright a { color: #4a6070; }

/* ══════════════════════════════════════════════════════════
   SCROLL TOP
══════════════════════════════════════════════════════════ */
.gn-scroll-top {
    position: fixed; bottom: 26px; right: 26px;
    width: 44px; height: 44px;
    background: var(--gn-navy); color: #fff; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--gn-shadow-lg); z-index: 400;
    opacity: 0; transform: translateY(12px);
    transition: opacity .3s, transform .3s, background var(--gn-tr);
    pointer-events: none;
}
.gn-scroll-top.is-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.gn-scroll-top:hover { background: var(--gn-red); }

/* ══════════════════════════════════════════════════════════
   BOARD PAGE (게시판 목록 / 뷰)
══════════════════════════════════════════════════════════ */
.gn-bbs-wrap { max-width: var(--gn-container); margin: 0 auto; padding: 26px 20px; }
.gn-bbs-hd { margin-bottom: 24px; }
.gn-bbs-title { font-family: var(--gn-font-title); font-size: 1.6rem; color: var(--gn-navy); border-left: 5px solid var(--gn-red); padding-left: 14px; margin-bottom: 5px; }
.gn-bbs-desc { font-size: .83rem; color: var(--gn-text-mute); }

/* 카테고리 탭 */
.gn-cat-tabs { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 20px; }
.gn-cat-tab { padding: 5px 15px; border-radius: 20px; font-size: .8rem; font-weight: 500; border: 1.5px solid var(--gn-border); color: var(--gn-text-sub); transition: all var(--gn-tr); }
.gn-cat-tab:hover, .gn-cat-tab.is-active { background: var(--gn-red); border-color: var(--gn-red); color: #fff; }

/* 뉴스 그리드 (3열) */
.gn-list-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 28px; }
.gn-list-card { background: var(--gn-surface); border-radius: var(--gn-radius); overflow: hidden; box-shadow: var(--gn-shadow); transition: box-shadow var(--gn-tr), transform var(--gn-tr); }
.gn-list-card:hover { box-shadow: var(--gn-shadow-md); transform: translateY(-2px); }
.gn-lc-img { display: block; aspect-ratio: 16/9; overflow: hidden; }
.gn-lc-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.gn-list-card:hover .gn-lc-img img { transform: scale(1.04); }
.gn-lc-no-img { width: 100%; aspect-ratio: 16/9; background: #f5f5f7; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; }
.gn-lc-body { padding: 14px; }
.gn-lc-cat { font-size: .68rem; color: var(--gn-red); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 5px; }
.gn-lc-title { display: block; font-size: .9rem; font-weight: 600; line-height: 1.45; margin-bottom: 8px; color: var(--gn-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gn-lc-title:hover { color: var(--gn-red); }
.gn-lc-meta { font-size: .71rem; color: var(--gn-text-light); display: flex; gap: 10px; }

/* 페이지네이션 */
.gn-paging { display: flex; justify-content: center; gap: 4px; margin: 26px 0; }
.gn-paging a, .gn-paging span { display: flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 8px; border-radius: var(--gn-radius); font-size: .83rem; border: 1px solid var(--gn-border); background: var(--gn-surface); color: var(--gn-text-sub); transition: all var(--gn-tr); }
.gn-paging a:hover { background: var(--gn-red); color: #fff; border-color: var(--gn-red); }
.gn-paging .pg_current { background: var(--gn-red); color: #fff; border-color: var(--gn-red); }

/* 목록 툴바 */
.gn-bbs-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 20px; }
.gn-bbs-search { display: flex; gap: 6px; }
.gn-bbs-sel { padding: 8px 10px; border: 1.5px solid var(--gn-border); border-radius: var(--gn-radius); font-family: inherit; font-size: .82rem; background: #fff; outline: none; }
.gn-bbs-stx { padding: 8px 12px; border: 1.5px solid var(--gn-border); border-radius: var(--gn-radius); font-family: inherit; font-size: .83rem; outline: none; transition: border-color var(--gn-tr); width: 220px; }
.gn-bbs-stx:focus { border-color: var(--gn-red); }
.gn-bbs-sbtn { padding: 8px 16px; background: var(--gn-navy); color: #fff; border-radius: var(--gn-radius); font-size: .83rem; font-weight: 600; transition: background var(--gn-tr); }
.gn-bbs-sbtn:hover { background: var(--gn-red); }
.gn-btn-write { padding: 9px 20px; background: var(--gn-red); color: #fff; border-radius: var(--gn-radius); font-size: .83rem; font-weight: 600; white-space: nowrap; transition: background var(--gn-tr); }
.gn-btn-write:hover { background: var(--gn-red-dark); color: #fff; }

/* 뷰 페이지 */
.gn-view-outer { max-width: 860px; margin: 0 auto; }
.gn-view-breadcrumb { font-size: .76rem; color: var(--gn-text-mute); margin-bottom: 20px; }
.gn-view-breadcrumb a { color: var(--gn-text-mute); }
.gn-view-breadcrumb a:hover { color: var(--gn-red); }
.gn-view-breadcrumb span { margin: 0 5px; }
.gn-view-hd { background: var(--gn-surface); border-radius: var(--gn-radius); padding: 24px 28px; box-shadow: var(--gn-shadow); margin-bottom: 4px; }
.gn-view-cat { font-size: .7rem; color: var(--gn-red); font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 10px; }
.gn-view-title { font-family: var(--gn-font-title); font-size: 1.9rem; line-height: 1.35; color: var(--gn-navy); margin-bottom: 16px; }
.gn-view-meta { display: flex; gap: 16px; font-size: .78rem; color: var(--gn-text-mute); flex-wrap: wrap; }
.gn-view-meta span { display: flex; align-items: center; gap: 4px; }
.gn-view-thumb { margin: 0 0 4px; border-radius: var(--gn-radius); overflow: hidden; box-shadow: var(--gn-shadow); }
.gn-view-thumb img { width: 100%; }
.gn-view-body { background: var(--gn-surface); padding: 28px; border-radius: var(--gn-radius); box-shadow: var(--gn-shadow); }
.gn-view-content { font-size: .94rem; line-height: 1.9; color: var(--gn-text); }
.gn-view-content img { max-width: 100%; border-radius: 4px; margin: 12px 0; }
.gn-view-content p { margin-bottom: 16px; }
.gn-view-content h2, .gn-view-content h3 { font-family: var(--gn-font-title); margin: 22px 0 10px; color: var(--gn-navy); }
.gn-view-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--gn-border); }
.gn-view-tag { padding: 4px 12px; background: #f3f4f6; border-radius: 20px; font-size: .76rem; color: var(--gn-text-sub); transition: all var(--gn-tr); }
.gn-view-tag:hover { background: var(--gn-red); color: #fff; }

.gn-view-share { display: flex; align-items: center; gap: 10px; padding: 18px 0; border-top: 1px solid var(--gn-border); border-bottom: 1px solid var(--gn-border); margin: 20px 0; }
.gn-share-label { font-size: .82rem; font-weight: 600; color: var(--gn-text-sub); }
.gn-share-btns { display: flex; gap: 7px; }
.gn-share-btn { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: opacity var(--gn-tr), transform var(--gn-tr); }
.gn-share-btn:hover { opacity: .82; transform: scale(1.09); }
.gn-share-fb { background: #1877f2; color: #fff; }
.gn-share-tw { background: #000; color: #fff; }
.gn-share-copy { background: var(--gn-navy); color: #fff; border: none; cursor: pointer; }

.gn-view-actions { display: flex; gap: 7px; margin-bottom: 16px; }
.gn-btn-edit { padding: 7px 15px; background: var(--gn-navy); color: #fff; border-radius: var(--gn-radius); font-size: .8rem; font-weight: 600; }
.gn-btn-del { padding: 7px 15px; background: #fee2e2; color: var(--gn-red); border-radius: var(--gn-radius); font-size: .8rem; font-weight: 600; transition: all var(--gn-tr); }
.gn-btn-del:hover { background: var(--gn-red); color: #fff; }

.gn-view-nav { border: 1px solid var(--gn-border); border-radius: var(--gn-radius); overflow: hidden; margin: 20px 0; }
.gn-view-nav-item { display: flex; justify-content: space-between; align-items: center; padding: 11px 16px; border-bottom: 1px solid var(--gn-border); gap: 14px; transition: background var(--gn-tr); }
.gn-view-nav-item:last-child { border-bottom: none; }
.gn-view-nav-item:hover { background: #f9fafb; }
.gn-nav-dir { font-size: .72rem; color: var(--gn-red); font-weight: 700; white-space: nowrap; }
.gn-nav-subj { font-size: .83rem; color: var(--gn-text); text-align: right; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.gn-view-footer { text-align: center; margin: 20px 0 30px; }
.gn-btn-list { display: inline-block; padding: 10px 28px; background: var(--gn-navy); color: #fff; border-radius: var(--gn-radius); font-weight: 600; transition: background var(--gn-tr); }
.gn-btn-list:hover { background: var(--gn-red); color: #fff; }

/* 댓글 */
.gn-comment-wrap { margin-top: 30px; padding-top: 24px; border-top: 2px solid var(--gn-border); }
.gn-comment-title { font-family: var(--gn-font-title); font-size: 1.2rem; color: var(--gn-navy); margin-bottom: 18px; }
.gn-comment-title span { color: var(--gn-red); }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    :root { --gn-sidebar: 270px; }
    .gn-footer-nav { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
    .gn-main-grid { grid-template-columns: 1fr; }
    .gn-sidebar { position: static; display: grid; grid-template-columns: repeat(2, 1fr); }
    .gn-section-body { grid-template-columns: 1fr; }
    .gn-sub-list { display: grid; grid-template-columns: repeat(2, 1fr); }
    .gn-header-inner { grid-template-columns: auto auto; }
    .gn-header-banner { display: none; }
    .gn-list-grid { grid-template-columns: repeat(2, 1fr); }
    .gn-footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 660px) {
    .gn-nav-list { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--gn-navy-mid); padding: 8px 0; box-shadow: var(--gn-shadow-lg); z-index: 100; }
    .gn-nav-list.is-open { display: flex; }
    .gn-nav-toggle { display: flex; }
    .gn-mobile-search-btn { display: flex; }
    .gn-hs-btn { display: none; }
    .gn-hs-input { width: 130px; }
    .gn-slider { height: 300px; }
    .gn-slide-body { left: 20px; bottom: 36px; max-width: 280px; }
    .gn-slide-title { font-size: 1.2rem; }
    .gn-slide-excerpt { display: none; }
    .gn-sidebar { grid-template-columns: 1fr; }
    .gn-sub-list { grid-template-columns: 1fr; }
    .gn-list-grid { grid-template-columns: 1fr; }
    .gn-footer-nav { grid-template-columns: 1fr 1fr; }
    .gn-footer-bottom-inner { flex-direction: column; text-align: center; }
    .gn-view-title { font-size: 1.4rem; }
    .gn-view-hd { padding: 18px; }
    .gn-view-body { padding: 18px; }
    .gn-bbs-stx { width: 140px; }
    .gn-main-wrap { padding: 20px 0; }
}

@media (max-width: 420px) {
    .gn-header-inner { grid-template-columns: 1fr; }
    .gn-header-search { display: none; }
    .gn-logo-main { font-size: 2rem; }
}


/* ══════════════════════════════════════════════════════════
   BREADCRUMB
══════════════════════════════════════════════════════════ */
.gn-bc {
    font-size: .78rem;
    color: var(--gn-text-mute);
    padding: 12px 0 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}
.gn-bc a { color: var(--gn-text-mute); transition: color var(--gn-tr); }
.gn-bc a:hover { color: var(--gn-red); }
.gn-bc span { color: var(--gn-text-light); }

/* ══════════════════════════════════════════════════════════
   LIST PAGE
══════════════════════════════════════════════════════════ */
.gn-list-header { margin-bottom: 18px; }
.gn-list-title {
    font-family: var(--gn-font-title);
    font-size: 1.5rem;
    color: var(--gn-navy);
    border-left: 5px solid var(--gn-red);
    padding-left: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.gn-list-title-icon { font-size: 1.2rem; }
.gn-list-total {
    font-family: var(--gn-font-body);
    font-size: .78rem;
    color: var(--gn-text-light);
    font-weight: 400;
    margin-left: 6px;
}

/* 카드 그리드 */
.gn-list-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 26px;
}
.gn-list-card {
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    overflow: hidden;
    box-shadow: var(--gn-shadow);
    transition: box-shadow var(--gn-tr), transform var(--gn-tr);
    display: flex;
    flex-direction: column;
}
.gn-list-card:hover { box-shadow: var(--gn-shadow-md); transform: translateY(-2px); }

.gn-lc-img-wrap {
    display: block;
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #f0f0f2;
}
.gn-lc-img-wrap img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.gn-list-card:hover .gn-lc-img-wrap img { transform: scale(1.04); }

.gn-lc-no-img {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2.8rem;
    background: color-mix(in srgb, var(--cat-color, var(--gn-red)) 10%, white);
}

/* 카테고리 배지 (이미지 위에 표시) */
.gn-lc-cat-badge {
    position: absolute;
    top: 10px; left: 10px;
    padding: 3px 10px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #fff;
    border-radius: 3px;
    background: var(--gn-red);
}

.gn-lc-body { padding: 14px; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.gn-lc-title {
    font-size: .92rem;
    font-weight: 600;
    line-height: 1.45;
    color: var(--gn-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.gn-lc-title:hover { color: var(--gn-red); }
.gn-lc-excerpt {
    font-size: .8rem;
    color: var(--gn-text-sub);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}
.gn-lc-meta {
    font-size: .71rem;
    color: var(--gn-text-light);
    display: flex;
    gap: 10px;
    align-items: center;
    margin-top: auto;
}
.gn-lc-comment { color: var(--gn-red); }

/* 검색 + 글쓰기 툴바 */
.gn-list-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding-top: 16px;
    border-top: 1px solid var(--gn-border);
}
.gn-toolbar-search { display: flex; gap: 6px; flex: 1; }
.gn-sel {
    padding: 8px 10px;
    border: 1.5px solid var(--gn-border);
    border-radius: var(--gn-radius);
    font-family: inherit;
    font-size: .82rem;
    background: #fff;
    outline: none;
    flex-shrink: 0;
}
.gn-toolbar-input {
    flex: 1;
    padding: 8px 12px;
    border: 1.5px solid var(--gn-border);
    border-radius: var(--gn-radius);
    font-family: inherit;
    font-size: .83rem;
    outline: none;
    transition: border-color var(--gn-tr);
    min-width: 0;
}
.gn-toolbar-input:focus { border-color: var(--gn-red); }
.gn-toolbar-btn {
    padding: 8px 16px;
    background: var(--gn-navy);
    color: #fff;
    border-radius: var(--gn-radius);
    font-size: .82rem;
    font-weight: 600;
    transition: background var(--gn-tr);
    flex-shrink: 0;
}
.gn-toolbar-btn:hover { background: var(--gn-red); }
.gn-btn-write {
    padding: 9px 18px;
    background: var(--gn-red);
    color: #fff;
    border-radius: var(--gn-radius);
    font-size: .83rem;
    font-weight: 600;
    white-space: nowrap;
    transition: background var(--gn-tr);
}
.gn-btn-write:hover { background: var(--gn-red-dark); color: #fff; }

/* 빈 목록 */
.gn-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--gn-text-mute);
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    box-shadow: var(--gn-shadow);
    margin-bottom: 20px;
}
.gn-empty span { font-size: 3rem; display: block; margin-bottom: 12px; }

/* ══════════════════════════════════════════════════════════
   VIEW PAGE
══════════════════════════════════════════════════════════ */
.gn-view {
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    box-shadow: var(--gn-shadow);
    overflow: hidden;
    margin-bottom: 4px;
}

/* 뷰 헤더 */
.gn-view-head {
    padding: 28px 30px 20px;
    border-bottom: 1px solid var(--gn-border);
    position: relative;
}
.gn-view-cat {
    display: inline-block;
    padding: 4px 12px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #fff;
    border-radius: 3px;
    background: var(--gn-red);
    margin-bottom: 14px;
    transition: opacity var(--gn-tr);
}
.gn-view-cat:hover { opacity: .85; color: #fff; }
.gn-view-title {
    font-family: var(--gn-font-title);
    font-size: 1.85rem;
    line-height: 1.35;
    color: var(--gn-navy);
    margin-bottom: 16px;
    padding-right: 120px; /* 공유 버튼 공간 */
}
.gn-view-meta {
    display: flex;
    gap: 14px;
    font-size: .78rem;
    color: var(--gn-text-mute);
    flex-wrap: wrap;
    align-items: center;
}
.gn-view-meta span,
.gn-view-meta time { display: flex; align-items: center; gap: 4px; }

/* 헤더 우측 공유 버튼 */
.gn-view-share-top {
    position: absolute;
    top: 28px; right: 28px;
    display: flex;
    gap: 6px;
}

/* 썸네일 */
.gn-view-thumb { line-height: 0; }
.gn-view-thumb img { width: 100%; max-height: 480px; object-fit: cover; }

/* 본문 */
.gn-view-body {
    padding: 28px 30px;
    font-size: .96rem;
    line-height: 1.9;
    color: var(--gn-text);
    word-break: keep-all;
    overflow-wrap: break-word;
}
.gn-view-body img { max-width: 100%; height: auto; border-radius: 4px; margin: 14px 0; }
.gn-view-body p { margin-bottom: 16px; }
.gn-view-body h2, .gn-view-body h3, .gn-view-body h4 {
    font-family: var(--gn-font-title);
    color: var(--gn-navy);
    margin: 24px 0 10px;
    line-height: 1.35;
}
.gn-view-body ul, .gn-view-body ol {
    padding-left: 20px;
    margin-bottom: 16px;
}
.gn-view-body ul { list-style: disc; }
.gn-view-body ol { list-style: decimal; }
.gn-view-body li { margin-bottom: 5px; }
.gn-view-body blockquote {
    border-left: 4px solid var(--gn-red);
    margin: 16px 0;
    padding: 12px 18px;
    background: #f9f9fb;
    color: var(--gn-text-sub);
    border-radius: 0 var(--gn-radius) var(--gn-radius) 0;
}
.gn-view-body a { color: var(--gn-red); text-decoration: underline; }
.gn-view-body table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: .88rem; }
.gn-view-body th, .gn-view-body td { border: 1px solid var(--gn-border); padding: 8px 12px; }
.gn-view-body th { background: #f5f6f8; font-weight: 600; }

/* 관리 버튼 */
.gn-view-actions {
    display: flex;
    gap: 8px;
    padding: 0 30px 20px;
}
.gn-act-btn {
    padding: 7px 16px;
    border-radius: var(--gn-radius);
    font-size: .8rem;
    font-weight: 600;
    transition: all var(--gn-tr);
}
.gn-act-edit { background: var(--gn-navy); color: #fff; }
.gn-act-edit:hover { background: #22334f; color: #fff; }
.gn-act-del { background: #fee2e2; color: var(--gn-red); }
.gn-act-del:hover { background: var(--gn-red); color: #fff; }

/* 공유 버튼 공통 */
.gn-share-btn {
    width: 34px; height: 34px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    transition: opacity var(--gn-tr), transform var(--gn-tr);
    cursor: pointer;
    border: none;
}
.gn-share-btn:hover { opacity: .82; transform: scale(1.1); }
.gn-share-fb { background: #1877f2; color: #fff; }
.gn-share-tw { background: #000; color: #fff; }
.gn-share-copy { background: var(--gn-navy); color: #fff; }

/* 이전/다음 */
.gn-view-nav {
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    box-shadow: var(--gn-shadow);
    overflow: hidden;
    margin-bottom: 20px;
}
.gn-vn-item {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 14px;
    border-bottom: 1px solid var(--gn-border);
    transition: background var(--gn-tr);
}
.gn-vn-item:last-child { border-bottom: none; }
.gn-vn-item:hover { background: #f9fafb; }
.gn-vn-dir { font-size: .72rem; color: var(--gn-red); font-weight: 700; white-space: nowrap; flex-shrink: 0; }
.gn-vn-subj { font-size: .84rem; color: var(--gn-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* 관련 기사 */
.gn-related {
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    box-shadow: var(--gn-shadow);
    padding: 20px;
    margin-bottom: 20px;
}
.gn-related-title {
    font-family: var(--gn-font-title);
    font-size: 1.1rem;
    color: var(--gn-navy);
    margin-bottom: 16px;
    display: flex; align-items: center; gap: 6px;
}
.gn-related-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.gn-related-card { display: flex; flex-direction: column; gap: 7px; }
.gn-related-img { display: block; aspect-ratio: 16/9; overflow: hidden; border-radius: 4px; }
.gn-related-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.gn-related-card:hover .gn-related-img img { transform: scale(1.06); }
.gn-related-noimg {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem;
    border-radius: 4px;
    background: #f0f0f2;
}
.gn-related-subj {
    font-size: .8rem; font-weight: 500; color: var(--gn-text);
    line-height: 1.4;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.gn-related-subj:hover { color: var(--gn-red); }
.gn-related-date { font-size: .7rem; color: var(--gn-text-light); }

/* 댓글 */
.gn-comment-wrap {
    background: var(--gn-surface);
    border-radius: var(--gn-radius);
    box-shadow: var(--gn-shadow);
    padding: 22px;
    margin-bottom: 20px;
}
.gn-comment-title { font-family: var(--gn-font-title); font-size: 1.15rem; color: var(--gn-navy); margin-bottom: 16px; }
.gn-comment-title span { color: var(--gn-red); }
.gn-comment-placeholder {
    padding: 20px;
    background: #f9fafb;
    border-radius: var(--gn-radius);
    text-align: center;
    font-size: .83rem;
    color: var(--gn-text-mute);
}
.gn-comment-placeholder code { background: #eee; padding: 2px 6px; border-radius: 3px; font-size: .78rem; }

/* 뷰 하단 버튼 */
.gn-view-footer {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-bottom: 30px;
}
.gn-btn-list {
    display: inline-flex; align-items: center;
    padding: 10px 24px;
    background: var(--gn-navy);
    color: #fff;
    border-radius: var(--gn-radius);
    font-weight: 600;
    font-size: .88rem;
    transition: background var(--gn-tr);
}
.gn-btn-list:hover { background: var(--gn-red); color: #fff; }

/* 사이드바 카테고리 현재 활성 */
.gn-cat-item.is-current { color: var(--gn-red); background: #fff5f5; border-radius: var(--gn-radius); }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE – LIST / VIEW
══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .gn-list-grid { grid-template-columns: repeat(2, 1fr); }
    .gn-related-grid { grid-template-columns: repeat(2, 1fr); }
    .gn-view-title { font-size: 1.45rem; padding-right: 0; }
    .gn-view-share-top { position: static; margin-top: 10px; }
    .gn-view-head { padding: 20px; }
    .gn-view-body { padding: 20px; }
    .gn-view-actions { padding: 0 20px 16px; }
}
@media (max-width: 600px) {
    .gn-list-grid { grid-template-columns: 1fr; }
    .gn-related-grid { grid-template-columns: repeat(2, 1fr); }
    .gn-toolbar-search { flex-wrap: wrap; }
    .gn-toolbar-input { width: 100%; }
    .gn-view-title { font-size: 1.25rem; }
    .gn-cat-tabs { gap: 5px; }
    .gn-view-body { padding: 16px; font-size: .9rem; }
}
