/**
 * LIVE MAP KOREA
 * Japanese Kawaii + K-POP Style Mobile UI
 * 日本人向け韓国コンサート情報プラットフォーム
 */

/* ===================================
   CSS Variables (Design Tokens)
   =================================== */
:root {
    /* Colors - 코랄 & 내추럴 톤 */
    --color-primary: #FF6666;
    --color-primary-text: #CC4444;
    --color-primary-dark: #E04E4E;
    --color-on-primary: #FFFFFF;
    --color-secondary: #4F7185;

    /* Gradient */
    --gradient-primary: #FF6666;
    --gradient-card: #FFFFFF;

    /* Pastel Colors - 웜톤 파스텔 */
    --pastel-pink: #FFE0E0;
    --pastel-cool: #E8F0F5;
    --pastel-blue: #E8F4FF;
    --pastel-mint: #E8FFF5;
    --pastel-yellow: #F8ECCC;
    --pastel-peach: #FFEDE8;

    /* Neutrals */
    --color-text: #4A4440;
    --color-text-light: #7C7268;
    --color-text-muted: #7A6F62;
    --color-border: #EDE8DF;
    --color-bg: #FFFFFF;
    --color-bg-white: #FFFFFF;
    --color-bg-light: #F8ECCC;
    --color-bg-card: #F8ECCC;
    --color-bg-secondary: #EFF4F7;

    /* Status Colors */
    --color-success: #10B981;
    --color-success-dark: #059669;
    --color-warning: #FBBF24;
    --color-warning-dark: #D97706;
    --color-warning-deep: #B45309;
    --color-danger: #F43F5E;
    --color-danger-dark: #D32F2F;
    --color-info: #2563EB;

    /* Neutrals - Extended Gray Scale */
    --color-text-dark: #333333;
    --color-text-darker: #222222;
    --color-gray-lightest: #FAFAFA;
    --color-gray-light: #e8e8e8;
    --color-gray-border: #dddddd;
    --color-gray-mid: #999999;
    --color-gray-dark: #555555;
    --color-gray-muted: #888888;
    --color-gray-faint: #aaaaaa;
    --color-border-light: #e0e0e0;
    --color-border-mid: #cccccc;

    /* Overlay */
    --color-overlay: rgba(0, 0, 0, 0.6);
    --color-overlay-light: rgba(0, 0, 0, 0.12);

    /* Navigation */
    --color-nav-bg: #FFFFFF;
    --color-nav-border: #e0e0e0;
    --color-nav-item-bg: #e8e8e8;
    --color-nav-item-text: #333333;
    --color-nav-item-active-bg: #222222;
    --color-nav-item-active-text: #FFFFFF;

    /* Brand Colors - External */
    --color-naver: #03C75A;
    --color-naver-dark: #02b050;
    --color-google: #4285F4;
    --color-google-dark: #3367D6;

    /* Footer */
    --color-footer-text: #B8B0A8;
    --color-footer-bg-end: #2D2640;

    /* Tag Semantic Colors */
    --tag-red-bg: #FFEBEE;
    --tag-red-text: #D32F2F;
    --tag-orange-bg: #FFF8E8;
    --tag-orange-text: #D97706;
    --tag-deep-orange-bg: #FFF0E8;
    --tag-deep-orange-text: #EA580C;
    --tag-green-bg: #E8FFF5;
    --tag-green-text: #059669;
    --tag-blue-bg: #dbeafe;
    --tag-blue-text: #1d4ed8;
    --tag-yellow-bg: #fef3c7;
    --tag-yellow-text: #92400e;
    --tag-purple-bg: #ede9fe;
    --tag-purple-text: #6d28d9;
    --tag-info-blue-text: #2563EB;
    --tag-accent-purple-text: #7C3AED;

    /* Map Legend Colors */
    --color-map-venue: #e74c3c;
    --color-map-restaurant: #f39c12;
    --color-map-accommodation: #3498db;

    /* Typography */
    --font-family: "Noto Sans JP", "Noto Sans KR", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Malgun Gothic", sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 1.875rem;

    /* Spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;

    /* Border Radius - 더 둥글게 */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --radius-full: 9999px;

    /* Shadows - 부드러운 웜톤 그림자 */
    --shadow-sm: 0 2px 8px rgba(79, 113, 133, 0.08);
    --shadow-md: 0 4px 16px rgba(79, 113, 133, 0.12);
    --shadow-lg: 0 8px 32px rgba(79, 113, 133, 0.16);
    --shadow-glow: 0 0 20px rgba(255, 102, 102, 0.3);

    /* Glassmorphism */
    --glass-bg: rgba(255, 255, 255, 0.85);
    --glass-border: rgba(255, 255, 255, 0.3);

    /* Common Borders */
    --border-glass: 1px solid rgba(255, 255, 255, 0.5);

    /* Z-index */
    --z-header: 100;
    --z-nav: 90;
    --z-bottom-nav: 100;

    /* Layout */
    --header-height: 44px;
    --bottom-nav-height: 60px;

    /* Safe Area */
    --safe-area-top: env(safe-area-inset-top, 0px);
    --safe-area-bottom: env(safe-area-inset-bottom, 0px);
    --safe-area-left: env(safe-area-inset-left, 0px);
    --safe-area-right: env(safe-area-inset-right, 0px);
}

/* ===================================
   Reset & Base
   =================================== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--color-text);
    background: var(--color-bg);
    background-attachment: fixed;
    padding-top: calc(var(--header-height) + var(--safe-area-top));
    padding-bottom: calc(var(--bottom-nav-height) + var(--safe-area-bottom));
    padding-left: var(--safe-area-left);
    padding-right: var(--safe-area-right);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100vh;
}

a {
    color: inherit;
    text-decoration: none;
    transition: all 0.3s ease;
}

img {
    max-width: 100%;
    height: auto;
}

ul, ol {
    list-style: none;
}

/* ===================================
   Focus Visible - 접근성
   =================================== */
:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* 버튼/링크 - 둥근 요소 포커스 */
.btn-primary:focus-visible,
.btn-outline:focus-visible,
.btn-naver-map:focus-visible,
.btn-google-map:focus-visible,
.btn-show-map:focus-visible,
.btn-pronounce:focus-visible,
.expand-action-btn:focus-visible,
.expand-detail-link:focus-visible,
.filter-chip:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    box-shadow: var(--shadow-glow);
}

/* 네비게이션 */
.bottom-nav-item:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.lang-btn:focus-visible,
.header-back-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* 카드 - 클릭 가능 요소 */
.concert-card:focus-visible,
.venue-card:focus-visible,
.restaurant-card:focus-visible,
.concert-mini-card:focus-visible,
.notice-card-link:focus-visible,
.ad-card:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    box-shadow: var(--shadow-md);
}

/* 링크 */
a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* 찜 버튼 */
.btn-pin:focus-visible {
    outline: 2px solid var(--color-secondary);
    outline-offset: 2px;
}

/* 폼 요소 - outline 대신 border 강조 */
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(255, 102, 102, 0.15);
}

/* 팝업/모달 닫기 버튼 */
.map-popup-close:focus-visible,
.feedback-toast-close:focus-visible,
.review-bottomsheet-close:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* 탭/칩 버튼 */
.nearby-tab-btn:focus-visible,
.venue-chip:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ===================================
   Loading Animation
   =================================== */
@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

@keyframes pulse-glow {
    0%, 100% { box-shadow: var(--shadow-md); }
    50% { box-shadow: var(--shadow-glow); }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--pastel-cool);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

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

.loading-state {
    display: flex;
    justify-content: center;
    padding: var(--spacing-2xl);
}

/* ===================================
   Mobile Header - 글래스모피즘
   =================================== */
.mobile-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: calc(var(--header-height) + var(--safe-area-top));
    padding-top: var(--safe-area-top);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--glass-border);
    z-index: var(--z-header);
}

.header-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--header-height);
    padding: 0 var(--spacing-md);
    padding-left: calc(var(--spacing-md) + var(--safe-area-left));
    padding-right: calc(var(--spacing-md) + var(--safe-area-right));
}

.header-back-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--pastel-pink);
    border: none;
    font-size: 1.25rem;
    color: var(--color-primary-text);
    cursor: pointer;
    margin-left: -8px;
    border-radius: var(--radius-full);
    transition: all 0.3s ease;
}

.header-back-btn:hover {
    background: var(--color-primary);
    color: var(--color-on-primary);
    transform: scale(1.05);
}

.logo {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.logo.logo-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
}

.logo-text {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-primary-text);
    line-height: 1.2;
}

.logo.logo-center .logo-text {
    font-size: var(--font-size-lg);
}

.logo-sub {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    letter-spacing: 0.5px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.lang-selector {
    display: flex;
    gap: 4px;
    background: var(--pastel-cool);
    padding: 3px;
    border-radius: var(--radius-full);
}

.lang-btn {
    padding: 6px 10px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text-light);
    background: transparent;
    border: none;
    border-radius: var(--radius-full);
    transition: all 0.3s ease;
}

.lang-btn:hover {
    color: var(--color-primary-text);
}

.lang-btn.active {
    background: white;
    color: var(--color-primary-text);
    box-shadow: var(--shadow-sm);
}

.menu-toggle {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--color-text);
    cursor: pointer;
    padding: var(--spacing-sm);
    border-radius: var(--radius-md);
    transition: all 0.3s ease;
}

.menu-toggle:hover {
    background: var(--pastel-cool);
    color: var(--color-primary-text);
}

/* ===================================
   Mobile Navigation
   =================================== */
.mobile-nav {
    display: none;
    position: fixed;
    top: calc(var(--header-height) + var(--safe-area-top));
    left: 0;
    right: 0;
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--glass-border);
    z-index: var(--z-nav);
    padding: var(--spacing-sm);
    animation: fadeInUp 0.3s ease;
}

.mobile-nav.active {
    display: block;
}

.nav-list {
    padding: var(--spacing-sm);
}

.nav-list li {
    margin-bottom: var(--spacing-xs);
}

.nav-list a {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    color: var(--color-text);
    border-radius: var(--radius-lg);
    transition: all 0.3s ease;
}

.nav-list a:hover {
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    transform: translateX(5px);
}

.nav-list a i {
    font-size: 1.25rem;
}

/* ===================================
   Bottom Navigation - 귀여운 스타일
   =================================== */
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: calc(var(--bottom-nav-height) + var(--safe-area-bottom));
    padding-bottom: var(--safe-area-bottom);
    padding-left: calc(var(--spacing-sm) + var(--safe-area-left));
    padding-right: calc(var(--spacing-sm) + var(--safe-area-right));
    background: var(--color-nav-bg);
    border-top: 1px solid var(--color-nav-border);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-sm);
    z-index: var(--z-bottom-nav);
}

.bottom-nav-item {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    max-width: 90px;
    height: 44px;
    padding: 4px 4px;
    background: var(--color-nav-item-bg);
    color: var(--color-nav-item-text);
    font-size: var(--font-size-sm);
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    border-radius: 12px;
    transition: all 0.2s ease;
    line-height: 1.3;
    word-break: keep-all;
}

.bottom-nav-item span {
    white-space: pre-line;
}

.bottom-nav-item.active {
    background: var(--color-nav-item-active-bg);
    color: var(--color-nav-item-active-text);
}

.bottom-nav-item:hover {
    opacity: 0.85;
}

/* ===================================
   Main Content
   =================================== */
.main-content {
    min-height: calc(100vh - var(--header-height) - var(--bottom-nav-height));
}

.page-container {
    max-width: 480px;
    margin: 0 auto;
    padding: var(--spacing-md);
}

/* ===================================
   Page Header - 귀여운 타이틀
   =================================== */
.page-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: var(--spacing-xs) var(--spacing-md);
    animation: fadeInUp 0.5s ease;
}

.page-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-primary-text);
    margin-bottom: 0;
}

.page-subtitle {
    font-size: var(--font-size-xs);
    line-height: 1.4;
    color: var(--color-text-light);
}

.page-notice {
    font-size: 11px;
    line-height: 1.4;
    color: var(--color-text-light);
    margin-top: 8px;
    opacity: 0.7;
}

.page-notice i {
    margin-right: 2px;
}

/* ===================================
   Month Navigation - 둥근 버튼
   =================================== */
.month-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) 0 var(--spacing-sm);
}

.month-nav-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border: 2px solid var(--pastel-cool);
    border-radius: var(--radius-full);
    color: var(--color-secondary);
    font-size: 1.1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--shadow-sm);
}

.month-nav-btn:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: var(--color-on-primary);
    transform: scale(1.1);
    box-shadow: var(--shadow-glow);
}

.month-display {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    min-width: 100px;
    text-align: center;
}

/* ===================================
   Venue Filter Chips - 공연장 필터
   =================================== */
.venue-filter {
    display: flex;
    gap: var(--spacing-sm);
    padding: 0 var(--spacing-md) var(--spacing-md);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.venue-filter::-webkit-scrollbar {
    display: none;
}

/* Status Filter - 상태 필터 */
.status-filter {
    display: flex;
    gap: var(--spacing-sm);
    padding: 0 var(--spacing-md) var(--spacing-md);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.status-filter::-webkit-scrollbar {
    display: none;
}

.filter-chip {
    flex-shrink: 0;
    padding: 8px 16px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text-light);
    background: white;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.filter-chip:hover {
    border-color: var(--color-primary);
    color: var(--color-primary-text);
}

.filter-chip.active {
    background: var(--gradient-primary);
    border-color: transparent;
    color: var(--color-on-primary);
    box-shadow: var(--shadow-sm);
}

/* ===================================
   Concert Card - 카와이 스타일
   =================================== */
.concert-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.concert-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    transition: all 0.3s ease;
    animation: fadeInUp 0.5s ease backwards;
    color: inherit;
    text-decoration: none;
}

.concert-card.concert-card-expandable {
    display: block;
    cursor: pointer;
}

.concert-card:nth-child(1) { animation-delay: 0.1s; }
.concert-card:nth-child(2) { animation-delay: 0.15s; }
.concert-card:nth-child(3) { animation-delay: 0.2s; }
.concert-card:nth-child(4) { animation-delay: 0.25s; }
.concert-card:nth-child(5) { animation-delay: 0.3s; }

.concert-card:hover {
    box-shadow: var(--shadow-lg);
}

.concert-card:active {
    transform: scale(0.99);
}

.concert-date {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 52px;
    min-height: 58px;
    background: var(--gradient-primary);
    border-radius: var(--radius-md);
    color: var(--color-on-primary);
    box-shadow: var(--shadow-sm);
    padding: 4px 0;
    gap: 0;
}

.date-ticket {
    font-size: 9px;
    font-weight: 600;
    margin-top: 2px;
    padding: 1px 6px;
    border-radius: 6px;
    line-height: 1.2;
    white-space: nowrap;
}

.date-ticket.ticket-available {
    background: rgba(255,255,255,0.25);
    color: var(--color-on-primary);
}

.date-ticket.ticket-soldout {
    background: rgba(211,47,47,0.85);
    color: var(--color-on-primary);
}

.date-ticket.ticket-comingsoon {
    background: rgba(245,124,0,0.85);
    color: var(--color-on-primary);
}

.date-month {
    font-size: var(--font-size-xs);
    font-weight: 500;
    opacity: 0.9;
}

.date-day {
    font-size: var(--font-size-xl);
    font-weight: 700;
    line-height: 1;
}

.date-weekday {
    font-size: 10px;
    font-weight: 500;
    opacity: 0.9;
}

.concert-info {
    flex: 1;
    min-width: 0;
}

.concert-info-row {
    width: 100%;
    padding-top: 2px;
    margin-top: 2px;
    border-top: 1px solid var(--color-text-muted);
}

.concert-info-row:first-child {
    padding-top: 0;
    margin-top: 0;
    border-top: none;
}

.concert-info-row-split {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
}

.concert-detail-group {
    flex: 1;
    min-width: 0;
}

.concert-info-row:first-child {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-sm);
}

.concert-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-sm);
    flex: 1;
    min-width: 0;
}

.concert-artist {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.concert-header + .concert-venue {
    margin-top: var(--spacing-xs);
}

.concert-header .tag-accessibility {
    flex-shrink: 0;
}

.concert-venue,
.concert-time {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-bottom: 1px;
}

.concert-venue i,
.concert-time i {
    color: var(--color-secondary);
    font-size: 0.9em;
}

.concert-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    margin-top: 2px;
}

.concert-scores {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-shrink: 0;
    padding: var(--spacing-sm);
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
}

.score-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
}

.score-item i {
    color: var(--color-secondary);
}

.score-value {
    font-weight: 700;
    color: var(--color-text);
}

.concert-arrow {
    flex-shrink: 0;
    color: var(--color-text-muted);
    font-size: 1.25rem;
}

/* ===================================
   Tags - 둥근 태그
   =================================== */
.tag {
    display: inline;
    font-size: var(--font-size-xs);
    font-weight: 400;
    color: var(--color-gray-mid);
}

.tag-type {
    color: var(--color-secondary);
}

.tag-card {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
}

.tag-ticket-available {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
}

.tag-ticket-soldout {
    background: var(--tag-red-bg);
    color: var(--tag-red-text);
}

.tag-ticket-comingsoon {
    background: var(--pastel-yellow);
    color: #F57C00;
}

.tag-solo {
    background: var(--pastel-peach);
    color: var(--tag-deep-orange-text);
}

.tag-jp {
    background: var(--pastel-blue);
    color: var(--tag-info-blue-text);
}

.tag-quiet {
    background: var(--pastel-cool);
    color: var(--tag-accent-purple-text);
}

/* Spicy Level Tags */
.tag-spicy-0 {
    background: var(--tag-green-bg);
    color: var(--tag-green-text);
}

.tag-spicy-1 {
    background: var(--tag-orange-bg);
    color: var(--tag-orange-text);
}

.tag-spicy-2 {
    background: var(--tag-deep-orange-bg);
    color: var(--tag-deep-orange-text);
}

.tag-spicy-3 {
    background: var(--tag-red-bg);
    color: var(--tag-red-text);
}

.tag-friendly {
    background: var(--pastel-blue);
    color: var(--tag-info-blue-text);
}

.tag-clean {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
}

/* Restaurant Scores Row */
.restaurant-scores {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
}

.spicy-note {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    font-style: italic;
}

/* Locker Info Section */
.locker-info {
    border-left: 3px solid var(--color-primary);
}

.locker-info .info-row.station-locker .info-value {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Facility Info (bathroom / rest area) */
.facility-info-block {
    margin-bottom: var(--spacing-md);
}

.facility-info-block:last-child {
    margin-bottom: 0;
}

.facility-info-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.facility-info-title i {
    color: var(--color-secondary);
}

.facility-info-text {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

.facility-info-image {
    margin-top: 8px;
    max-width: 100%;
    border-radius: var(--radius-sm);
}

/* Venue Locker Brief (concert detail) */
.venue-locker-brief {
    margin-top: var(--spacing-sm);
    padding: 8px 12px;
    background: var(--pastel-cool);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    color: var(--color-secondary);
}

/* ===================================
   Venue Quick Links
   =================================== */
.venue-quick-links {
    margin-top: var(--spacing-2xl);
    animation: fadeInUp 0.5s ease 0.3s backwards;
}

.section-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: var(--font-size-base);
    font-weight: 700;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text);
}

.section-title i {
    color: var(--color-secondary);
}

.venue-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.venue-chip {
    display: inline-flex;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: white;
    border: 2px solid var(--pastel-cool);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.venue-chip:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: var(--color-on-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-glow);
}

/* ===================================
   Detail Page - Hero Section
   =================================== */
.concert-hero {
    text-align: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    position: relative;
    overflow: hidden;
}

.concert-type-badge {
    display: inline-block;
    padding: 4px 12px;
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-xs);
    font-weight: 600;
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-xs);
    box-shadow: var(--shadow-sm);
}

.concert-title {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.concert-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.concert-meta-inline {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin: var(--spacing-sm) 0 0;
}

.concert-meta-inline i {
    margin-right: 2px;
}

.concert-meta-divider {
    border: none;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    margin: var(--spacing-sm) 0;
}

.meta-item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.meta-item i {
    color: var(--color-secondary);
}

/* Score Card */
.score-card {
    background: white;
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-top: var(--spacing-sm);
    box-shadow: var(--shadow-sm);
}

.score-card-title {
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-align: center;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text);
}

.score-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
}

.score-box {
    text-align: center;
    padding: var(--spacing-sm);
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
}

.score-label {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin-bottom: 4px;
}

.score-stars {
    color: var(--color-warning);
    font-size: var(--font-size-sm);
}

.score-stars .bi-star {
    color: var(--color-border);
}

.score-note {
    display: block;
    font-size: 10px;
    color: var(--color-text-muted);
    margin-top: 4px;
}

/* Info Card */
.info-card {
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
}

/* From Japan Card - 특별 강조 (하늘색 계열) */
.from-japan-card {
    background: linear-gradient(135deg, #F0F8FF 0%, #E6F3FF 50%, #F5F0FF 100%);
    border: 2px solid #A8D4F0;
    position: relative;
    overflow: hidden;
}

.from-japan-card::before {
    content: '🇯🇵';
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    font-size: 1.5rem;
    opacity: 0.3;
}

.from-japan-card .info-value.highlight {
    color: var(--color-primary-text);
    font-weight: 700;
}

.info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    border-bottom: 1px solid var(--color-border);
}

.info-row:last-child {
    border-bottom: none;
}

.info-label {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
}

.info-value {
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-align: right;
    color: var(--color-text);
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
}

.venue-name {
    font-size: var(--font-size-base);
    font-weight: 700;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text);
}

.access-info {
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm);
    margin: var(--spacing-sm) 0;
}

.access-info h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--color-secondary);
}

.access-info p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Badges */
.badge {
    display: inline-block;
    padding: 4px 10px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    border-radius: var(--radius-full);
}

.badge-success {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
}

.badge-warning {
    background: var(--pastel-yellow);
    color: var(--color-warning-dark);
}

/* Buttons - 귀여운 버튼 */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: 12px 24px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
}

.btn-primary {
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    box-shadow: var(--shadow-md);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-glow);
}

.btn-outline {
    background: white;
    border: 2px solid var(--pastel-cool);
    color: var(--color-text);
}

.btn-outline:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: var(--color-on-primary);
}

.btn-block {
    width: 100%;
    margin-top: var(--spacing-sm);
}

/* ===================================
   Restaurant List
   =================================== */
.restaurant-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.restaurant-card {
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md) var(--spacing-md);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    transition: all 0.3s ease;
}

.restaurant-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.restaurant-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-xs);
}

.restaurant-name {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
}

.restaurant-distance {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--color-primary-text);
    font-weight: 600;
    background: var(--pastel-pink);
    padding: 4px 10px;
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-xs);
    max-width: 100%;
}

.restaurant-category {
    font-size: var(--font-size-xs);
    color: var(--color-secondary);
    font-weight: 500;
    margin-bottom: var(--spacing-xs);
}

.restaurant-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xs);
    line-height: 1.4;
}

.restaurant-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-xs);
}

.restaurant-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    padding-top: var(--spacing-xs);
    border-top: 1px solid var(--color-border);
}

.price-range {
    color: var(--color-success);
    font-weight: 700;
}

/* ===================================
   Accommodation Cards (숙소 전용 태그 + 예약 링크)
   =================================== */
.tag-wifi {
    background: var(--tag-blue-bg) !important;
    color: var(--tag-blue-text) !important;
}

.tag-luggage {
    background: var(--tag-yellow-bg) !important;
    color: var(--tag-yellow-text) !important;
}

.tag-late {
    background: var(--tag-purple-bg) !important;
    color: var(--tag-purple-text) !important;
}

.restaurant-booking-link {
    display: block;
    text-align: center;
    margin-top: var(--spacing-xs);
    padding: 6px 12px;
    background: var(--color-primary);
    color: var(--color-on-primary);
    border-radius: var(--radius-lg);
    text-decoration: none;
    font-size: var(--font-size-sm);
    font-weight: 600;
    transition: background 0.2s;
}

.restaurant-booking-link:hover {
    background: var(--color-primary-dark);
}

/* ===================================
   Detail Section
   =================================== */
.detail-section {
    margin-bottom: var(--spacing-md);
}

.detail-section .info-card {
    padding: var(--spacing-sm);
}

.section-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-top: calc(-1 * var(--spacing-sm));
    margin-bottom: var(--spacing-md);
}

/* Back Link */
.back-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-md) 0;
    transition: all 0.3s ease;
}

.back-link:hover {
    color: var(--color-primary-text);
    transform: translateX(-5px);
}

/* ===================================
   Venue List & Card
   =================================== */
.venue-sort-selector {
    margin-bottom: var(--spacing-sm);
}

.venue-sort-selector select {
    width: 100%;
    padding: 8px 14px;
    border: 1px solid var(--color-gray-mid);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    font-weight: 600;
    background: var(--color-bg-card);
    color: var(--color-text);
    outline: none;
    cursor: pointer;
    text-align: center;
    text-align-last: center;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%23666' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.venue-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.venue-card {
    display: block;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    transition: all 0.2s ease;
}

.venue-card:hover {
    box-shadow: var(--shadow-md);
}

.venue-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2px;
}

.venue-card-name-wrap {
    flex: 1;
    min-width: 0;
}

.venue-card-name {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.3;
}

.venue-card-pronunciation {
    font-size: 11px;
    font-weight: 500;
    color: var(--color-on-primary);
    background: var(--color-gray-dark);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    padding: 3px 10px;
    margin-left: var(--spacing-sm);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    vertical-align: middle;
    transition: background 0.2s;
}

.venue-card-pronunciation:hover {
    background: var(--color-text-dark);
}

.venue-card-pronunciation.playing {
    background: var(--color-secondary);
}

.venue-card-pronunciation i {
    font-size: 0.85em;
}

.venue-card-chevron {
    flex-shrink: 0;
    font-size: 18px;
    color: var(--color-text-muted);
    margin-left: 12px;
}

.venue-card-detail {
    margin-bottom: 0;
}

.venue-card-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 5px 0;
    border-bottom: 1px solid var(--color-gray-border);
}

.venue-card-label {
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text);
    flex-shrink: 0;
    min-width: 90px;
}

.venue-card-value {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    text-align: right;
    flex: 1;
}

.venue-card-station {
    color: var(--color-success-dark);
    font-weight: 600;
}

.venue-card-facilities-row {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    padding: 5px 0;
    border-bottom: 1px solid var(--color-gray-border);
}

.venue-card-schedule {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 5px 0;
}

.venue-card-schedule .venue-card-label {
    font-size: var(--font-size-xs);
}

.venue-card-schedule .venue-card-value {
    font-size: var(--font-size-xs);
}

/* ===================================
   Ad Slots - 광고 슬롯
   =================================== */
.ad-card {
    display: block;
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    background: linear-gradient(135deg, var(--color-bg-light) 0%, var(--color-gray-lightest) 100%);
    margin: var(--spacing-sm) 0;
    text-decoration: none;
    overflow: hidden;
}

.ad-card-featured {
    border-color: var(--pastel-pink);
    background: linear-gradient(135deg, #FFF5F7 0%, #FFF0F5 50%, #F5F0FF 100%);
}

.ad-card-exclusive {
    border: 2px solid var(--pastel-cool);
    background: linear-gradient(135deg, #F8F5FF 0%, #F0EBFF 50%, #E8E0FF 100%);
    box-shadow: 0 4px 16px rgba(147, 112, 219, 0.15);
}

.ad-card-exclusive .ad-icon {
    background: linear-gradient(135deg, var(--pastel-cool) 0%, #9B7FD9 100%);
}

.ad-card-exclusive .ad-label {
    color: var(--tag-purple-text);
    font-weight: 600;
}

.ad-label {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-bottom: 2px;
}

.ad-content {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.ad-icon {
    width: 40px;
    height: 40px;
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.ad-card-featured .ad-icon {
    background: var(--pastel-pink);
}

.ad-text {
    flex: 1;
    min-width: 0;
}

.ad-title {
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 1px;
}

.ad-desc {
    font-size: 11px;
    color: var(--color-text-light);
}

.ad-price {
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-primary-text);
    margin-top: 2px;
}

/* Venue Hero */
.venue-hero {
    text-align: center;
    padding: var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    position: relative;
    overflow: hidden;
}

.venue-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-secondary), var(--color-primary));
}

.venue-title {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.venue-name-sub {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-sm);
}

.btn-pronounce {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 16px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-primary-text);
    background: var(--pastel-pink);
    border: 1.5px solid var(--color-primary);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.2s ease;
    margin-bottom: var(--spacing-md);
}

.btn-pronounce:active {
    transform: scale(0.95);
}

.btn-pronounce.playing {
    color: var(--color-on-primary);
    background: var(--color-primary);
    animation: pulse-pronounce 1s infinite;
}

@keyframes pulse-pronounce {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

.venue-meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.facility-tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

.facility-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    border-radius: 20px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    font-size: var(--font-size-xs);
    color: var(--color-text);
}

.facility-tag i {
    font-size: 14px;
    color: var(--color-secondary);
}

.facility-icon-bathroom {
    display: inline-flex;
    gap: 0;
}

.facility-icon-bathroom i {
    margin: 0;
}

.facility-icon-bathroom i + i {
    margin-left: -0.35em;
}

/* Subway Line Badges */
.subway-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-end;
}

.subway-badge {
    display: inline-flex;
    align-items: center;
    gap: 0;
}

.subway-line-circle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--color-bg-white);
    border: 3px solid var(--line-color);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.subway-line-label {
    font-size: 8px;
    font-weight: 700;
    color: var(--line-color);
    letter-spacing: 0.5px;
}

.subway-line-num {
    font-size: 20px;
    font-weight: 700;
    color: var(--line-color);
}

.subway-bridge {
    width: 8px;
    height: 3px;
    background: var(--line-color);
}

.subway-station-num {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--line-color);
    color: var(--color-on-primary);
    font-size: 16px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.subway-station-name {
    font-size: 13px;
    color: var(--color-text);
    margin-left: 6px;
    font-weight: 500;
}

/* Concert Mini List */
.concert-mini-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.concert-mini-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: white;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.concert-mini-card:hover {
    transform: translateX(5px);
    box-shadow: var(--shadow-md);
}

.concert-mini-date {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    min-width: 80px;
    color: var(--color-primary-text);
}

.concert-mini-info {
    flex: 1;
    min-width: 0;
}

.mini-artist {
    display: block;
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mini-type {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
}

/* ===================================
   Schedule Example
   =================================== */
.schedule-example {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.schedule-day {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
}

.schedule-day h4 {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-primary-text);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px dashed var(--pastel-cool);
}

.schedule-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.schedule-list li {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: var(--font-size-sm);
    padding: var(--spacing-sm) 0;
}

.schedule-list .time {
    font-weight: 600;
    color: var(--color-secondary);
    min-width: 55px;
    background: var(--pastel-cool);
    padding: 4px 8px;
    border-radius: var(--radius-sm);
    text-align: center;
}

/* ===================================
   Notice Card
   =================================== */
.notice-card {
    background: linear-gradient(135deg, var(--pastel-yellow) 0%, var(--color-bg-white) 100%);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    border-left: 4px solid var(--color-warning);
    box-shadow: var(--shadow-sm);
}

.notice-card h3 {
    font-size: var(--font-size-sm);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    color: var(--color-warning-deep);
}

.notice-card ul {
    list-style: none;
    padding-left: 0;
}

.notice-card li {
    font-size: var(--font-size-xs);
    color: var(--color-text);
    line-height: 1.8;
    padding-left: var(--spacing-md);
    position: relative;
}

.notice-card li::before {
    content: '♡';
    position: absolute;
    left: 0;
    color: var(--color-primary-text);
}

/* ===================================
   Empty State
   =================================== */
.empty-state {
    text-align: center;
    padding: var(--spacing-2xl);
    color: var(--color-text-muted);
}

.empty-state i {
    font-size: 4rem;
    margin-bottom: var(--spacing-md);
    color: var(--color-secondary);
    opacity: 0.5;
}

.empty-state p {
    font-size: var(--font-size-sm);
}

.empty-state.small {
    padding: var(--spacing-lg);
}

.empty-state.small i {
    font-size: 2.5rem;
}

/* ===================================
   Test Banner
   =================================== */
.test-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px var(--spacing-md);
    background: var(--tag-yellow-bg);
    color: #856404;
    font-size: var(--font-size-xs);
    font-weight: 500;
    text-align: center;
    line-height: 1.4;
}

.test-banner i {
    flex-shrink: 0;
    font-size: 0.85em;
}

/* ===================================
   Footer
   =================================== */
.mobile-footer {
    background: linear-gradient(135deg, var(--color-text) 0%, var(--color-footer-bg-end) 100%);
    color: var(--color-on-primary);
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: center;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    margin-top: var(--spacing-xs);
}

.footer-brand {
    font-weight: 700;
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
    color: var(--color-primary-text);
}

.footer-desc {
    font-size: 11px;
    color: var(--color-footer-text);
    margin-bottom: 2px;
}

.footer-links {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: 2px;
}

.footer-legal-link {
    font-size: var(--font-size-xs);
    color: var(--color-footer-text);
    text-decoration: none;
}

.footer-legal-link:hover {
    color: var(--color-on-primary);
    text-decoration: underline;
}

.footer-copyright {
    font-size: var(--font-size-xs);
    color: var(--color-footer-text);
}

/* ===================================
   Utilities
   =================================== */
.text-center { text-align: center; }
.text-right { text-align: right; }
.mb-0 { margin-bottom: 0; }
.mt-md { margin-top: var(--spacing-md); }
.mb-md { margin-bottom: var(--spacing-md); }
.text-gradient {
    color: var(--color-primary-text);
}

/* ===================================
   Disabled States - 범용
   =================================== */
.btn-primary:disabled,
.btn-outline:disabled,
button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.btn-primary:disabled:hover,
.btn-outline:disabled:hover {
    transform: none;
    box-shadow: none;
}

/* ===================================
   Form Error States - 폼 에러
   =================================== */
.form-error {
    border-color: var(--color-danger) !important;
}

.form-error-message {
    display: block;
    color: var(--color-danger);
    font-size: var(--font-size-xs);
    margin-top: var(--spacing-xs);
}

.form-success-message {
    display: block;
    color: var(--color-success);
    font-size: var(--font-size-xs);
    margin-top: var(--spacing-xs);
}


/* ===================================
   Media Queries
   =================================== */
@media (min-width: 768px) {
    .page-container {
        max-width: 680px;
    }

    .bottom-nav {
        display: none !important;
    }

    body {
        padding-bottom: var(--spacing-xl);
    }

    .header-back-btn {
        display: none;
    }

    .logo.logo-center {
        position: static;
        transform: none;
    }

    /* 태블릿 카드 간격 */
    .concert-list,
    .venue-list {
        gap: var(--spacing-lg);
    }

    .restaurant-list {
        gap: var(--spacing-sm);
    }

    /* 가이드 아티클 폭 확대 */
    .guide-article {
        max-width: 600px;
    }

    /* 스코어 그리드 여유 */
    .score-grid {
        gap: var(--spacing-lg);
    }
}

/* 데스크톱 */
@media (min-width: 1024px) {
    .page-container {
        max-width: 800px;
    }

    .guide-article {
        max-width: 720px;
    }

    /* 데스크톱에서 카드 패딩 */
    .concert-card,
    .venue-card {
        padding: var(--spacing-xl);
    }

    .restaurant-card {
        padding: var(--spacing-md) var(--spacing-lg);
    }

    /* 팁 그리드 3열 */
    .tips-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ===================================
   Touch Feedback & Mobile Optimization
   =================================== */
* {
    -webkit-tap-highlight-color: transparent;
}

.concert-card:active,
.venue-card:active,
.concert-mini-card:active,
.restaurant-card:active {
    transform: scale(0.98);
}

.venue-chip:active,
.btn:active {
    transform: scale(0.95);
}

.bottom-nav-item:active {
    transform: scale(0.95);
    opacity: 0.8;
}

.main-content {
    -webkit-overflow-scrolling: touch;
}

.bottom-nav,
.mobile-header,
.concert-card,
.venue-card {
    -webkit-user-select: none;
    user-select: none;
}

@media all and (display-mode: standalone) {
    body {
        padding-top: calc(var(--header-height) + var(--safe-area-top));
    }
}

/* ===================================
   Venue Filter Dropdown
   =================================== */
.venue-filter-select {
    padding: 6px 28px 6px 10px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text);
    background: white;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 12px;
    max-width: 160px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-left: var(--spacing-sm);
}

.venue-filter-select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(79, 113, 133, 0.15);
}

/* ===================================
   Concert Card Expand - 인라인 확장
   =================================== */
.concert-card-main {
    display: flex;
    align-items: stretch;
    gap: var(--spacing-sm);
}

.concert-expand-indicator {
    display: inline-flex;
    align-items: center;
    font-size: 1.5rem;
    color: var(--color-text-muted);
    flex-shrink: 0;
    transition: transform 0.25s ease;
}

.concert-card.expanded .concert-expand-indicator {
    transform: rotate(90deg);
}

/* 확장영역 네비 버튼 4종 */
.expand-nav-buttons {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-xs);
}

.expand-nav-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: var(--spacing-sm) 4px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text);
    text-decoration: none;
    font-size: var(--font-size-xs);
    font-weight: 500;
    text-align: center;
    line-height: 1.2;
    transition: all 0.2s;
}

.expand-nav-btn:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    transform: translateY(-1px);
}

.expand-nav-btn i {
    font-size: 1.3rem;
    color: var(--color-secondary);
}

.expand-nav-btn:hover i {
    color: var(--color-primary);
}

.concert-arrow-link {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding: var(--spacing-sm);
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color 0.2s;
}

.concert-arrow-link:hover {
    color: var(--color-primary-text);
}

.concert-expand {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px dashed var(--color-border);
    animation: expandSlideDown 0.3s ease;
}

@keyframes expandSlideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.expand-section {
    margin-bottom: var(--spacing-md);
}

.expand-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.expand-title i {
    color: var(--color-secondary);
}

.btn-view-map-inline {
    margin-left: auto;
    background: none;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-primary-text);
    cursor: pointer;
    padding: 2px 8px;
    font-size: var(--font-size-xs);
    display: inline-flex;
    align-items: center;
}

.btn-view-map-inline:hover {
    background: var(--color-primary);
    color: var(--color-on-primary);
}

.expand-text {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    line-height: 1.6;
}

.expand-locker-details .expand-text {
    margin-bottom: 2px;
}

.expand-locker-details .expand-text-sub {
    margin-top: var(--spacing-xs);
    padding-top: var(--spacing-xs);
    border-top: 1px dashed var(--color-border);
    color: var(--color-text-muted);
}

.expand-image {
    margin-top: var(--spacing-xs);
    max-width: 100%;
    border-radius: var(--radius-sm);
}

.expand-update-request {
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
}

.expand-update-text {
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.expand-update-text i {
    color: var(--color-secondary);
}

.expand-update-desc {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin-top: 2px;
}

.expand-detail-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s;
}

.expand-detail-link:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-glow);
}

.concert-card.expanded {
    box-shadow: var(--shadow-lg);
}

/* ===================================
   Facility Tags - 시설 태그
   =================================== */
.tag-facility {
    color: var(--color-gray-mid);
}

/* ===================================
   Decorative Elements
   =================================== */
.page-container::before {
    content: '';
    position: fixed;
    top: 100px;
    right: -50px;
    width: 150px;
    height: 150px;
    background: radial-gradient(circle, rgba(255, 102, 102, 0.15) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: -1;
}

.page-container::after {
    content: '';
    position: fixed;
    bottom: 150px;
    left: -50px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(79, 113, 133, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: -1;
}

/* ===================================
   Guide Article - 가이드 상세 페이지
   =================================== */
.guide-article {
    max-width: 480px;
    margin: 0 auto;
    padding: var(--spacing-md);
}

.guide-article-header {
    text-align: center;
    padding: var(--spacing-xl) 0;
    margin-bottom: var(--spacing-lg);
    animation: fadeInUp 0.5s ease;
}

.guide-article-emoji {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
    display: block;
}

.guide-article-title {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--color-primary-text);
    margin-bottom: var(--spacing-sm);
}

.guide-article-subtitle {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Guide Sections */
.guide-section {
    margin-bottom: var(--spacing-xl);
    animation: fadeInUp 0.5s ease backwards;
}

.guide-section:nth-child(2) { animation-delay: 0.1s; }
.guide-section:nth-child(3) { animation-delay: 0.15s; }
.guide-section:nth-child(4) { animation-delay: 0.2s; }
.guide-section:nth-child(5) { animation-delay: 0.25s; }
.guide-section:nth-child(6) { animation-delay: 0.3s; }

.guide-section h2 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.section-icon {
    font-size: 1.25rem;
}

/* Guide Intro Box */
.guide-intro {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.8;
}

.guide-intro.warning-intro {
    background: linear-gradient(135deg, #FFF5F7 0%, var(--pastel-pink) 100%);
    border-color: var(--pastel-pink);
}

/* Guide Tip Box */
.guide-tip {
    background: var(--pastel-cool);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.guide-tip h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-secondary);
    margin-bottom: var(--spacing-xs);
}

.guide-tip p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Guide Warning Box */
.guide-warning {
    background: linear-gradient(135deg, var(--pastel-yellow) 0%, var(--color-bg-white) 100%);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
    border-left: 4px solid var(--color-warning);
}

.guide-warning h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-warning-deep);
    margin-bottom: var(--spacing-xs);
}

.guide-warning p {
    font-size: var(--font-size-sm);
    color: var(--color-text);
    line-height: 1.6;
}

/* Guide Conclusion Box */
.guide-conclusion {
    background: var(--gradient-primary);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    color: var(--color-on-primary);
    text-align: center;
}

.guide-conclusion h2 {
    color: var(--color-on-primary);
    justify-content: center;
    margin-bottom: var(--spacing-sm);
}

.guide-conclusion p {
    font-size: var(--font-size-sm);
    opacity: 0.95;
    line-height: 1.8;
}

/* Guide TOC */
.guide-toc {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-lg);
}

.guide-toc h3 {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.guide-toc ul {
    list-style: none;
}

.guide-toc li {
    padding: var(--spacing-sm) 0;
    border-bottom: 1px dashed var(--color-border);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.guide-toc li:last-child {
    border-bottom: none;
}

.guide-toc li a {
    color: var(--color-secondary);
    font-weight: 500;
}

/* Guide Timeline */
.guide-timeline {
    position: relative;
    padding-left: var(--spacing-xl);
}

.guide-timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--gradient-primary);
    border-radius: 2px;
}

.timeline-item {
    position: relative;
    margin-bottom: var(--spacing-lg);
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.timeline-item::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--spacing-xl) + 4px);
    top: var(--spacing-lg);
    width: 12px;
    height: 12px;
    background: var(--gradient-primary);
    border-radius: 50%;
    border: 2px solid white;
    box-shadow: var(--shadow-sm);
}

.timeline-label {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-on-primary);
    background: var(--gradient-primary);
    padding: 4px 12px;
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-sm);
}

.timeline-item h4 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.timeline-item p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: var(--spacing-sm);
}

.timeline-item ul {
    list-style: none;
    margin-top: var(--spacing-sm);
}

.timeline-item li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
}

.timeline-item li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-success);
    font-weight: bold;
}

/* Checklist */
.checklist {
    background: var(--pastel-mint);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.checklist h5 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-success-dark);
    margin-bottom: var(--spacing-sm);
}

.checklist ul {
    list-style: none;
}

.checklist li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
}

.checklist li::before {
    content: '☐';
    position: absolute;
    left: 0;
    color: var(--color-success);
}

/* Transport Card */
.transport-card {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.transport-card h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.transport-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
}

.info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-sm);
}

.info-label {
    color: var(--color-text-light);
}

.info-value {
    font-weight: 600;
    color: var(--color-text);
}

.safety-high {
    color: var(--color-success);
}

.safety-medium {
    color: var(--color-warning-dark);
}

.transport-card > p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Venue Route */
.venue-route {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.venue-route h3 {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.route-steps {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.route-step {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.step-number {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 700;
    border-radius: 50%;
}

.step-content {
    flex: 1;
}

.step-content strong {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 4px;
}

.step-content p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Venue Night Info */
.venue-night-info {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.venue-night-info h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.venue-night-info ul {
    list-style: none;
}

.venue-night-info li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
    line-height: 1.6;
}

.venue-night-info li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--color-primary-text);
}

/* Venue Food Area */
.venue-food-area {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.venue-food-area h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.venue-food-area p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Warning List */
.warning-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.warning-item {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.warning-item h4 {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.warning-item p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Emergency Contacts */
.emergency-contacts {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.contact-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.contact-number {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-primary-text);
    min-width: 60px;
}

.contact-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Tips Grid */
.tips-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.tip-card {
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.tip-card h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.tip-card p {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    line-height: 1.5;
}

/* Place Category */
.place-category {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.place-category h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.place-category p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: var(--spacing-sm);
}

.place-category ul {
    list-style: none;
    margin-top: var(--spacing-sm);
}

.place-category li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
}

.place-category li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--color-primary-text);
}

/* Venue Japanese */
.venue-japanese {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.venue-japanese h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.venue-japanese ul {
    list-style: none;
}

.venue-japanese li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
    line-height: 1.6;
}

.venue-japanese li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-success);
}

/* App List */
.app-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.app-card {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.app-card h4 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.app-card p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

.app-recommend {
    display: inline-block;
    margin-top: var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-primary-text);
    background: var(--pastel-pink);
    padding: 4px 10px;
    border-radius: var(--radius-full);
}

/* Phrase List */
.phrase-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.phrase-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.phrase-ja {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.phrase-ko {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-secondary);
    background: var(--pastel-cool);
    padding: 4px 10px;
    border-radius: var(--radius-full);
}

/* Mistake Card */
.mistake-card {
    display: flex;
    gap: var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
    position: relative;
    overflow: hidden;
}

.mistake-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--gradient-primary);
}

.mistake-rank {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-lg);
    font-weight: 700;
    border-radius: 50%;
}

.mistake-content {
    flex: 1;
}

.mistake-content h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.mistake-detail {
    background: linear-gradient(135deg, #FFF5F7 0%, var(--pastel-pink) 100%);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.mistake-detail h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-danger);
    margin-bottom: var(--spacing-xs);
}

.mistake-detail p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
}

.mistake-solution {
    background: var(--pastel-mint);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
}

.mistake-solution h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-success);
    margin-bottom: var(--spacing-sm);
}

.mistake-solution ul {
    list-style: none;
}

.mistake-solution li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
    line-height: 1.6;
}

.mistake-solution li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-success);
    font-weight: bold;
}

/* Aftershow Shop */
.aftershow-shop {
    display: flex;
    gap: var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    margin-bottom: var(--spacing-md);
}

.shop-rank {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-lg);
    font-weight: 700;
    border-radius: 50%;
}

.shop-content {
    flex: 1;
}

.shop-content h3 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.shop-hours {
    font-size: var(--font-size-xs);
    color: var(--color-secondary);
    font-weight: 500;
    margin-bottom: var(--spacing-sm);
}

.shop-content > p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: var(--spacing-md);
}

.shop-recommend {
    background: var(--pastel-cool);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.shop-recommend h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-secondary);
    margin-bottom: var(--spacing-sm);
}

.shop-recommend ul {
    list-style: none;
}

.shop-recommend li {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-xs) 0;
    line-height: 1.5;
}

.shop-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
}

.shop-tags .tag {
    font-size: var(--font-size-xs);
    padding: 4px 8px;
}

/* Related Links */
.guide-related {
    margin-top: var(--spacing-2xl);
    padding-top: var(--spacing-lg);
    border-top: 2px dashed var(--color-border);
}

.guide-related h2 {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.related-links {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.related-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
    transition: all 0.3s ease;
}

.related-link:hover {
    transform: translateX(5px);
    box-shadow: var(--shadow-md);
}

.related-emoji {
    font-size: 1.5rem;
}

.related-link span:last-child {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
}

/* ===================================
   Markdown Content Styles
   =================================== */
.guide-content.markdown-body {
    font-size: var(--font-size-sm);
    line-height: 1.8;
    color: var(--color-text);
}

.markdown-body h1 {
    font-size: var(--font-size-xl);
    font-weight: 700;
    margin: var(--spacing-xl) 0 var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--pastel-cool);
    color: var(--color-primary-text);
}

.markdown-body h2 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    margin: var(--spacing-xl) 0 var(--spacing-md);
    padding: var(--spacing-sm) 0;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    scroll-margin-top: calc(var(--header-height) + var(--safe-area-top) + 16px);
}

.markdown-body h3 {
    font-size: var(--font-size-base);
    font-weight: 600;
    margin: var(--spacing-lg) 0 var(--spacing-sm);
    color: var(--color-text);
}

.markdown-body h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    margin: var(--spacing-md) 0 var(--spacing-xs);
    color: var(--color-secondary);
}

.markdown-body p {
    margin: var(--spacing-sm) 0;
}

.markdown-body ul,
.markdown-body ol {
    margin: var(--spacing-sm) 0;
    padding-left: var(--spacing-lg);
}

.markdown-body li {
    margin: var(--spacing-xs) 0;
    line-height: 1.6;
}

.markdown-body ul li {
    list-style-type: disc;
}

.markdown-body ol li {
    list-style-type: decimal;
}

.markdown-body strong {
    font-weight: 600;
    color: var(--color-text);
}

.markdown-body a {
    color: var(--color-primary-text);
    text-decoration: underline;
}

.markdown-body a:hover {
    color: var(--color-primary-dark);
}

.markdown-body hr {
    border: none;
    border-top: 2px dashed var(--color-border);
    margin: var(--spacing-xl) 0;
}

.markdown-body blockquote {
    background: var(--pastel-cool);
    border-left: 4px solid var(--color-secondary);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--spacing-md);
    margin: var(--spacing-md) 0;
}

.markdown-body blockquote p {
    margin: 0;
}

.markdown-body blockquote strong {
    color: var(--color-secondary);
}

/* Warning blockquote style */
.markdown-body blockquote:has(strong:first-child) {
    background: var(--pastel-cool);
}

/* Tables */
.markdown-body table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--spacing-md) 0;
    font-size: var(--font-size-sm);
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.markdown-body thead {
    background: var(--gradient-primary);
    color: var(--color-on-primary);
}

.markdown-body th {
    padding: var(--spacing-md);
    text-align: left;
    font-weight: 600;
}

.markdown-body td {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.markdown-body tr:last-child td {
    border-bottom: none;
}

.markdown-body tbody tr:hover {
    background: var(--pastel-cool);
}

/* Code */
.markdown-body code {
    background: var(--pastel-cool);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-family: 'SF Mono', 'Monaco', 'Consolas', monospace;
    font-size: 0.9em;
    color: var(--color-secondary);
}

.markdown-body pre {
    background: var(--color-text);
    color: #f8f8f2;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin: var(--spacing-md) 0;
}

.markdown-body pre code {
    background: none;
    padding: 0;
    color: inherit;
}

/* Tags in paragraphs */
.markdown-body p code {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
    font-family: var(--font-family);
    font-size: var(--font-size-xs);
    padding: 4px 8px;
    border-radius: var(--radius-full);
    margin-right: 4px;
}

/* ===================================
   Notice Banner - 공지사항 배너
   =================================== */
.notice-banner-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    padding: 0 var(--spacing-md);
}

.notice-banner {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    border-radius: var(--radius-lg);
    animation: fadeInDown 0.5s ease;
}

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

/* Notice Types */
.notice-banner.notice-info {
    background: linear-gradient(135deg, var(--pastel-blue) 0%, #E0EFFF 100%);
    border: 1px solid #A8D4F0;
}

.notice-banner.notice-info .notice-icon {
    color: #1976D2;
}

.notice-banner.notice-warning {
    background: linear-gradient(135deg, var(--pastel-yellow) 0%, #FFECB3 100%);
    border: 1px solid #FFD54F;
}

.notice-banner.notice-warning .notice-icon {
    color: #F57C00;
}

.notice-banner.notice-event {
    background: linear-gradient(135deg, var(--pastel-pink) 0%, #FFE4F2 100%);
    border: 1px solid #FFB6D1;
}

.notice-banner.notice-event .notice-icon {
    color: var(--color-primary-text);
}

.notice-icon {
    flex-shrink: 0;
    font-size: 1.25rem;
    margin-top: 2px;
}

.notice-content {
    flex: 1;
    min-width: 0;
}

.notice-title {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.notice-desc {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
    line-height: 1.5;
}

.notice-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    font-weight: 500;
    color: var(--color-primary-text);
    text-decoration: none;
    transition: all 0.2s ease;
}

.notice-link:hover {
    color: var(--color-primary-dark);
}

.notice-link i {
    font-size: 0.75rem;
    transition: transform 0.2s ease;
}

.notice-link:hover i {
    transform: translateX(3px);
}

/* ===================================
   Notice List Page - 공지사항 목록 페이지
   =================================== */
.notice-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    padding: 0 var(--spacing-md);
}

.notice-card {
    background: var(--gradient-card);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
    border: var(--border-glass);
    animation: fadeInUp 0.5s ease backwards;
}

.notice-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-sm);
}

.notice-type-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
}

.notice-type-tag.type-info {
    background: var(--pastel-blue);
    color: #1976D2;
}

.notice-type-tag.type-warning {
    background: var(--pastel-yellow);
    color: #F57C00;
}

.notice-type-tag.type-event {
    background: var(--pastel-pink);
    color: var(--color-primary-text);
}

.notice-date {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.notice-card-title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
    line-height: 1.4;
}

.notice-card-content {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: var(--spacing-sm);
}

.notice-card-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-primary-text);
    text-decoration: none;
    transition: all 0.2s ease;
}

.notice-card-link:hover {
    color: var(--color-primary-dark);
}

.notice-card-link i {
    font-size: 0.875rem;
    transition: transform 0.2s ease;
}

.notice-card-link:hover i {
    transform: translateX(3px);
}

/* Notice card type variations */
.notice-card.notice-card-info {
    border-left: 4px solid #1976D2;
}

.notice-card.notice-card-warning {
    border-left: 4px solid #F57C00;
}

.notice-card.notice-card-event {
    border-left: 4px solid var(--color-primary);
}

/* ===================================
   Detailed Access - 상세 교통 안내
   =================================== */
.detailed-access {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.access-block {
    background: var(--gradient-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: var(--border-glass);
}

.access-block h4 {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.access-block h4 i {
    color: var(--color-secondary);
    font-size: 1.1rem;
}

.access-block p {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    line-height: 1.8;
}

.access-block.access-tips {
    background: linear-gradient(135deg, var(--pastel-yellow) 0%, #FFFDF5 100%);
    border-color: #FFE082;
}

.access-block.access-tips p {
    color: var(--color-text);
}

.access-block.access-tips h4 i {
    color: #F9A825;
}

/* ===================================
   Pin-Up (핀업 기능)
   =================================== */

@keyframes btnPop {
    0% { transform: scale(1); }
    30% { transform: scale(1.3); }
    60% { transform: scale(0.9); }
    100% { transform: scale(1); }
}

/* 핀 버튼 - 콘서트 카드 내 */
.btn-pin {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-muted);
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    flex-shrink: 0;
    padding: 0;
    z-index: 2;
}

.btn-pin:hover {
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}

.btn-pin.active {
    background: var(--pastel-cool);
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}

.btn-pin.pop {
    animation: btnPop 0.4s ease;
}

/* 확장 영역 액션 버튼 행 */
.expand-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

.expand-action-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    border-radius: var(--radius-lg);
    border: 2px solid var(--color-border);
    background: white;
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    position: relative;
}

.expand-action-btn:hover {
    border-color: var(--color-primary);
    color: var(--color-primary-text);
}

.expand-action-btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.expand-action-btn i {
    font-size: 1rem;
}

/* 추후 구성 뱃지 */
.coming-soon-badge {
    position: absolute;
    top: -8px;
    right: -4px;
    background: var(--color-warning);
    color: var(--tag-yellow-text);
    font-size: 9px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: var(--radius-full);
    white-space: nowrap;
    line-height: 1.3;
}

/* 약도 팝업 오버레이 */
.map-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-overlay);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
    animation: fadeIn 0.2s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.map-popup {
    background: white;
    border-radius: var(--radius-xl);
    max-width: 440px;
    width: 100%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: popupSlideUp 0.3s ease;
}

@keyframes popupSlideUp {
    from { transform: translateY(30px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.map-popup-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.map-popup-title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
}

.map-popup-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pastel-cool);
    border: none;
    border-radius: var(--radius-full);
    color: var(--color-text);
    font-size: 1.25rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.map-popup-close:hover {
    background: var(--color-secondary);
    color: white;
}

.map-popup-body {
    padding: var(--spacing-lg);
    text-align: center;
}

.map-popup-body-embed {
    padding: 0;
}

.map-popup-iframe {
    width: 100%;
    height: 350px;
    border: none;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
    display: block;
}

.map-popup-body-image {
    padding: 0;
}

.map-popup-img {
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
    display: block;
}

.map-popup-placeholder {
    padding: var(--spacing-2xl) var(--spacing-lg);
    text-align: center;
    color: var(--color-text-muted);
}

.map-popup-placeholder i {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
    color: var(--color-border);
}

.map-popup-placeholder p {
    font-size: var(--font-size-sm);
}

/* ===================================
   Map Popup - Leaflet Container
   =================================== */
.map-popup-leaflet {
    width: 100%;
    height: 300px;
    border-radius: 0;
}

.map-route-info {
    text-align: center;
    padding: 8px 12px;
    font-size: var(--font-size-xs);
    color: var(--color-text);
    background: var(--color-bg-card);
    border-top: 1px solid var(--color-border);
}

.map-route-info i {
    color: var(--color-map-venue);
    margin-right: 4px;
}

.map-popup-directions {
    display: flex;
    gap: 8px;
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--color-border);
}

.map-popup-directions .btn-naver-map,
.map-popup-directions .btn-google-map {
    flex: 1 1 0;
    justify-content: center;
    text-align: center;
    font-size: 0.78rem;
    min-width: 0;
    margin-top: 0;
    padding: 8px 12px;
}

.btn-show-map {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: var(--color-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: var(--spacing-sm);
}

.btn-show-map:hover {
    opacity: 0.85;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255, 102, 102, 0.3);
}

.info-card .btn-show-map {
    display: flex;
    justify-content: center;
    width: 100%;
}

/* ===================================
   Naver Map Directions Button
   =================================== */
.btn-naver-map {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: 10px 18px;
    background: var(--color-naver);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    margin-top: var(--spacing-sm);
}

.btn-naver-map:hover {
    background: var(--color-naver-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(3, 199, 90, 0.3);
    color: var(--color-on-primary);
}

.btn-naver-map i {
    font-size: 1.1rem;
}

.btn-google-map {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: 10px 18px;
    background: var(--color-google);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    margin-top: var(--spacing-sm);
}

.btn-google-map:hover {
    background: var(--color-google-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(66, 133, 244, 0.3);
    color: var(--color-on-primary);
}

.btn-google-map i {
    font-size: 1.1rem;
}

.directions-buttons {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
}

.directions-buttons .btn-naver-map,
.directions-buttons .btn-google-map {
    flex: 1 1 0;
    justify-content: center;
    text-align: center;
    font-size: 0.8rem;
    min-width: 0;
}

.airport-time-info {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: var(--spacing-sm);
    padding: 8px 12px;
    background: var(--pastel-blue);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text);
}

.airport-time-info i {
    color: var(--color-info);
}

/* ===================================
   Nearby Tabs (Accommodation / Restaurant)
   =================================== */
.nearby-tabs {
    display: flex;
    gap: 0;
    margin-bottom: var(--spacing-md);
    background: var(--pastel-cool);
    border-radius: var(--radius-full);
    padding: 3px;
}

.nearby-tab-btn {
    flex: 1;
    padding: 8px 14px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-light);
    background: transparent;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
}

.nearby-tab-btn.active {
    background: var(--color-bg-white);
    color: var(--color-primary-text);
    box-shadow: var(--shadow-sm);
}

.nearby-tab-btn:hover:not(.active) {
    color: var(--color-primary-text);
}

/* ===================================
   Nearby Filter Dropdown
   =================================== */
.nearby-filter-select {
    display: block;
    width: 100%;
    padding: 8px 14px;
    font-size: var(--font-size-sm);
    font-family: var(--font-family);
    color: var(--color-text);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%237C7291' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    cursor: pointer;
}

.nearby-filter-select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(255, 102, 102, 0.15);
}

/* ===================================
   Filter Chips (Restaurant tab)
   =================================== */
.nearby-filter-chips {
    display: none;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: var(--spacing-md);
}

.nearby-filter-chips.show {
    display: flex;
}

.filter-chip {
    padding: 6px 14px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    font-family: var(--font-family);
    color: var(--color-text-light);
    background: var(--color-bg-white);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
    -webkit-user-select: none;
}

.filter-chip:active {
    transform: scale(0.95);
}

.filter-chip.active {
    color: var(--color-on-primary);
    background: var(--color-primary);
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(255, 102, 102, 0.25);
}

/* ===================================
   Restaurant Card Footer (distance + directions link)
   =================================== */
.restaurant-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--spacing-xs);
    padding-top: var(--spacing-xs);
    border-top: 1px solid var(--color-border);
}

.restaurant-card-footer .footer-distance {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 4px;
}

.restaurant-card-footer .footer-naver-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-naver);
    text-decoration: none;
    transition: all 0.2s ease;
}

.restaurant-card-footer .footer-naver-link:hover {
    color: var(--color-naver-dark);
    text-decoration: underline;
}

.restaurant-card-footer .footer-map-links {
    display: flex;
    align-items: center;
    gap: 10px;
}

.restaurant-card-footer .footer-google-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-google);
    text-decoration: none;
    transition: all 0.2s ease;
}

.restaurant-card-footer .footer-google-link:hover {
    color: var(--color-google-dark);
    text-decoration: underline;
}

/* ===================================
   Interactive Map (Leaflet)
   =================================== */
.interactive-map-container {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    margin-top: var(--spacing-sm);
}

#interactiveMap {
    width: 100%;
    height: 350px;
}

.map-legend {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    flex-wrap: wrap;
}

.map-legend-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.map-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    flex-shrink: 0;
}

.map-legend-dot.venue { background: var(--color-map-venue); }
.map-legend-dot.restaurant { background: var(--color-map-restaurant); }
.map-legend-dot.accommodation { background: var(--color-map-accommodation); }

/* Leaflet popup custom */
.map-popup-name {
    font-weight: 700;
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
}

.map-popup-type {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-bottom: 4px;
}

.map-popup-distance {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.map-popup-link {
    display: inline-block;
    margin-top: 4px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-google);
    text-decoration: none;
}

.map-popup-link:hover {
    text-decoration: underline;
}

/* ===================================
   Feedback Toast Popup
   =================================== */
.feedback-toast-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-overlay);
    z-index: 9999;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 0;
    animation: fadeIn 0.2s ease;
}

.feedback-toast {
    background: white;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    max-width: 440px;
    width: 100%;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.2);
    animation: toastSlideUp 0.3s ease;
}

@keyframes toastSlideUp {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.feedback-toast-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.feedback-toast-title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
}

.feedback-toast-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pastel-cool);
    border: none;
    border-radius: var(--radius-full);
    color: var(--color-text);
    font-size: 1.25rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.feedback-toast-close:hover {
    background: var(--color-secondary);
    color: white;
}

.feedback-toast-body {
    padding: var(--spacing-lg);
}

.feedback-toast-body label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.feedback-toast-body select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    background: white;
    margin-bottom: var(--spacing-md);
    appearance: auto;
}

.feedback-toast-body select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(255, 102, 102, 0.1);
}

.feedback-toast-body textarea {
    width: 100%;
    min-height: 100px;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    resize: vertical;
    font-family: inherit;
    box-sizing: border-box;
}

.feedback-toast-body textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(255, 102, 102, 0.1);
}

.feedback-toast-actions {
    display: flex;
    gap: var(--spacing-sm);
    padding: 0 var(--spacing-lg) var(--spacing-lg);
}

.feedback-toast-actions .btn-feedback-cancel {
    flex: 1;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: white;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.feedback-toast-actions .btn-feedback-cancel:hover {
    background: var(--color-bg);
}

.feedback-toast-actions .btn-feedback-submit {
    flex: 2;
    padding: 12px;
    border: none;
    border-radius: var(--radius-md);
    background: var(--color-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.feedback-toast-actions .btn-feedback-submit:hover {
    background: var(--color-primary-dark, #e55a5a);
    transform: translateY(-1px);
}

.feedback-toast-actions .btn-feedback-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.feedback-toast-message {
    text-align: center;
    padding: var(--spacing-lg);
    font-size: var(--font-size-sm);
    font-weight: 600;
}

.feedback-toast-message.success {
    color: var(--color-success);
}

.feedback-toast-message.error {
    color: var(--color-primary-text);
}

/* ===================================
   Terms Page
   =================================== */
.terms-version-selector {
    padding: 0 var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.terms-version-selector select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--color-gray-mid);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    font-weight: 600;
    background: var(--color-bg-card);
    color: var(--color-text);
    outline: none;
    cursor: pointer;
    appearance: auto;
}

.terms-content {
    padding: 0 var(--spacing-md) var(--spacing-xl);
}

.terms-article {
    margin-bottom: var(--spacing-lg);
}

.terms-article-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text);
}

.terms-article-body {
    font-size: var(--font-size-xs);
    line-height: 1.7;
    color: var(--color-text-light);
}

.terms-appendix {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border);
}

/* ===================================
   About Page
   =================================== */
.about-content {
    padding: 0 var(--spacing-md) var(--spacing-xl);
}

.about-section {
    margin-bottom: var(--spacing-xl);
}

.about-section-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
}

.about-section-body {
    font-size: var(--font-size-xs);
    line-height: 1.7;
    color: var(--color-text-light);
}

.about-service-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.about-service-list li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg-secondary);
    border-radius: var(--radius-md);
}

.about-service-list li i {
    color: var(--color-primary-text);
    font-size: var(--font-size-sm);
}

.about-contact-email {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: var(--spacing-sm);
    font-size: var(--font-size-xs);
}

.about-contact-email i {
    color: var(--color-primary-text);
}

.about-contact-email a {
    color: var(--color-primary-text);
    text-decoration: none;
}

.about-contact-email a:hover {
    text-decoration: underline;
}

/* ===================================
   Sitemap Page
   =================================== */
.sitemap-content {
    padding: 0 var(--spacing-md) var(--spacing-xl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.sitemap-group {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    background: var(--color-bg);
}

.sitemap-group-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--spacing-sm) 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sitemap-group-title i {
    color: var(--color-primary-text);
}

.sitemap-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sitemap-list li a {
    display: block;
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    text-decoration: none;
    background: var(--color-bg-secondary);
    border-radius: var(--radius-sm);
}

.sitemap-list li a:hover {
    color: var(--color-primary-text);
    background: var(--color-bg);
    border: 1px solid var(--color-primary);
    padding: calc(var(--spacing-sm) - 1px) calc(var(--spacing-md) - 1px);
}

/* ===================================
   FAQ Page
   =================================== */
.faq-content {
    padding: 0 var(--spacing-md) var(--spacing-xl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.faq-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.faq-question {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: var(--spacing-md);
    background: var(--color-bg-light);
    border: none;
    cursor: pointer;
    text-align: left;
}

.faq-q-label {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-xs);
    font-weight: 700;
}

.faq-q-text {
    flex: 1;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text);
}

.faq-chevron {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    transition: transform 0.2s ease;
}

.faq-item.open .faq-chevron {
    transform: rotate(180deg);
}

.faq-answer {
    display: none;
    padding: 0 var(--spacing-md) var(--spacing-md);
    padding-left: calc(var(--spacing-md) + 34px);
    gap: 10px;
}

.faq-item.open .faq-answer {
    display: flex;
}

.faq-a-label {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-bg-secondary);
    color: var(--color-text-light);
    font-size: var(--font-size-xs);
    font-weight: 700;
}

.faq-a-text {
    font-size: var(--font-size-xs);
    line-height: 1.7;
    color: var(--color-text-light);
}

/* ===================================
   마이페이지
   =================================== */
.mypage-section {
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.mypage-section-title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    padding: 16px 20px 12px;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid var(--color-border);
}

.mypage-section-title i {
    color: var(--color-primary-text);
}

.mypage-section-body {
    padding: 16px 20px;
}

.mypage-section-body .empty-state {
    text-align: center;
    padding: 24px 0;
    color: var(--color-text-muted);
}

.mypage-section-body .empty-state i {
    font-size: 2rem;
    display: block;
    margin-bottom: 8px;
    opacity: 0.4;
}

.mypage-section-body .empty-state p {
    font-size: var(--font-size-xs);
    margin: 4px 0;
}

.empty-hint {
    font-size: 11px !important;
    opacity: 0.6;
}

/* 닉네임 검색 */
.mypage-nickname-search {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
}

.mypage-input {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    background: var(--color-bg-light);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s;
}

.mypage-input:focus {
    border-color: var(--color-primary);
}

.mypage-btn {
    padding: 10px 16px;
    border: none;
    border-radius: var(--radius-md);
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    font-size: var(--font-size-xs);
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
}

/* 핀업 목록 */
.mypage-fav-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.mypage-fav-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    background: #fff;
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-primary);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.fav-info {
    text-decoration: none;
    flex: 1;
    min-width: 0;
}

.fav-title {
    display: block;
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 4px;
}

.fav-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 2px;
}

.fav-date {
    font-size: 12px;
    color: var(--color-text-muted);
}

.fav-venue {
    font-size: 12px;
    color: var(--color-point);
    font-weight: 500;
}

.fav-type {
    font-size: 11px;
    color: var(--color-primary);
    background: var(--color-sub);
    padding: 1px 6px;
    border-radius: 4px;
}

.fav-remove {
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 4px 8px;
    font-size: 14px;
    flex-shrink: 0;
}

.fav-remove:hover {
    color: var(--color-danger);
}

/* 내 후기 */
.mypage-review-item {
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border);
}

.mypage-review-item:last-child {
    border-bottom: none;
}

.review-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}

.review-stars {
    color: var(--color-warning);
    font-size: 13px;
}

.review-date {
    font-size: 11px;
    color: var(--color-text-muted);
}

.review-content {
    font-size: var(--font-size-xs);
    line-height: 1.6;
    color: var(--color-text);
    word-break: break-word;
}

/* 설정 */
.mypage-settings-list {
    display: flex;
    flex-direction: column;
}

.mypage-settings-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    border-bottom: 1px solid var(--color-border);
    text-decoration: none;
    color: var(--color-text);
}

.mypage-settings-item:last-child {
    border-bottom: none;
}

.settings-label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: var(--font-size-xs);
    font-weight: 500;
}

.settings-label i {
    color: var(--color-text-muted);
    font-size: 16px;
}

.settings-value {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.settings-lang-toggle {
    display: flex;
    gap: 6px;
}

.settings-lang-btn {
    padding: 6px 14px;
    border-radius: var(--radius-md);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    color: var(--color-text-muted);
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    transition: all 0.2s;
}

.settings-lang-btn.active {
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    border-color: transparent;
}

/* 로딩 */
.mypage-loading {
    text-align: center;
    padding: 24px;
    color: var(--color-text-muted);
}

.mypage-loading i {
    font-size: 1.5rem;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* ===================================
   고객의소리 - 아코디언 레이아웃
   =================================== */
.fb-accordion {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: 12px;
    overflow: hidden;
}

.fb-accordion-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 18px 20px;
    background: none;
    border: none;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}

.fb-accordion-info {
    flex: 1;
    text-align: left;
}

.fb-accordion-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 4px;
}

.fb-accordion-desc {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin: 0;
    line-height: 1.4;
}

.fb-accordion-chevron {
    flex-shrink: 0;
    font-size: 18px;
    color: var(--color-text-muted);
    transition: transform 0.2s ease;
    margin-left: 12px;
}

.fb-accordion.open .fb-accordion-chevron {
    transform: rotate(180deg);
}

.fb-accordion-body {
    display: none;
    border-top: 1px solid var(--color-border);
}

.fb-accordion.open .fb-accordion-body {
    display: block;
}

.feedback-form {
    padding: 16px 20px 20px;
}

.feedback-form .form-group {
    margin-bottom: 0;
    padding: 14px 0;
    border-bottom: 1px solid var(--color-gray-mid);
}

.feedback-form .form-group:last-of-type {
    border-bottom: none;
}

.feedback-form label {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: 500;
    margin-bottom: 6px;
    color: var(--color-text);
}

.feedback-form select,
.feedback-form input[type="text"],
.feedback-form input[type="email"],
.feedback-form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--color-gray-mid);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    background: var(--color-bg-light);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s;
    box-sizing: border-box;
}

.feedback-form select:focus,
.feedback-form input[type="text"]:focus,
.feedback-form input[type="email"]:focus,
.feedback-form textarea:focus {
    border-color: var(--color-primary);
}

.feedback-form textarea {
    resize: vertical;
    min-height: 120px;
}

.char-count {
    display: block;
    text-align: right;
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: 4px;
}

.feedback-submit-btn {
    display: block;
    width: 50%;
    margin: 8px auto 0;
    padding: 12px;
    border: none;
    border-radius: var(--radius-md);
    background: var(--color-text-darker);
    color: var(--color-on-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.2s;
}

.feedback-submit-btn:hover {
    opacity: 0.9;
}

.feedback-submit-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.feedback-alert {
    margin: 0 20px 12px;
    padding: 12px 16px;
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
}

.feedback-alert.success {
    background: var(--pastel-mint);
    color: var(--color-success-dark);
    border: 1px solid #bbf7d0;
}

.feedback-alert.error {
    background: var(--tag-red-bg);
    color: var(--color-danger);
    border: 1px solid #fecaca;
}

/* ===================================
   콘서트 상세 찜 버튼 행
   =================================== */
.concert-title-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* ===================================
   조회수 표시
   =================================== */
.view-count {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    font-weight: 500;
}

.tag.tag-view {
    background: var(--pastel-cool, #eef2f7);
    color: var(--color-text-muted);
    font-weight: 500;
}

.venue-card-views,
.restaurant-views {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.venue-card-views {
    margin-top: 4px;
}

/* ===================================
   후기 작성 폼
   =================================== */
.review-form {
    margin-top: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--pastel-cream, #fff8f0);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.review-form-guide {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    margin: 0;
    padding: 8px 10px;
    background: var(--color-bg-white);
    border-left: 3px solid var(--color-primary);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    line-height: 1.5;
    color: var(--color-text-light);
}

.review-form-guide i {
    color: var(--color-primary);
    margin-top: 2px;
    flex-shrink: 0;
}

.review-input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-family: inherit;
}

.review-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(255, 102, 102, 0.12);
}

textarea.review-input {
    resize: vertical;
    min-height: 70px;
}

.review-submit-btn {
    align-self: flex-end;
}
