/* ============================================
   엔블 / NBL — Redesign · Design tokens
   ============================================
   • Soft pastel base + indigo→pink gradient accent
   • All components derive from CSS vars
   • Backwards-compatible alias vars for old class names
   ============================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
    /* ─── base ─── */
    --bg:            #FAF9F7;
    --bg-soft:       #F4F2EE;
    --bg-tint:       #F6F4FF;
    --bg-tint-2:     #FFF4F0;
    --surface:       #FFFFFF;
    --surface-2:     #FCFBF9;
    --border:        #EDEAE3;
    --border-strong: #DAD6CC;

    --text:        #14131A;
    --text-soft:   #3A3845;
    --text-muted:  #7C7B86;
    --text-faint:  #B1AFB8;

    /* ─── accent (violet → cyan) ─── */
    --accent-a:     #8B5CF6;   /* violet */
    --accent-b:     #06B6D4;   /* cyan   */
    --accent-tint:  rgba(139,92,246,.08);
    --accent-ring:  rgba(139,92,246,.20);

    /* gradient stops */
    --gradient-main: linear-gradient(120deg, var(--accent-a), var(--accent-b));
    --gradient-cool: linear-gradient(135deg, #06B6D4, #8B5CF6);
    --gradient-warm: linear-gradient(135deg, #F59E0B, #EC4899);
    --gradient-mesh: radial-gradient(at 20% 20%, rgba(139,92,246,.07) 0px, transparent 50%),
                     radial-gradient(at 80% 0%,  rgba(6,182,212,.06)  0px, transparent 50%),
                     radial-gradient(at 0% 80%,  rgba(139,92,246,.04) 0px, transparent 50%);

    /* ─── status ─── */
    --success: #16A36A;
    --warning: #F59E0B;  --warn: #F59E0B;
    --danger:  #EF4444;
    --info:    var(--accent-a);

    /* ─── shape ─── */
    --radius-sm: 10px;
    --radius:    14px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --r-sm: 10px; --r: 14px; --r-lg: 20px; --r-xl: 28px;

    /* ─── shadows ─── */
    --shadow-sm:  0 1px 0 rgba(20,19,26,.02), 0 2px 6px -3px rgba(20,19,26,.06);
    --shadow:     0 1px 0 rgba(20,19,26,.02), 0 8px 24px -12px rgba(20,19,26,.08);
    --shadow-lg:  0 24px 48px -22px rgba(20,19,26,.18), 0 2px 0 rgba(20,19,26,.02);
    --shadow-glow: 0 0 0 4px var(--accent-ring);

    /* ─── legacy aliases (호환) ─── */
    --brand-1: var(--accent-a);
    --brand-2: #8B5CF6;
    --brand-3: var(--accent-b);
    --brand-4: #06B6D4;
    --bg-subtle:   var(--bg);
    --bg-elevated: rgba(255,255,255,.7);
    --text-subtle: var(--text-faint);

    /* ─── type (AA 원본과 동일) ─── */
    --font-sans: "Pretendard","Pretendard Variable", Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-en:   Inter, "Pretendard Variable","Pretendard", ui-sans-serif, system-ui, sans-serif;
    --font-mono: "JetBrains Mono","Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
    --font: var(--font-sans);
}

html, body {
    font-family: var(--font-sans);
    color: var(--text);
    background: var(--bg);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    font-size: 15px;
    letter-spacing: -0.011em;
    font-feature-settings: "ss01","cv11";
    transition: background .25s ease, color .25s ease;
    overflow-x: clip;   /* hidden 은 body 를 스크롤 컨테이너로 만들어 사이드바 sticky 를 깨뜨림 → clip */
    max-width: 100%;    /* [2026-06-05] 100vw 는 세로 스크롤바 폭까지 포함해 콘텐츠영역보다 ~15px 넓어짐(넘침). 100% = 콘텐츠영역 폭 */
}
.main, .page { max-width: 100%; overflow-x: hidden; }
/* .app 은 overflow:hidden 금지 — 사이드바 position:sticky 가 깨짐. clip 은 스크롤 컨테이너를 안 만들어 sticky 유지 */
.app { max-width: 100%; overflow-x: clip; }

/* ─── 다크 테마 ─── */
html[data-theme="dark"] {
    --bg:            #0B0B11;
    --bg-soft:       #111119;
    --bg-tint:       #14121E;
    --bg-tint-2:     #1A121A;
    --surface:       #13131C;
    --surface-2:     #181822;
    --border:        #23232E;
    --border-strong: #2E2E3B;

    --text:        #F4F4F7;
    --text-soft:   #C9C8D1;
    --text-muted:  #8A8896;
    --text-faint:  #54535E;

    --accent-tint:  rgba(139,92,246,.14);
    --accent-ring:  rgba(139,92,246,.34);

    --gradient-mesh: radial-gradient(at 20% 20%, rgba(139,92,246,.16) 0px, transparent 50%),
                     radial-gradient(at 80% 0%,  rgba(6,182,212,.12)  0px, transparent 50%),
                     radial-gradient(at 0% 80%,  rgba(139,92,246,.10) 0px, transparent 50%);
}
html[data-theme="dark"] .topbar { background: #13131C; }
html[data-theme="dark"] .nb-stat,
html[data-theme="dark"] .card,
html[data-theme="dark"] .bd-card { background: #13131C !important; border-color: #2E2E3B !important; box-shadow: 0 1px 0 rgba(255,255,255,.02), 0 18px 40px -20px rgba(0,0,0,.6) !important; }
html[data-theme="dark"] .credits-badge,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .logout-btn { background: #181822; }
html[data-theme="dark"] .form-input,
html[data-theme="dark"] .form-textarea,
html[data-theme="dark"] .form-select,
html[data-theme="dark"] .bd-input,
html[data-theme="dark"] .bd-textarea { background: #181822 !important; color: var(--text); }
html[data-theme="dark"] .radio-pill { background: #181822; }
html[data-theme="dark"] .radio-pill.active { background: var(--accent-tint); }
html[data-theme="dark"] .modal { background: rgba(0,0,0,.65); }
html[data-theme="dark"] .modal-content { background: #13131C; }
html[data-theme="dark"] .site-footer { background: #13131C; color: var(--text-muted); }
html[data-theme="dark"] table.data thead,
html[data-theme="dark"] .bd-table thead { background: #181822 !important; }
html[data-theme="dark"] .sidebar { background: #13131C !important; border-right-color: #2E2E3B !important; }
html[data-theme="dark"] .sidebar-brand .brand-text { color: #F4F4F7 !important; }
html[data-theme="dark"] .nav-item { color: #8A8896 !important; }
html[data-theme="dark"] .nav-item:hover { background: #181822 !important; color: #F4F4F7 !important; }
html[data-theme="dark"] .nav-item.active { background: rgba(139,92,246,.18) !important; color: #c4b5fd !important; }
html[data-theme="dark"] .nav-item.active .nav-icon { color: #c4b5fd !important; }
html[data-theme="dark"] body { background: #0B0B11; }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; }
img { max-width: 100%; display: block; }

/* ============================================
   레이아웃
   ============================================ */
.app {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 244px 1fr;
    /* 사이드바 컬럼 전체에 surface 색을 깔아서 sticky sidebar 가 viewport 바닥에 못 미치는 경우에도 시각적으로 바닥까지 이어지게 */
    background:
        linear-gradient(to right, var(--surface) 0 244px, transparent 244px 100%) no-repeat,
        var(--bg);
    background-attachment: local, local;
}
html[data-theme="dark"] .app {
    background:
        linear-gradient(to right, #13131C 0 244px, transparent 244px 100%) no-repeat,
        var(--bg);
}
@media (max-width: 1100px) {
    .app {
        grid-template-columns: 1fr;
        background: var(--bg);
    }
    html[data-theme="dark"] .app { background: var(--bg); }
}

/* ─── Sidebar ─── (모든 페이지에서 동일하게 보이도록 강제 고정) */
.sidebar {
    background: var(--surface) !important;
    border-right: 1px solid var(--border) !important;
    height: 100vh !important;
    height: 100dvh !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: 18px 14px;
    position: sticky;
    top: 0;
    display: flex;
    scrollbar-width: thin;
    scrollbar-color: var(--border-strong) transparent;
}
.sidebar { flex-direction: column; }
.sidebar::-webkit-scrollbar { width: 6px; }
.sidebar::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
.sidebar::-webkit-scrollbar-track { background: transparent; }
.sidebar nav { flex: 1 1 auto; min-height: 0; }
.sidebar-brand {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    height: 56px !important;
    padding: 0 8px !important;
    margin-bottom: 16px !important;
    text-decoration: none !important;
    line-height: 1 !important;
}
.sidebar-brand .logo-mark {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    border-radius: 10px !important;
    background: var(--gradient-main) !important;
    display: grid !important;
    place-items: center !important;
    color: white !important;
    font-weight: 800 !important;
    font-family: var(--font-en) !important;
    font-size: 14px !important;
    line-height: 1 !important;
    letter-spacing: -.02em !important;
    box-shadow: 0 6px 16px -8px var(--accent-a) !important;
    position: relative !important;
    flex-shrink: 0 !important;
}
.sidebar-brand .logo-mark::after {
    content: "";
    position: absolute; inset: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255,255,255,.25), transparent 60%);
    pointer-events: none;
}
.sidebar-brand .brand-text {
    font-family: var(--font-sans) !important;
    font-weight: 700 !important;
    font-size: 17px !important;
    line-height: 1 !important;
    letter-spacing: -.02em !important;
    color: var(--text) !important;
    background: none !important;
    -webkit-text-fill-color: currentColor !important;
    display: inline-flex;
    align-items: center;
    height: 20px;
}

.nav-item {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    height: 42px !important;
    padding: 0 12px !important;
    color: var(--text-muted) !important;
    border-radius: 11px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    margin-bottom: 3px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    font-family: var(--font-sans) !important;
    transition: background .2s ease, color .2s ease, transform .2s cubic-bezier(.2,.7,.3,1);
}
.nav-item > * { flex-shrink: 0; }
.nav-item > span {
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 20px !important;
    letter-spacing: -.01em !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: inherit !important;
}
.nav-item:hover { background: var(--surface-2) !important; color: var(--text) !important; transform: translateX(2px); }
.nav-item.active { background: var(--accent-tint) !important; color: var(--accent-a) !important; }
.nav-item.active {
    background: var(--accent-tint);
    color: var(--accent-a);
    box-shadow: none;
}
.nav-item.active::after {
    content: "";
    position: absolute; right: 10px; top: 50%;
    transform: translateY(-50%);
    width: 4px; height: 14px; border-radius: 4px;
    background: var(--gradient-main);
}
.nav-item .nav-icon {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    color: var(--text-faint);
    transition: color .15s ease;
    flex-shrink: 0 !important;
    display: block !important;
    stroke-width: 1.8 !important;
    fill: none !important;
    vertical-align: middle !important;
}
.nav-item:hover .nav-icon { color: var(--text-soft) !important; }
.nav-item.active .nav-icon { color: var(--accent-a) !important; }
/* 활성 메뉴의 pill 위치 고정 — 메뉴 높이 변경에 맞춤 */
.nav-item.active::after {
    height: 14px;
}
.nav-item:hover .nav-icon { color: var(--text-soft); }
.nav-item.active .nav-icon { color: var(--accent-a); }

.nav-section-title {
    font-size: 11px; font-weight: 700;
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 16px 12px 8px;
}

/* sidebar bottom: credit card + user chip */
.sidebar-bottom { margin-top: auto; }
.sidebar-credits {
    padding: 16px;
    border-radius: 16px;
    background: linear-gradient(160deg, var(--bg-tint), var(--bg-tint-2));
    border: 1px solid var(--border);
    position: relative;
    overflow: hidden;
}
.sidebar-credits::before {
    content: "";
    position: absolute; inset: 0;
    opacity: .5;
    background: radial-gradient(80% 60% at 100% 0%, var(--accent-tint), transparent 70%);
    pointer-events: none;
}
.sidebar-credits-label {
    font-size: 11.5px;
    color: var(--text-muted);
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    position: relative;
}
.sidebar-credits-value {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.1;
    margin-top: 4px;
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    position: relative;
    letter-spacing: -.025em;
}
.sidebar-credits-sub {
    font-size: 12px;
    color: var(--text-muted);
    margin-bottom: 12px;
    position: relative;
}
.sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 8px 4px;
}
.sidebar-user .avatar {
    width: 32px; height: 32px;
    border-radius: 999px;
    background: linear-gradient(135deg, #FFD6A0, #FFA8C5);
    display: grid; place-items: center;
    color: #7a3b3b;
    font-weight: 700;
    font-size: 13px;
}
.sidebar-user-info { min-width: 0; flex: 1; }
.sidebar-user-name {
    font-weight: 600;
    font-size: 13px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sidebar-user-plan {
    font-size: 11.5px;
    color: var(--text-muted);
}
.sidebar-user-action {
    background: transparent;
    border: 0;
    padding: 6px;
    color: var(--text-muted);
    border-radius: 8px;
    display: grid; place-items: center;
    transition: background .15s, color .15s;
}
.sidebar-user-action:hover { background: var(--surface-2); color: var(--danger); }

/* ─── Main content area ─── */
.main {
    background: var(--bg);
    min-height: 100vh;
    position: relative;
    display: flex;
    flex-direction: column;
    /* [넘침 루트픽스 2026-06-05] .app(grid)의 자식 .main 은 기본 min-width:auto 라
       내부 콘텐츠(캠페인 표 min-width:160px td 등) 고유폭만큼 트랙이 부풀어 뷰포트를 넘김.
       → min-width:0 으로 트랙이 뷰포트까지 줄어들게 강제. 모바일 가로 넘침의 진짜 원인. */
    min-width: 0;
}
.main > .page { flex: 1 0 auto; min-width: 0; }
.main > .site-footer { flex-shrink: 0; margin-top: auto; }
/* 메쉬는 topbar 영역(상단 80px)에만 살짝, 본문 카드 영역에는 영향 X */
.main::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 240px;
    pointer-events: none;
    z-index: 0;
    background: var(--gradient-mesh);
    opacity: .6;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 14px 32px;
    border-bottom: 1px solid var(--border);
    background: #FFFFFF;
    position: sticky; top: 0; z-index: 50;
    min-height: 64px;
}
.topbar-title-block .topbar-sub {
    font-size: 11.5px;
    color: var(--text-muted);
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.topbar-title-block .topbar-title {
    font-size: 19px;
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--text);
}
.topbar-actions { display: flex; align-items: center; gap: 10px; height: 38px; }
.topbar-actions > * { height: 38px; box-sizing: border-box; }

.credits-badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 0 16px 0 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: var(--shadow-sm);
    transition: border-color .15s, box-shadow .15s;
    color: var(--text-soft);
}
.credits-badge:hover {
    border-color: var(--accent-a);
    box-shadow: 0 4px 14px -6px var(--accent-a);
}
.credits-badge .credits-icon { color: var(--warning); flex-shrink: 0; }
.credits-badge strong {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-size: 15px;
}

.user-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 0 14px 0 5px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    color: var(--text-soft);
    transition: border-color .15s, transform .15s, box-shadow .15s;
}
.user-chip:hover { border-color: var(--accent-a); transform: translateY(-1px); box-shadow: 0 4px 14px -6px var(--accent-a); }
.user-chip .avatar {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--gradient-main);
    color: white;
    font-weight: 700;
    font-size: 12px;
    display: grid; place-items: center;
}

.logout-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 38px; min-width: 38px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text-muted);
    cursor: pointer;
    transition: all .15s ease;
}
.logout-btn:hover {
    color: var(--danger);
    border-color: #fecaca;
    background: #fef2f2;
    transform: translateY(-1px);
}

.page {
    padding: 28px 36px 40px;
    max-width: 1640px;
    width: 100%;
    position: relative;
    z-index: 2;
    /* z-index 2 — .main::before(mesh) 위에 본문이 보이도록.
       단, 내부 .modal(fixed)은 이 stacking context 안에 갇히므로
       footer를 덮으려면 .site-footer 가 stacking context 만들지 말아야 함 (아래 .site-footer에서 z-index 제거) */
}
.page-title {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 6px;
    letter-spacing: -.025em;
}
.page-sub {
    color: var(--text-muted);
    font-size: 14px;
    margin-bottom: 24px;
}

/* ============================================
   카드·박스
   ============================================ */
.card {
    background: #FFFFFF;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: 0 1px 0 rgba(20,19,26,.04), 0 18px 40px -20px rgba(20,19,26,.18);
    position: relative;
    z-index: 1;
    transition: transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s ease, border-color .2s ease;
}
.card-lift:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--border-strong);
}
.card-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 16px;
}
.card-title { font-size: 16px; font-weight: 700; letter-spacing: -.01em; }
.card-sub { color: var(--text-muted); font-size: 13px; }

.glass-card {
    background: color-mix(in oklab, var(--surface) 70%, transparent);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
    box-shadow: var(--shadow-lg);
    border-radius: var(--radius-xl);
}

/* ─── Stat 카드 ─── */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.stat {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 22px;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s ease, border-color .2s;
}
.stat:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
    border-color: var(--border-strong);
}
.stat::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(80% 80% at 100% 0%, var(--accent-tint), transparent 60%);
    pointer-events: none;
}
.stat > * { position: relative; }
.stat-label {
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .02em;
    margin-bottom: 14px;
}
.stat-value {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    font-size: 34px;
    font-weight: 800;
    letter-spacing: -.025em;
    line-height: 1;
    margin-bottom: 8px;
    color: var(--text);
}
.stat-value.gradient {
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.stat-meta { color: var(--text-muted); font-size: 12.5px; }

/* ============================================
   버튼
   ============================================ */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 8px;
    padding: 12px 18px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
    border-radius: 12px;
    transition: transform .15s ease, box-shadow .25s ease, background .2s, border-color .2s;
    border: 1px solid transparent;
    user-select: none;
    white-space: nowrap;
}
.btn:active { transform: translateY(1px) scale(.98); }
.btn-primary {
    background: var(--gradient-main);
    color: white;
    box-shadow: 0 10px 24px -10px var(--accent-a), 0 1px 0 rgba(255,255,255,.2) inset;
    position: relative;
    overflow: hidden;
}
.btn-primary::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%);
    transform: translateX(-100%);
    transition: transform .6s cubic-bezier(.2,.7,.3,1);
}
.btn-primary:hover {
    box-shadow: 0 18px 36px -10px var(--accent-a), 0 1px 0 rgba(255,255,255,.25) inset;
    transform: translateY(-2px);
}
.btn-primary:hover::before { transform: translateX(100%); }
.btn-primary > * { position: relative; z-index: 1; }
.btn-ghost {
    background: var(--surface);
    border-color: var(--border-strong);
    color: var(--text);
}
.btn-ghost:hover { background: var(--surface-2); border-color: var(--border-strong); }
.btn-soft {
    background: var(--accent-tint);
    color: var(--accent-a);
    border-color: transparent;
}
.btn-soft:hover { background: var(--accent-ring); }
.btn-secondary {
    background: var(--surface-2);
    color: var(--text-soft);
    border-color: var(--border);
}
.btn-secondary:hover { background: var(--surface); border-color: var(--border-strong); }
.btn-danger {
    background: var(--danger);
    color: white;
}
.btn-danger:hover { filter: brightness(1.05); transform: translateY(-1px); }

.btn-lg { padding: 16px 22px; font-size: 15px; border-radius: 14px; }
.btn-sm { padding: 8px 12px; font-size: 12.5px; border-radius: 10px; }
.btn-block { width: 100%; }
.btn-icon { padding: 10px; }

/* ============================================
   폼
   ============================================ */
.form-row { margin-bottom: 16px; }
.form-label {
    display: block;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-soft);
    margin-bottom: 8px;
    letter-spacing: -.005em;
}
.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 13px 14px;
    border: 1px solid var(--border);
    border-radius: 12px;
    font-size: 14.5px;
    background: var(--surface-2);
    color: var(--text);
    transition: border-color .15s ease, background .2s, box-shadow .2s;
    outline: none;
}
.form-input:hover,
.form-select:hover,
.form-textarea:hover { border-color: var(--border-strong); }
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--accent-a);
    background: var(--surface);
    box-shadow: 0 0 0 4px var(--accent-ring);
}
.form-textarea { resize: vertical; min-height: 88px; line-height: 1.5; }
.form-help { color: var(--text-muted); font-size: 12px; margin-top: 6px; }
.form-error { color: var(--danger); font-size: 12px; margin-top: 4px; }

/* ============================================
   알림 박스
   ============================================ */
.alert {
    padding: 14px 16px;
    border-radius: 12px;
    font-size: 14px;
    margin-bottom: 16px;
    display: flex; align-items: flex-start; gap: 10px;
    border: 1px solid transparent;
}
.alert-success { background: color-mix(in oklab, var(--success) 8%, transparent); color: #065f46; border-color: color-mix(in oklab, var(--success) 20%, transparent); }
.alert-error   { background: color-mix(in oklab, var(--danger) 8%, transparent);  color: #991b1b; border-color: color-mix(in oklab, var(--danger) 20%, transparent); }
.alert-info    { background: var(--accent-tint); color: #312e81; border-color: var(--accent-ring); }
.alert-warn    { background: color-mix(in oklab, var(--warning) 10%, transparent); color: #92400e; border-color: color-mix(in oklab, var(--warning) 22%, transparent); }

/* ============================================
   배지·태그
   ============================================ */
.badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 600;
    letter-spacing: -.005em;
    background: var(--surface-2);
    color: var(--text-soft);
    border: 1px solid var(--border);
    text-transform: none;
}
.badge .dot { width: 5px; height: 5px; border-radius: 999px; background: currentColor; }
.badge-success { color: var(--success); background: color-mix(in oklab, var(--success) 8%, transparent); border-color: color-mix(in oklab, var(--success) 18%, transparent); }
.badge-warn    { color: var(--warning); background: color-mix(in oklab, var(--warning) 10%, transparent); border-color: color-mix(in oklab, var(--warning) 22%, transparent); }
.badge-danger  { color: var(--danger); background: color-mix(in oklab, var(--danger) 9%, transparent); border-color: color-mix(in oklab, var(--danger) 22%, transparent); }
.badge-info    { color: var(--accent-a); background: var(--accent-tint); border-color: transparent; }
.badge-neutral { color: var(--text-soft); background: var(--surface-2); border-color: var(--border); }

/* ============================================
   테이블
   ============================================ */
.table-wrap {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
table.data {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 13.5px;
}
table.data thead {
    background: var(--surface-2);
}
table.data thead th {
    text-align: left;
    font-weight: 600;
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-muted);
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
}
table.data tbody td {
    padding: 16px;
    border-bottom: 1px solid var(--border);
    color: var(--text-soft);
}
table.data tbody tr:last-child td { border-bottom: 0; }
table.data tbody tr { transition: background .15s ease; }
table.data tbody tr:hover { background: var(--surface-2); }
table.data tbody td strong { color: var(--text); font-weight: 600; }

/* NBL-MOBILE-TABLE-V2 ===== 표는 데스크탑 그대로 + 가로 스크롤(스와이프) (사용자 선택 2026-06-06) =====
   방침: 모바일에서도 데스크탑 '표' 형태 100% 유지. 줄이거나 카드로 바꾸지 않고, 좁으면 래퍼가
        좌우로 스크롤(손가락 스와이프)된다.
   ① 레이아웃 체인(app/main/page/카드/그리드)은 뷰포트에 맞춤 → 페이지 자체 가로넘침은 차단
   ② '표'만 예외: 자연폭(min-width) 유지 + 래퍼 overflow-x:auto 로 표 내부만 좌우 스크롤 */
@media (max-width: 1100px) {
    /* 레이아웃 — 뷰포트까지 줄어들되 '표'는 건드리지 않음 */
    .app, .main, .page { max-width: 100% !important; min-width: 0 !important; }
    .page > *, .dash-row, .nb-stat-grid { max-width: 100% !important; min-width: 0 !important; }
    .dash-row > *, .nb-stat-grid > *, .dash-row .card, .card { min-width: 0 !important; max-width: 100% !important; }
    .page { overflow-x: clip; }   /* 페이지 전체는 가로 넘침 차단(표는 자체 스크롤러로 처리) */

    /* 대시보드 '진행중 캠페인' 카드 — 카드뷰 유지(사용자 요청 2026-06-06).
       blog_deploy 의 '표'들은 스크롤(아래 ≤900px 블록)이지만, 이 대시보드 위젯만 카드형 그대로:
       1줄=캠페인명+날짜 / 2줄=키워드(좌)+진행바(우) / 3줄=상태 */
    .dash-camp-card { overflow-x: hidden !important; }
    .dash-camp-card table.data { min-width: 0 !important; }
    .dash-camp-card table.data,
    .dash-camp-card table.data tbody { display: block !important; width: 100% !important; max-width: 100% !important; box-sizing: border-box; }
    .dash-camp-card table.data thead { display: none !important; }
    .dash-camp-card table.data tr {
        display: flex !important; flex-wrap: wrap !important; align-items: center; column-gap: 10px; row-gap: 6px;
        width: 100% !important; max-width: 100% !important; box-sizing: border-box;
        padding: 12px 0; border-bottom: 1px solid var(--border);
    }
    .dash-camp-card table.data tr:last-child { border-bottom: 0; }
    .dash-camp-card table.data td {
        border: 0 !important; padding: 0 !important; min-width: 0 !important;
        box-sizing: border-box; max-width: 100%;
        white-space: normal !important; overflow-wrap: anywhere; word-break: break-word;
    }
    .dash-camp-card table.data td:nth-child(1) { order: 1 !important; flex: 0 0 100% !important; }               /* 캠페인명+날짜 */
    .dash-camp-card table.data td:nth-child(2) { order: 2 !important; flex: 0 0 auto !important; }               /* 키워드 — 좌 */
    .dash-camp-card table.data td:nth-child(3) { order: 3 !important; flex: 1 1 0 !important; min-width: 0 !important; } /* 진행(텍스트+바) — 우 */
    .dash-camp-card table.data td:nth-child(4) { order: 4 !important; flex: 0 0 100% !important; }               /* 상태 */
    .dash-camp-card table.data td:nth-child(3) .progress { width: 100% !important; max-width: 100% !important; box-sizing: border-box; }
    .dash-camp-card table.data td:nth-child(3) > div:first-child { margin-bottom: 4px; }
    .dash-camp-card table.data td .kw-chip { max-width: 100%; }
}

/* ============================================
   진행도 바
   ============================================ */
.progress {
    height: 6px;
    width: 100%;
    background: var(--bg-soft);
    border-radius: 999px;
    overflow: hidden;
    position: relative;
}
.progress > span {
    display: block;
    height: 100%;
    background: var(--gradient-main);
    border-radius: inherit;
    transition: width .5s cubic-bezier(.2,.7,.3,1);
}

/* ============================================
   로그인·회원가입 (auth pages)
   ============================================ */
.auth-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    background: var(--bg);
}
@media (max-width: 900px) {
    .auth-page { grid-template-columns: 1fr; }
}
.auth-hero {
    background: linear-gradient(160deg, var(--bg-tint), var(--bg-tint-2));
    color: var(--text);
    padding: 56px 48px;
    display: flex; flex-direction: column; justify-content: space-between;
    position: relative;
    overflow: hidden;
}
.auth-hero::before {
    content: '';
    position: absolute;
    width: 520px; height: 520px;
    border-radius: 50%;
    filter: blur(80px);
    top: -180px; left: -120px;
    background: var(--accent-a);
    opacity: .12;
    pointer-events: none;
}
.auth-hero::after {
    content: '';
    position: absolute;
    width: 520px; height: 520px;
    border-radius: 50%;
    filter: blur(80px);
    bottom: -200px; right: -160px;
    background: var(--accent-b);
    opacity: .10;
    pointer-events: none;
}
.auth-hero > * { position: relative; z-index: 1; }
.auth-hero-logo {
    display: inline-flex; align-items: center; gap: 10px;
    font-weight: 700; font-size: 17px;
    letter-spacing: -.02em;
    color: var(--text);
}
.auth-hero-logo .logo-mark {
    width: 32px; height: 32px;
    border-radius: 10px;
    background: var(--gradient-main);
    display: grid; place-items: center;
    color: white;
    font-weight: 800;
    font-family: var(--font-en);
    font-size: 14px;
    box-shadow: 0 6px 16px -8px var(--accent-a);
}
.auth-hero-title {
    font-size: 44px;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -.035em;
    margin-bottom: 18px;
    color: var(--text);
}
.auth-hero-title .gd,
.auth-hero-title .gradient {
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.auth-hero-desc {
    font-size: 15px;
    color: var(--text-soft);
    line-height: 1.6;
    max-width: 420px;
}
.auth-hero-features {
    background: color-mix(in oklab, var(--surface) 70%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
    border-radius: 14px;
    overflow: hidden;
}
.auth-hero-feat {
    display: flex; align-items: flex-start; gap: 14px;
    padding: 16px;
    background: transparent;
    border: 0;
    border-bottom: 1px solid color-mix(in oklab, var(--border) 50%, transparent);
}
.auth-hero-feat:last-child { border-bottom: 0; }
.auth-hero-feat .feat-icon {
    width: 36px; height: 36px;
    border-radius: 11px;
    background: var(--gradient-main);
    color: white;
    display: grid; place-items: center;
    flex-shrink: 0;
}
.auth-hero-feat h4 { font-size: 14px; font-weight: 700; margin-bottom: 4px; color: var(--text); }
.auth-hero-feat p { font-size: 13px; color: var(--text-muted); }

.auth-form {
    display: flex; align-items: center; justify-content: center;
    padding: 40px;
    background: var(--surface);
}
.auth-form-inner { width: 100%; max-width: 420px; }
.auth-form-title {
    font-size: 30px;
    font-weight: 800;
    letter-spacing: -.025em;
    margin-bottom: 8px;
}
.auth-form-sub {
    color: var(--text-muted);
    font-size: 14.5px;
    margin-bottom: 30px;
}
.auth-divider {
    text-align: center;
    margin: 22px 0 16px;
    color: var(--text-faint);
    font-size: 12px;
    position: relative;
    display: flex; align-items: center; gap: 12px;
}
.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}
.auth-divider span { display: inline-block; }
.auth-bottom {
    text-align: center;
    margin-top: 22px;
    font-size: 13.5px;
    color: var(--text-muted);
}
.auth-bottom a {
    color: var(--accent-a);
    font-weight: 700;
}

/* ============================================
   유틸리티
   ============================================ */
.text-gradient,
.grad-text {
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.grad-bg { background: var(--gradient-main); color: white; }

.flex { display: flex; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-8  { gap: 8px; }
.gap-12 { gap: 12px; }
.gap-16 { gap: 16px; }
.mt-8  { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.hidden { display: none !important; }
.text-muted { color: var(--text-muted); }
.text-sm { font-size: 13px; }
.text-xs { font-size: 12px; }
.fw-700 { font-weight: 700; }
.fw-800 { font-weight: 800; }
.num {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    letter-spacing: -.025em;
}

/* ============================================
   체크박스
   ============================================ */
.checkbox-row {
    display: flex; align-items: flex-start; gap: 10px;
    margin-bottom: 8px;
    font-size: 14px;
    color: var(--text-soft);
}
.checkbox-row input[type=checkbox] {
    margin-top: 2px;
    width: 18px; height: 18px;
    accent-color: var(--accent-a);
    cursor: pointer;
}
.checkbox-row label { cursor: pointer; user-select: none; }

/* ============================================
   푸터
   ============================================ */
.site-footer {
    border-top: 1px solid var(--border);
    background: var(--surface);
    padding: 28px 32px;
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.7;
    /* position/z-index 지정 X — stacking context 만들면 .modal(fixed)이 footer 위에 못 올라옴 */
}
.site-footer strong { color: var(--text-soft); }

/* ============================================
   모달 (blog_deploy 등에서 사용)
   ============================================ */
.modal {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(20,19,26,.5) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: none;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2000 !important;
    padding: 20px !important;
    margin: 0 !important;
}
.modal.active { display: flex !important; }
.modal-content {
    position: relative !important;
    margin: auto !important;
    max-height: 90vh;
    overflow-y: auto;
}
.modal-content {
    background: var(--surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.modal-content.modal-sm { max-width: 440px; }
.modal-content.modal-md { max-width: 600px; }
.modal-content.modal-lg { max-width: 880px; }
.modal-content.modal-xl { max-width: 1100px; max-height: 88vh; }

.modal-header {
    padding: 18px 20px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px;
}
.modal-header h2 {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -.01em;
}
.modal-close {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: transparent;
    color: var(--text-muted);
    border: 0;
    display: grid; place-items: center;
    cursor: pointer;
    transition: background .15s, color .15s;
    font-size: 18px;
}
.modal-close:hover { background: var(--surface-2); color: var(--text); }

.modal-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    padding: 14px 20px;
    border-top: 1px solid var(--border);
}

/* ============================================
   blog_deploy 페이지 클래스 (bd-*) — 통일
   ============================================ */
.bd-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}
.bd-card-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 20px;
    border-bottom: 1px solid var(--border);
    gap: 12px;
    flex-wrap: wrap;
}
.bd-card-header h2 {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -.01em;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.bd-header-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.bd-tabs {
    /* [좌측정렬 2026-06-06] inline-flex 는 부모 text-align 영향을 받아 쏠릴 수 있어 flex+좌측고정으로 변경 */
    display: flex;
    width: fit-content;
    max-width: 100%;
    margin-right: auto;       /* 왼쪽에 붙임 */
    justify-content: flex-start;
    gap: 4px;
    padding: 4px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.bd-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: transparent;
    border: 0;
    border-radius: 9px;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.bd-tab:hover { color: var(--text); }
.bd-tab.active {
    background: var(--surface-2);
    color: var(--text);
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.bd-tab-content { display: none; }
.bd-tab-content.active { display: block; }

.bd-form { padding: 20px; display: flex; flex-direction: column; gap: 16px; }
.bd-form-group { display: flex; flex-direction: column; }
.bd-form-row { display: grid; gap: 12px; }
.bd-form-row-2 { grid-template-columns: 1fr 1fr; }
.bd-form-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.bd-label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-soft);
    margin-bottom: 8px;
    letter-spacing: -.005em;
}
.bd-input,
.bd-textarea {
    width: 100%;
    padding: 11px 13px;
    border: 1px solid var(--border);
    border-radius: 10px;
    font-size: 14px;
    background: var(--surface-2);
    color: var(--text);
    transition: border-color .15s, background .2s, box-shadow .2s;
    outline: none;
}
.bd-input:hover, .bd-textarea:hover { border-color: var(--border-strong); }
.bd-input:focus, .bd-textarea:focus {
    border-color: var(--accent-a);
    background: var(--surface);
    box-shadow: 0 0 0 4px var(--accent-ring);
}
.bd-textarea { resize: vertical; min-height: 88px; line-height: 1.55; }
.bd-textarea-lg { min-height: 200px; }
.bd-input-icon { position: relative; }
.bd-input-icon i {
    position: absolute; right: 12px; top: 50%;
    transform: translateY(-50%);
    color: var(--text-faint);
    font-size: 13px;
    pointer-events: none;
}
.bd-input-icon .bd-input { padding-right: 32px; }

.bd-form-footer {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px;
    padding: 14px 0 0;
    border-top: 1px solid var(--border);
    margin-top: 4px;
    flex-wrap: wrap;
}

.bd-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 6px;
    padding: 10px 16px;
    border-radius: 10px;
    font-size: 13.5px;
    font-weight: 600;
    line-height: 1;
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    cursor: pointer;
    transition: transform .15s, box-shadow .25s, background .2s, border-color .2s;
    white-space: nowrap;
}
.bd-btn:hover { border-color: var(--border-strong); }
.bd-btn-primary {
    background: var(--gradient-main);
    color: white;
    border-color: transparent;
    box-shadow: 0 10px 24px -10px var(--accent-a);
}
.bd-btn-primary:hover {
    box-shadow: 0 14px 30px -10px var(--accent-a);
    transform: translateY(-1px);
}
.bd-btn-secondary {
    background: var(--surface-2);
    color: var(--text-soft);
    border-color: var(--border);
}
.bd-btn-secondary:hover { background: var(--surface); }
.bd-btn-danger {
    background: var(--danger);
    color: white;
    border-color: transparent;
}
.bd-btn-danger:hover { filter: brightness(1.05); transform: translateY(-1px); }
.bd-btn-sm { padding: 7px 11px; font-size: 12px; border-radius: 8px; }
.bd-btn-full { width: 100%; }
.bd-btn-icon { padding: 9px; }

.bd-search-box {
    position: relative;
    display: flex; align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0 10px;
}
.bd-search-box i { color: var(--text-faint); font-size: 12px; }
.bd-search-box input {
    flex: 1;
    border: 0;
    background: transparent;
    padding: 8px 10px;
    font-size: 13px;
    outline: none;
    min-width: 0;
}
.bd-search-box:focus-within {
    border-color: var(--accent-a);
    box-shadow: 0 0 0 4px var(--accent-ring);
}

.bd-list-toolbar {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--surface-2);
    flex-wrap: wrap;
}
.bd-switch-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-soft);
    cursor: pointer;
}
.bd-switch {
    position: relative;
    display: inline-block;
    width: 34px; height: 18px;
}
.bd-switch input { opacity: 0; width: 0; height: 0; }
.bd-switch-slider {
    position: absolute;
    inset: 0;
    background: var(--border-strong);
    border-radius: 999px;
    transition: background .2s;
}
.bd-switch-slider::before {
    content: '';
    position: absolute;
    left: 2px; top: 2px;
    width: 14px; height: 14px;
    background: white;
    border-radius: 50%;
    transition: transform .2s;
}
.bd-switch input:checked + .bd-switch-slider { background: var(--accent-a); }
.bd-switch input:checked + .bd-switch-slider::before { transform: translateX(16px); }
.bd-batch-actions { display: inline-flex; gap: 6px; }

.bd-table-wrapper {
    overflow-x: auto;
}
.bd-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 13px;
}
.bd-table thead {
    background: var(--surface-2);
}
.bd-table thead th {
    text-align: left;
    padding: 12px 14px;
    font-size: 11.5px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
}
.bd-table tbody td {
    padding: 14px;
    border-bottom: 1px solid var(--border);
    color: var(--text-soft);
}
.bd-table tbody tr:hover { background: var(--surface-2); }
.bd-table tbody tr:last-child td { border-bottom: 0; }

.bd-sortable .bd-sort-ind {
    font-size: 10px;
    color: var(--text-faint);
}

.bd-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;
    padding: 16px;
}
.bd-pagination button {
    min-width: 32px;
    height: 32px;
    padding: 0 10px;
    border-radius: 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text-soft);
    font-size: 12.5px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.bd-pagination button:hover { border-color: var(--accent-a); color: var(--accent-a); }
.bd-pagination button.active {
    background: var(--gradient-main);
    color: white;
    border-color: transparent;
}

/* 토스트 — 항상 우측 상단 고정 (모든 페이지 공통) */
.bd-toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    left: auto;
    bottom: auto;
    transform: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 9999;
    pointer-events: none;
    max-width: min(380px, calc(100vw - 32px));
}
.bd-toast {
    padding: 12px 18px;
    background: var(--text);
    color: white;
    border-radius: 10px;
    font-size: 13.5px;
    font-weight: 600;
    box-shadow: var(--shadow-lg);
    pointer-events: auto;
    animation: nbToastIn .25s cubic-bezier(.2,.7,.3,1);
}
.bd-toast.success { background: var(--success); }
.bd-toast.error   { background: var(--danger); }
.bd-toast.warning { background: var(--warning); }

@keyframes nbToastIn {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* radio-pill (campaign_new) */
.radio-pill {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 11px 14px;
    border: 1px solid var(--border);
    border-radius: 11px;
    cursor: pointer;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--text-muted);
    background: var(--surface);
    transition: all .15s ease;
}
.radio-pill:hover { border-color: var(--border-strong); color: var(--text); }
.radio-pill.active {
    border-color: var(--accent-a);
    background: var(--accent-tint);
    color: var(--accent-a);
}
.radio-pill input[type=radio] { display: none; }

/* fade-in 애니메이션 (landing) */
.fade-in {
    opacity: 0;
    transform: translateY(14px);
    animation: nb-fade .7s cubic-bezier(.2,.7,.3,1) forwards;
}
.fade-in[data-d="1"] { animation-delay: .08s; }
.fade-in[data-d="2"] { animation-delay: .16s; }
.fade-in[data-d="3"] { animation-delay: .24s; }
.fade-in[data-d="4"] { animation-delay: .32s; }
@keyframes nb-fade {
    to { opacity: 1; transform: none; }
}

/* 캘린더 (blog_deploy logs 탭) */
.bd-calendar-header-row,
.bd-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}
.bd-cal-day-header {
    text-align: center;
    padding: 8px 0;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
}
.bd-cal-sun { color: var(--danger); }
.bd-cal-sat { color: var(--accent-a); }

@media (max-width: 720px) {
    .topbar { padding: 10px 14px; min-height: 56px; }
    .page { padding: 18px 14px 28px; }
    .auth-form { padding: 28px 20px; }
}

/* ============================================
   태블릿·작은 데스크탑 (1100px 이하) — 폼 그리드 깨짐 방지
   ============================================ */
@media (max-width: 1100px) {
    .bd-form-row,
    .bd-form-row-2,
    .bd-form-row-3 {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    .bd-form-group [style*="grid-template-columns:repeat(3,1fr)"],
    .bd-form-group [style*="grid-template-columns:repeat(6,1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    /* card 안 모든 자식 부모 폭 안에 강제 (overflow 방지) */
    .card, .bd-card { max-width: 100%; box-sizing: border-box; }
    .card *, .bd-card * { max-width: 100%; }
    .card input, .card select, .card textarea,
    .bd-card input, .bd-card select, .bd-card textarea { width: 100%; box-sizing: border-box; }
    /* sticky 미리보기 카드 — 좁은 화면에선 sticky 풀어서 폼 아래로 흐름 */
    form[style*="grid-template-columns:1.5fr 1fr"] {
        grid-template-columns: 1fr !important;
    }
    form[style*="grid-template-columns:1.5fr 1fr"] > div .card[style*="sticky"] {
        position: static !important;
    }
}

/* ============================================
   모바일·작은 데스크탑 햄버거 모드 (1100px 이하)
   ============================================ */
@media (max-width: 1100px) {
    .app { grid-template-columns: 1fr; }

    /* 사이드바를 화면 밖으로 슬라이드, 햄버거 토글로 열기 */
    .sidebar {
        position: fixed !important;
        top: 0; left: 0;
        width: 86vw;
        max-width: 320px;
        height: 100vh;
        z-index: 1100; /* topbar(50) + 모달(2000) 사이 — topbar 보다 무조건 위 */
        transform: translateX(-100%);
        transition: transform .28s cubic-bezier(.2,.7,.3,1);
        box-shadow: 0 30px 60px -20px rgba(0,0,0,.35);
        padding: 18px 14px;
    }
    .sidebar.is-open { transform: none; }

    /* 백드롭 */
    .sidebar-backdrop {
        position: fixed; inset: 0;
        background: rgba(20,19,26,.45);
        opacity: 0;
        pointer-events: none;
        transition: opacity .25s;
        z-index: 1099;
    }
    .sidebar-backdrop.is-open {
        opacity: 1;
        pointer-events: auto;
    }

    /* 햄버거 버튼 — 좌측 첫 위치, 더 눈에 띄게 */
    .hamburger-btn {
        display: inline-flex !important;
        align-items: center; justify-content: center;
        width: 40px; height: 40px;
        background: var(--surface);
        border: 1px solid var(--border-strong);
        border-radius: 10px;
        color: var(--text);
        cursor: pointer;
        flex-shrink: 0;
        margin-right: auto;
    }
    .hamburger-btn:active { background: var(--surface-2); }

    /* topbar 레이아웃 — 햄버거(좌) ↔ 액션(우) 양끝 정렬 */
    .topbar {
        padding: 10px 14px !important;
        min-height: 58px !important;
        gap: 8px !important;
        justify-content: space-between !important;
    }
    .topbar-actions {
        margin-left: 0 !important;
        gap: 6px !important;
    }
    .credits-badge {
        padding: 0 12px 0 10px;
        font-size: 12px;
        height: 36px !important;
    }
    .credits-badge strong { font-size: 13px; }
    .credits-badge .credits-icon { width: 14px; height: 14px; }
    .user-chip span { display: none; }
    .user-chip {
        padding: 0 5px;
        height: 36px !important;
        width: 36px;
        justify-content: center;
    }
    .logout-btn {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
    }
    .topbar-actions > * { height: 36px !important; }

    /* 페이지 본문 */
    .page { padding: 16px 14px 32px; }
    .dash-hero {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 18px;
    }
    .dash-hero h1 { font-size: 22px !important; }
    .dash-hero p { font-size: 13px !important; }
    .dash-actions { width: 100%; flex-wrap: wrap; }
    .dash-actions .btn { flex: 1; min-width: 0; }

    /* 그리드: 모바일에선 2컬럼 (인라인 6컬럼·3컬럼도 강제) */
    .nb-stat-grid,
    .nb-stat-grid[style*="grid-template-columns"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    .dash-row,
    .dash-row[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        margin-bottom: 12px;
    }

    /* 카드 padding 압축 */
    .card { padding: 14px !important; border-radius: 14px !important; }
    .nb-stat { padding: 14px !important; border-radius: 14px !important; }
    .nb-stat-value { font-size: 24px !important; }
    .nb-stat-label { font-size: 11px !important; }
    .nb-stat-head { margin-bottom: 12px !important; }
    .nb-stat-icon { width: 28px !important; height: 28px !important; }
    .nb-stat-foot { font-size: 11.5px !important; }
    .nb-stat-grid { gap: 8px !important; }
    .dash-row { gap: 10px !important; }
    .card-header { margin-bottom: 12px; }
    .card-title { font-size: 15px !important; }
    .card-sub { font-size: 12px !important; }

    /* 폼 — 터치 영역 충분히 (44px↑) + iOS 자동 줌 방지 */
    .form-row .form-input,
    .form-row .form-textarea,
    .form-row .form-select,
    .bd-form-group .bd-input,
    .bd-form-group .bd-textarea {
        font-size: 16px !important;
        padding: 13px 14px !important;
        min-height: 46px;
    }
    /* select 글로벌 컴팩트 (헤더·필터·툴바 등 모든 select) */
    select,
    select.form-input,
    select.bd-input {
        font-size: 13px !important;
        padding: 7px 28px 7px 10px !important;
        height: 36px !important;
        min-height: 36px !important;
        max-height: 36px !important;
        line-height: 1.2 !important;
        background-position: right 8px center !important;
    }
    /* form-row 안 select 만 큼지막 */
    .form-row select.form-input,
    .form-row .form-select,
    .bd-form-group select.bd-input {
        font-size: 16px !important;
        height: 46px !important;
        min-height: 46px !important;
        max-height: 46px !important;
        padding: 12px 32px 12px 14px !important;
    }

    /* 일반 input 도 헤더·툴바 같은 좁은 곳에선 작게 */
    input[type="date"]:not(.form-row input):not(.bd-form-group input),
    input[type="search"]:not(.form-row input):not(.bd-form-group input),
    input[type="text"][style*="width:auto"],
    input[style*="padding:6px"],
    input[style*="padding:9px"] {
        font-size: 13px !important;
        height: 36px !important;
        min-height: 36px !important;
        padding: 7px 10px !important;
    }

    .form-row { margin-bottom: 14px; }
    .btn { min-height: 44px; padding: 12px 18px !important; }
    .btn-sm { min-height: 36px !important; padding: 8px 12px !important; }
    .bd-btn { min-height: 42px; }
    .bd-btn-sm { min-height: 34px !important; padding: 7px 10px !important; }
    .radio-pill { min-height: 46px; padding: 10px 12px !important; font-size: 13px !important; }

    /* 테이블 — 가로 스크롤 */
    .card .data,
    .bd-table {
        font-size: 12.5px !important;
    }
    .card > div:has(table), .bd-table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* charge_log 등 헤더 안 필터 영역 */
    .card-header {
        flex-wrap: wrap;
        gap: 10px;
    }
    .card-header .form-input,
    .card-header input[type="date"],
    .card-header select {
        flex: 1;
        min-width: 0;
        font-size: 13px !important;
        padding: 8px 10px !important;
    }

    /* 모달 모바일 최적화 */
    .modal-content {
        width: calc(100vw - 24px) !important;
        max-width: none !important;
        margin: 12px auto;
        border-radius: 16px;
    }

    /* 사이드바 내부 — 좁아진 사이드바 (268px) 에서도 그대로 OK */
    .sidebar-brand { padding: 4px 12px; }
    .nav-item { font-size: 14px; }

    /* 사이드바 안 닫기 버튼 영역 확보 */
    .sidebar-close {
        display: inline-flex !important;
        position: absolute;
        top: 14px; right: 12px;
        width: 32px; height: 32px;
        align-items: center; justify-content: center;
        background: var(--surface-2);
        border: 1px solid var(--border);
        border-radius: 50%;
        color: var(--text-muted);
        cursor: pointer;
    }

    /* lp(랜딩) 모바일 */
    .lp-nav { padding: 12px 16px !important; }
    .lp-nav-links { display: none !important; }
    .lp-hero { padding: 40px 16px 30px !important; }
    .lp-hero h1 { font-size: 34px !important; line-height: 1.1; }
    .lp-hero-inner { grid-template-columns: 1fr !important; gap: 32px !important; }
    .lp-hero-stat-row { gap: 16px !important; flex-wrap: wrap; }
    .lp-section { padding: 50px 16px !important; }
    .lp-section-head h2 { font-size: 28px !important; }
    .lp-features { grid-template-columns: 1fr !important; }
    .lp-bigstats-inner { grid-template-columns: 1fr !important; gap: 28px !important; }
    .lp-bigstats h2 { font-size: 26px !important; }
    .lp-pricing { grid-template-columns: 1fr !important; }
    .lp-cta { padding: 32px 22px !important; flex-direction: column; align-items: flex-start; border-radius: 22px; }
    .lp-cta h2 { font-size: 24px !important; }
    .lp-footer { padding: 18px 16px; flex-direction: column; align-items: flex-start; gap: 10px; }

    /* auth 페이지 모바일 */
    .auth-page { grid-template-columns: 1fr !important; }
    /* 모바일: 히어로를 숨기지 않고 컴팩트하게 — 가입 전 신뢰 요소 유지 */
    .auth-hero { display: flex !important; flex-direction: column; padding: 26px 22px 6px !important; min-height: auto !important; }
    .auth-hero::before, .auth-hero::after { display: none !important; }
    .auth-hero-desc, .auth-hero-features { display: none !important; }
    .auth-hero-title { font-size: 25px !important; margin-bottom: 0 !important; }
    .auth-form { padding: 24px 20px 32px !important; min-height: auto; }
    .auth-form-inner { max-width: 100% !important; }
    .auth-form-title { font-size: 24px !important; }
}

/* 데스크탑에선 햄버거·백드롭 숨김 */
.hamburger-btn { display: none; }
.sidebar-backdrop { display: none; }
.sidebar-close { display: none; }

/* 작은 모바일 (560px) */
@media (max-width: 560px) {
    .nb-stat-grid { grid-template-columns: 1fr !important; }
    .dash-hero h1 { font-size: 20px !important; }
    .lp-hero h1 { font-size: 28px !important; }
    .lp-section-head h2 { font-size: 22px !important; }
    .topbar { padding: 8px 12px; }
    .credits-badge {
        padding: 0 10px;
    }
    .credits-badge strong { display: inline; font-size: 12px; }
}

/* ============================================
   모바일 — 페이지별 정밀 보강
   ============================================ */
@media (max-width: 900px) {
    /* ── blog_deploy 폼 — 3컬럼 → 1컬럼 ── */
    .bd-form-row,
    .bd-form-row-2,
    .bd-form-row-3 {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    .bd-form { padding: 16px !important; gap: 14px !important; }
    .bd-form-group { margin: 0 !important; }

    /* 라디오 칩 (글 스타일·이미지 소스) — 6개를 2컬럼으로 */
    .bd-form-group .radio-pill {
        font-size: 12.5px !important;
        padding: 12px 8px !important;
        text-align: center;
        line-height: 1.25;
        word-break: keep-all;
    }
    .bd-form-group .radio-pill span { font-size: inherit !important; }
    .bd-form-group [style*="grid-template-columns:repeat(3,1fr)"],
    .bd-form-group [style*="grid-template-columns:repeat(6,1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .bd-form-group [style*="display:flex"][style*="flex-wrap"] { gap: 6px !important; }

    /* bd-tabs — 가로 스크롤 (좁은 화면에서 4탭 줄바꿈 방지) */
    .bd-tabs {
        overflow-x: auto;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
        flex-wrap: nowrap !important;
        scrollbar-width: none;
    }
    .bd-tabs::-webkit-scrollbar { display: none; }
    .bd-tab { flex-shrink: 0; padding: 8px 12px !important; font-size: 12.5px !important; }

    /* bd-card 헤더 wrap */
    .bd-card-header {
        flex-wrap: wrap !important;
        padding: 14px 16px !important;
    }
    /* [좌측정렬 강제 2026-06-06] 모바일에서 헤더 제목(대량 접수·진행 캠페인 등)을 무조건 왼쪽으로.
       h2 가 한 줄을 다 차지(width:100%)하게 해서 좌측 고정, 컨트롤은 자연히 아래 줄로. */
    .bd-card-header { justify-content: flex-start !important; }
    .bd-card-header h2 {
        font-size: 14px !important;
        display: flex !important;                 /* inline-flex → flex: 풀폭 블록으로 확실히 좌측 */
        width: 100% !important;
        text-align: left !important;
        justify-content: flex-start !important;    /* 아이콘+텍스트 좌측 */
        align-self: flex-start !important;
    }
    .bd-header-controls { width: 100%; flex-wrap: wrap; gap: 6px !important; justify-content: flex-start !important; }
    .bd-search-box { flex: 1; min-width: 0; }
    .bd-header-controls select,
    .bd-header-controls input { flex: 1; min-width: 0; font-size: 12px !important; }

    /* bd-list-toolbar — 모바일에선 wrap */
    .bd-list-toolbar { padding: 10px 16px !important; gap: 8px !important; }
    .bd-batch-actions { width: 100%; flex-wrap: wrap; }

    /* ─── 표 — 데스크탑 그대로 + 가로 스크롤(스와이프). 카드변환 안 함 (사용자 선택 2026-06-06) ─── */
    .bd-table-wrapper,
    .card > div[style*="overflow-x"] {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        background: none !important;
    }
    .bd-table-wrapper::after { display: none !important; }
    /* 표 본체 — 데스크탑 형태 유지(display:table), 줄이지 않고 래퍼가 좌우 스크롤 */
    .bd-table,
    .charge-log-tbl,
    table.data {
        display: table !important;
        width: 100%;
        min-width: 720px;   /* 컬럼 안 뭉개지게 — 좁으면 래퍼가 스와이프 스크롤 */
    }
    .bd-table thead, .charge-log-tbl thead, table.data thead { display: table-header-group !important; }
    .bd-table tbody, .charge-log-tbl tbody, table.data tbody { display: table-row-group !important; }
    .bd-table tbody tr, .charge-log-tbl tbody tr, table.data tbody tr { display: table-row !important; }
    .bd-table tbody td, .charge-log-tbl tbody td, table.data tbody td { display: table-cell !important; }
    /* 빈 상태·로딩(colspan) 행만 있을 땐 스크롤 없이 폭 맞춰 가운데 */
    .bd-table:has(tbody td[colspan]),
    .charge-log-tbl:has(tbody td[colspan]),
    table.data:has(tbody td[colspan]) { min-width: 100% !important; }
    .bd-table tbody td[colspan],
    .charge-log-tbl tbody td[colspan],
    table.data tbody td[colspan] { text-align: center !important; padding: 36px 20px !important; }
    .bd-table tbody td[colspan] i,
    .charge-log-tbl tbody td[colspan] i,
    table.data tbody td[colspan] i { display: block; font-size: 22px !important; margin-bottom: 8px; opacity: .5; }

    /* ─── blog_deploy 월별 요약 4카드 (인라인 4컬럼) → 2컬럼 강제 ─── */
    #tab-logs > .bd-card > div[style*="grid-template-columns:repeat(4,1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
        padding: 12px 14px !important;
    }
    #tab-logs > .bd-card > div[style*="grid-template-columns:repeat(4,1fr)"] > div {
        padding: 12px !important;
    }
    #tab-logs > .bd-card > div[style*="grid-template-columns:repeat(4,1fr)"] .num {
        font-size: 18px !important;
    }

    /* ─── 캘린더 (7컬럼) — 좁은 폰트·셀 ─── */
    .bd-calendar-header-row,
    .bd-calendar-grid {
        gap: 2px !important;
    }
    .bd-cal-day-header { font-size: 9.5px !important; padding: 4px 0 !important; }
    .bd-calendar-grid > * {
        font-size: 11px !important;
        padding: 6px 2px !important;
        min-height: 36px;
    }

    /* card-header / bd-card-header 안 필터 영역 — 컴팩트 모드 */
    .card-header > div[style*="display:flex"],
    .bd-card-header > div[style*="display:flex"],
    .bd-card-header > div.bd-header-controls,
    .card-header[style*="flex-wrap"] {
        gap: 6px !important;
        flex-wrap: wrap !important;
    }
    .card-header input,
    .card-header select,
    .card-header .form-input,
    .bd-card-header input,
    .bd-card-header select,
    .bd-card-header .bd-input,
    .bd-search-box {
        font-size: 13px !important;
        min-height: 36px !important;
        height: 36px !important;
        padding: 6px 10px !important;
        min-width: 0 !important;
        width: auto !important;
        flex: 1 1 calc(50% - 6px) !important;
        max-width: 100%;
    }
    .bd-search-box input { font-size: 13px !important; padding: 4px 6px !important; }
    .card-header button.btn,
    .bd-card-header button.bd-btn {
        min-height: 36px !important;
        padding: 6px 10px !important;
        font-size: 12px !important;
        flex: 0 0 auto;
    }
    .card-header span,
    .bd-card-header span { flex: 0 0 auto; }

    /* 빈 상태 — 컴팩트 */
    .empty-state { padding: 40px 16px !important; }
    .empty-state-icon { width: 50px !important; height: 50px !important; }
    .empty-state-title { font-size: 15px !important; }
    .empty-state-desc { font-size: 13px !important; }

    /* charge_log 페이지의 거래내역(transactions) 카드 모드에서 우측 변동/잔액 컬럼 */
    #txListBody tr td:nth-child(3),
    #txListBody tr td:nth-child(4) {
        display: inline-block !important;
        margin-right: 12px;
    }

    /* 모든 인라인 grid (5컬럼·6컬럼·7컬럼) — 모바일에서 2컬럼 강제 */
    [style*="grid-template-columns:repeat(4"],
    [style*="grid-template-columns:repeat(5"],
    [style*="grid-template-columns:repeat(6"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    [style*="grid-template-columns:repeat(7"] {
        grid-template-columns: repeat(7, 1fr) !important;
    }
    /* 캘린더(7컬럼)만 예외 — 위에서 폰트 줄여 처리 */

    /* bd-form-footer — 비용 미리보기 + 접수 버튼 세로 */
    .bd-form-footer { flex-direction: column; align-items: stretch !important; gap: 10px !important; }
    .bd-form-footer .bd-btn { width: 100%; }
    #deployCostPreview { font-size: 12px !important; flex-wrap: wrap; }

    /* 캘린더 (배포 로그 탭) */
    .bd-calendar-wrapper { padding: 8px 12px !important; }
    .bd-cal-day-header { font-size: 10px !important; padding: 6px 0 !important; }
    .bd-calendar-grid { font-size: 11px !important; }

    /* 엑셀 일괄 접수 안내 박스 — 폰트 줄임 */
    #tab-register .bd-card > div[style*="dashed"] {
        font-size: 11.5px !important;
        line-height: 1.6 !important;
    }

    /* ── campaign_new — 결제 미리보기 sticky 풀너비 ── */
    form[style*="grid-template-columns:1.5fr 1fr"] {
        display: block !important;
    }
    form[style*="grid-template-columns:1.5fr 1fr"] > div:last-child .card {
        position: static !important;
        margin-top: 14px;
    }
    .radio-pill { font-size: 12.5px; padding: 10px 12px; }

    /* ── charge.php — 좌우 dash-row 1컬럼 (모바일) ── */
    .dash-row { grid-template-columns: 1fr !important; }

    /* charge.php estimate 카드 — 가로 길어서 wrap */
    #estimate [style*="display:flex"][style*="align-items:baseline"] {
        font-size: 14px !important;
    }
    #estAmount { font-size: 24px !important; }

    /* ── charge_log — 필터 영역 wrap ── */
    .card-header { flex-wrap: wrap !important; padding: 14px 16px !important; }
    .card-header > div:last-child { width: 100%; flex-wrap: wrap; }
    .charge-log-tbl,
    table.data { min-width: 700px; font-size: 12px !important; }
    table.data thead th { padding: 10px 12px !important; font-size: 10.5px !important; }
    table.data tbody td { padding: 11px 12px !important; }

    /* charge_log 페이지네이션 */
    #chargeLogPagination { flex-wrap: wrap; gap: 4px !important; }

    /* ── mypage — 프로필 카드 + stat 1컬럼 ── */
    .dash-row[data-d="1"] > div[style*="flex-direction:column"] { gap: 14px !important; }
    .dash-row[data-d="1"] .nb-stat { padding: 14px !important; }

    /* ── campaign_view — 정보 그리드 1컬럼 ── */
    .card [style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
    }

    /* ── announcements ── */
    .ann-row { gap: 10px !important; padding: 14px 16px !important; }
    .ann-badge { font-size: 10px !important; padding: 2px 8px !important; }
    .ann-title { font-size: 13.5px !important; }
    .ann-meta { font-size: 11px !important; }
    .ann-body { font-size: 13px !important; padding: 12px !important; }
    .ann-chevron { width: 16px; height: 16px; }

    /* ── 랜딩 (index.php) 모바일 보강 ── */
    .lp-hero { padding: 32px 16px 24px !important; }
    .lp-hero-badge { font-size: 11.5px !important; padding: 6px 12px !important; }
    .lp-hero p { font-size: 14.5px !important; line-height: 1.55 !important; }
    .lp-hero-cta { flex-direction: column; }
    .lp-hero-cta .btn { width: 100%; }
    .lp-hero-stat-row { gap: 14px !important; padding-top: 20px !important; flex-wrap: wrap !important; }
    .lp-hero-stat-row > div { flex: 1; min-width: 95px; }
    .lp-hero-stat-row .stat-key { font-size: 20px !important; }
    .lp-hero-stat-row .stat-lab { font-size: 11.5px !important; }
    .lp-hero-card { padding: 16px !important; }
    .lp-hero-card-title { font-size: 11px !important; }
    .lp-hero-meter-value { font-size: 18px !important; }
    .lp-hero-listitem { padding: 9px 11px !important; }
    .lp-hero-listitem-title { font-size: 12px !important; }
    .lp-hero-listitem-sub { font-size: 11px !important; }
    .lp-feat { padding: 22px !important; }
    .lp-feat h3 { font-size: 17px !important; }
    .lp-feat p { font-size: 13.5px !important; }
    .lp-bigstats-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
    .lp-bigstat { padding: 18px !important; }
    .lp-bigstat .key { font-size: 28px !important; }
    .lp-plan { padding: 24px !important; }
    .lp-plan-price .num { font-size: 32px !important; }
    .lp-testimonial-text { font-size: 15px !important; }
    .lp-faq-item summary { font-size: 15px !important; gap: 10px !important; }

    /* ── 알림·공지 사이드 위젯 (dashboard) ── */
    #announcementCard, #notificationCard { padding: 0 !important; }
    #announcementCard .card-header,
    #notificationCard .card-header { padding: 14px 16px !important; }
    #announcementBody > div,
    #notificationBody > div { padding: 12px 16px !important; }

    /* sparkline 차트 카드 헤더 - 모바일 wrap */
    .dash-chart-head { flex-direction: column; align-items: flex-start; gap: 10px !important; }
    .dash-chart-value { font-size: 26px !important; }
    .dash-range-tabs { align-self: flex-end; }

    /* ── 모달 풀스크린 + 내부 폼 wrap ── */
    .modal-content.modal-xl,
    .modal-content.modal-lg,
    .modal-content.modal-md,
    .modal-content.modal-sm { max-width: none !important; max-height: 95vh; }
    .modal-header { padding: 14px 16px !important; }
    .modal-header h2 { font-size: 15px !important; }

    /* ── 토스트 모바일 위치 (우측 상단 고정 유지) ── */
    .bd-toast-container {
        top: 12px !important;
        right: 12px !important;
        left: auto !important;
        bottom: auto !important;
        transform: none !important;
        max-width: calc(100vw - 24px);
    }
    .bd-toast { padding: 10px 14px !important; font-size: 12.5px !important; }
}

/* 추가: 작은 모바일 360px 이하 */
@media (max-width: 380px) {
    .dash-hero h1 { font-size: 19px !important; }
    .nb-stat-value { font-size: 22px !important; }
    .bd-card-header h2 { font-size: 13px !important; }
    .credits-badge .credits-label { display: none; }  /* 라벨만 숨기고 숫자(strong)는 유지 → "N건" */
    .credits-badge { font-size: 11px; }
    .lp-hero h1 { font-size: 26px !important; }
    .lp-bigstats-grid { grid-template-columns: 1fr !important; }
}

/* ============================================
   AA dashboard 전용 컴포넌트
   ============================================ */

/* hero header (인사말 + 액션) */
.dash-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
}
.dash-hero h1 {
    font-size: 28px;
    font-weight: 800;
    letter-spacing: -.025em;
    margin-bottom: 6px;
}
.dash-hero p {
    color: var(--text-muted);
    font-size: 14px;
}
.dash-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* AA StatCard */
.nb-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 24px;
}
@media (max-width: 1100px) { .nb-stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .nb-stat-grid { grid-template-columns: 1fr; } }

.nb-stat {
    background: #FFFFFF;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-lg);
    padding: 22px;
    box-shadow: 0 1px 0 rgba(20,19,26,.04), 0 18px 40px -20px rgba(20,19,26,.18);
    position: relative;
    overflow: hidden;
    z-index: 1;
    transition: transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s, border-color .2s;
}
.nb-stat:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
    border-color: var(--border-strong);
}
.nb-stat.is-accent::before {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(80% 80% at 100% 0%, var(--accent-tint), transparent 60%);
    pointer-events: none;
}
.nb-stat-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 18px;
    position: relative;
}
.nb-stat-label {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 600;
    letter-spacing: .02em;
}
.nb-stat-icon {
    width: 32px; height: 32px;
    border-radius: 10px;
    background: var(--surface-2);
    color: var(--text-soft);
    border: 1px solid var(--border);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.nb-stat.is-accent .nb-stat-icon {
    background: var(--gradient-main);
    color: white;
    border-color: transparent;
}
.nb-stat-value {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    font-size: 34px;
    font-weight: 800;
    letter-spacing: -.025em;
    line-height: 1;
    margin-bottom: 8px;
    position: relative;
    color: var(--text);
}
.nb-stat.is-accent .nb-stat-value {
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.nb-stat-foot {
    display: flex; align-items: center; gap: 8px;
    font-size: 12.5px;
    color: var(--text-muted);
    position: relative;
}
.nb-stat-trend {
    display: inline-flex; align-items: center; gap: 3px;
    font-weight: 700;
}
.nb-stat-trend.up { color: var(--success); }
.nb-stat-trend.down { color: var(--danger); }

/* sparkline 카드 + 사이드 카드 grid */
.dash-row {
    display: grid;
    grid-template-columns: 1.55fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
}
@media (max-width: 1100px) { .dash-row { grid-template-columns: 1fr; } }

.dash-chart-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 12px;
}
.dash-chart-eyebrow {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.dash-chart-value-row {
    display: flex; align-items: baseline; gap: 12px;
    margin-top: 6px;
}
.dash-chart-value {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    font-size: 32px;
    font-weight: 800;
    letter-spacing: -.025em;
}
.dash-chart-trend {
    font-size: 13px;
    color: var(--success);
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}
.dash-range-tabs {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 10px;
}
.dash-range-tab {
    padding: 6px 12px;
    border-radius: 7px;
    background: transparent;
    color: var(--text-muted);
    font-size: 12.5px;
    font-weight: 600;
    cursor: pointer;
    border: 0;
}
.dash-range-tab.active {
    background: var(--surface);
    color: var(--text);
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.dash-sparkline-x {
    display: flex;
    justify-content: space-between;
    font-size: 11.5px;
    color: var(--text-muted);
    margin-top: 8px;
    font-family: var(--font-mono);
}

/* 최근 발행 카드 */
.dash-recent { display: flex; flex-direction: column; gap: 10px; }
.dash-recent-item {
    display: flex; gap: 10px; align-items: center;
    padding: 10px 12px;
    border-radius: 10px;
    background: var(--surface-2);
    border: 1px solid var(--border);
}
.dash-recent-dot {
    width: 6px; height: 6px; border-radius: 999px;
    flex-shrink: 0;
}
.dash-recent-dot.ok { background: var(--success); }
.dash-recent-dot.fail { background: var(--danger); }
.dash-recent-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dash-recent-time {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 2px;
}

/* 이번 주 일정 */
.dash-schedule { display: flex; flex-direction: column; gap: 14px; }
.dash-day-row { display: flex; align-items: center; gap: 12px; }
.dash-day-pill {
    width: 42px; height: 42px;
    border-radius: 11px;
    background: var(--surface-2);
    color: var(--text-soft);
    border: 1px solid var(--border);
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    flex-shrink: 0;
}
.dash-day-pill.today {
    background: var(--gradient-main);
    color: white;
    border-color: transparent;
}
.dash-day-pill .dow {
    font-size: 9.5px;
    font-weight: 600;
    opacity: .8;
}
.dash-day-pill .day {
    font-family: var(--font-en);
    font-variant-numeric: tabular-nums;
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
}
.dash-day-info { flex: 1; min-width: 0; }
.dash-day-info .label { font-size: 13px; font-weight: 600; color: var(--text); }
.dash-day-info .progress { margin-top: 6px; height: 4px; }
.dash-day-full {
    font-size: 10.5px;
    color: var(--warning);
    font-weight: 700;
}

/* 캠페인 테이블 카드 */
.dash-camp-card { padding: 0; overflow: hidden; }
.dash-camp-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px 24px;
}
.dash-camp-head .title { font-weight: 700; font-size: 15px; letter-spacing: -.01em; }
.dash-camp-head .sub { font-size: 12.5px; color: var(--text-muted); margin-top: 2px; }
.dash-camp-card .data thead th { background: var(--surface-2); }
.dash-camp-divider { height: 1px; background: var(--border); }

/* 캠페인 키워드 칩 */
.kw-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--text-soft);
}

/* deploy 캠페인 카드 탭 */
.deploy-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.deploy-tabs {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    flex-wrap: wrap;
}
.deploy-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: transparent;
    border: 0;
    border-radius: 9px;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.deploy-tab:hover { color: var(--text); }
.deploy-tab.active {
    background: var(--surface-2);
    color: var(--text);
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.deploy-tab-pill {
    font-family: var(--font-mono);
    font-size: 10.5px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-muted);
    border: 1px solid var(--border);
}
.deploy-tab.active .deploy-tab-pill {
    background: var(--accent-tint);
    color: var(--accent-a);
    border-color: transparent;
}

/* empty state */
.empty-state {
    text-align: center;
    padding: 80px 20px;
}
.empty-state-icon {
    width: 64px; height: 64px;
    border-radius: 18px;
    background: var(--bg-tint);
    display: grid; place-items: center;
    margin: 0 auto 16px;
    color: var(--accent-a);
}
.empty-state-title { font-size: 17px; font-weight: 700; margin-bottom: 6px; }
.empty-state-desc { font-size: 13.5px; color: var(--text-muted); margin-bottom: 18px; }

/* testimonial (landing) */
.lp-testimonial {
    max-width: 920px; margin: 0 auto;
}
.lp-testimonial-card {
    padding: 40px;
    border-radius: var(--radius-lg);
    background: linear-gradient(160deg, var(--bg-tint) 0%, var(--surface) 60%);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    position: relative;
    overflow: hidden;
}
.lp-testimonial-quote {
    position: absolute;
    top: 24px; right: 28px;
    opacity: .15;
}
.lp-testimonial-inner {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 24px;
    align-items: center;
}
.lp-testimonial-avatar {
    width: 76px; height: 76px;
    border-radius: 22px;
    background: linear-gradient(135deg, #FFD4B8, #FFB8D4);
    display: grid; place-items: center;
    font-size: 28px;
    font-weight: 700;
    color: #7a3b3b;
    flex-shrink: 0;
}
.lp-testimonial-text {
    font-size: 19px;
    font-weight: 500;
    line-height: 1.55;
    color: var(--text);
    margin-bottom: 18px;
    letter-spacing: -.015em;
}
.lp-testimonial-by {
    font-size: 14px;
    color: var(--text-soft);
}
.lp-testimonial-by strong { color: var(--text); }
@media (max-width: 700px) {
    .lp-testimonial-card { padding: 26px; }
    .lp-testimonial-inner { grid-template-columns: 1fr; gap: 16px; }
    .lp-testimonial-text { font-size: 16px; }
}

/* ============================================================
   ▼▼▼ 인터랙션 팩 — 전체 페이지 공통 ▼▼▼
   ripple, spotlight, reveal, flatpickr 보라톤 등
   ============================================================ */

/* ── 1) Button ripple ────────────────────────────────── */
.btn, .bd-btn, .radio-pill, .nav-item {
    position: relative;
    overflow: hidden;
}
.nbl-ripple {
    position: absolute;
    border-radius: 50%;
    transform: scale(0);
    animation: nblRipple .6s ease-out;
    background: rgba(139,92,246,.35);
    pointer-events: none;
    z-index: 0;
}
.btn-primary .nbl-ripple { background: rgba(255,255,255,.45); }
@keyframes nblRipple {
    to { transform: scale(2.4); opacity: 0; }
}

/* ── 2) 테이블 인터랙티브 ─────────────────────────── */
/* 헤더 정렬 가능한 컬럼 hover 강조 */
.bd-table thead th.bd-sortable:hover,
table th[onclick]:hover {
    background: var(--accent-tint) !important;
    color: var(--accent-a) !important;
    cursor: pointer;
}
/* 행 hover — 살짝 들썩 + 보라 좌측 강조 */
.bd-table tbody tr,
table.bd-table tbody tr {
    transition: background .15s ease, transform .15s cubic-bezier(.2,.7,.3,1), box-shadow .15s ease !important;
    position: relative;
}
.bd-table tbody tr:not(.bd-expand-row):hover {
    background: linear-gradient(90deg, rgba(139,92,246,.07), transparent 80%) !important;
    box-shadow: inset 3px 0 0 var(--accent-a);
}
/* 클릭 가능한 행 (cursor:pointer 있는 경우) — 추가 호버 효과 */
.bd-table tbody tr[onclick]:hover,
.bd-table tbody tr[style*="cursor:pointer"]:hover {
    background: linear-gradient(90deg, rgba(139,92,246,.12), rgba(6,182,212,.04)) !important;
}
/* 진행률 바 — hover 시 살짝 빛남 */
.bd-table tbody tr:hover [style*="background:var(--success)"],
.bd-table tbody tr:hover [style*="background:var(--primary)"],
.bd-table tbody tr:hover [style*="background:linear-gradient(90deg"] {
    filter: brightness(1.15);
}
/* 상태 배지 — hover 시 약간 스케일 */
.bd-table tbody tr:hover .bd-status {
    transform: scale(1.04);
}
.bd-status { transition: transform .15s cubic-bezier(.2,.7,.3,1); }

/* 액션 버튼 그룹 — 평소 살짝 흐림 → hover 시 또렷 */
.bd-action-group { opacity: .75; transition: opacity .15s; }
.bd-table tbody tr:hover .bd-action-group { opacity: 1; }

/* 일반 카드 — 호버 시 살짝 들썩 (spotlight 대체) */
.card, .bd-card, .nb-stat {
    transition: transform .2s cubic-bezier(.2,.7,.3,1), box-shadow .2s ease, border-color .2s !important;
}

/* ── 3) IntersectionObserver fade-up reveal ──────────── */
.to-reveal {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .55s cubic-bezier(.2,.7,.3,1), transform .55s cubic-bezier(.2,.7,.3,1);
}
.to-reveal.is-revealed {
    opacity: 1;
    transform: translateY(0);
}

/* ── 4) flatpickr — 보라톤 테마 오버라이드 ───────────── */
.flatpickr-calendar {
    background: var(--surface) !important;
    border: 1px solid var(--border-strong) !important;
    border-radius: 14px !important;
    box-shadow: 0 24px 50px -16px rgba(20,19,26,.35), 0 0 0 1px rgba(255,255,255,.04) inset !important;
    font-family: var(--font-sans) !important;
    padding: 8px !important;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after { border-bottom-color: var(--border-strong) !important; }
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after { border-top-color: var(--border-strong) !important; }
.flatpickr-months .flatpickr-month {
    color: var(--text) !important;
    fill: var(--text) !important;
    height: 40px !important;
}
.flatpickr-current-month {
    font-weight: 800 !important;
    color: var(--text) !important;
    padding: 6px 0 !important;
    letter-spacing: -.01em !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
    color: var(--text) !important;
    font-weight: 800 !important;
    background: transparent !important;
}
.flatpickr-prev-month, .flatpickr-next-month {
    color: var(--text-muted) !important;
    fill: var(--text-muted) !important;
    padding: 8px !important;
    border-radius: 8px !important;
    transition: all .15s !important;
}
.flatpickr-prev-month:hover, .flatpickr-next-month:hover {
    background: var(--accent-tint) !important;
    color: var(--accent-a) !important;
    fill: var(--accent-a) !important;
}
.flatpickr-weekdays {
    background: transparent !important;
    color: var(--text-muted) !important;
}
span.flatpickr-weekday {
    color: var(--text-muted) !important;
    font-weight: 700 !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
}
.flatpickr-day {
    color: var(--text-soft) !important;
    border-radius: 9px !important;
    font-weight: 600 !important;
    border: 0 !important;
    transition: all .15s !important;
    max-width: 38px !important;
    height: 36px !important;
    line-height: 36px !important;
    margin: 1px !important;
}
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
    background: var(--accent-tint) !important;
    color: var(--accent-a) !important;
}
.flatpickr-day.today {
    border: 1px solid var(--accent-a) !important;
    color: var(--accent-a) !important;
    background: transparent !important;
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover {
    background: var(--gradient-main) !important;
    color: white !important;
    border: 0 !important;
    box-shadow: 0 6px 14px -6px rgba(139,92,246,.6) !important;
}
.flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay {
    color: var(--text-tertiary) !important;
    opacity: .5;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
    color: var(--text-tertiary) !important;
    background: transparent !important;
    opacity: .3 !important;
}

/* 다크 테마용 추가 보정 */
html[data-theme="dark"] .flatpickr-calendar {
    background: #181822 !important;
    border-color: #2E2E3B !important;
}

/* ── 5) form-input / bd-input — 값 있을 때 살짝 강조 ── */
.form-input.has-value:not(:focus),
.bd-input.has-value:not(:focus) {
    border-color: var(--border-strong);
}

/* ── 6) sidebar nav-item — active indicator ──────────── */
.nav-item.active {
    position: relative;
}
.nav-item.active::before {
    content: "";
    position: absolute;
    left: -8px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 60%;
    border-radius: 0 3px 3px 0;
    background: linear-gradient(180deg, var(--accent-a), var(--accent-b));
}

/* ── 7) 버튼 hover 시 부드러운 들썩 ──────────────────── */
.btn:not(:disabled):hover {
    transform: translateY(-1px);
}
.btn:not(:disabled):active {
    transform: translateY(0);
}

/* ── 8) 회원가입 컴팩트 모드 — 한 화면에 들어오게 ────── */
.reg-compact .auth-form-title { font-size: 22px !important; margin-bottom: 4px !important; }
.reg-compact .auth-form-sub { font-size: 13px !important; margin-bottom: 16px !important; }
.reg-compact .form-row { margin-bottom: 10px !important; }
.reg-compact .form-label {
    font-size: 11.5px !important;
    font-weight: 700 !important;
    margin-bottom: 4px !important;
    letter-spacing: -.005em !important;
    color: var(--text-soft) !important;
    text-transform: uppercase;
    display: block;
}
.reg-compact .form-input {
    padding: 9px 12px !important;
    font-size: 13.5px !important;
    height: auto !important;
    border-radius: 9px !important;
}
.reg-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 12px;
}
@media (max-width: 520px) {
    .reg-grid-2 { grid-template-columns: 1fr; gap: 0; }
}
.reg-agree {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px 12px;
    padding: 10px 12px;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: 10px;
    margin: 10px 0 14px;
}
.reg-agree-row {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
    color: var(--text-soft);
    cursor: pointer;
    user-select: none;
    line-height: 1.4;
}
.reg-agree-row input[type="checkbox"] {
    width: 14px;
    height: 14px;
    cursor: pointer;
    accent-color: var(--accent-a);
    margin: 0;
    flex-shrink: 0;
}
.reg-agree-row b { color: var(--danger); font-weight: 700; margin-right: 1px; }
.reg-submit {
    padding: 11px 14px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    border-radius: 10px !important;
    margin-top: 4px !important;
}
.reg-compact .auth-bottom {
    margin-top: 14px !important;
    font-size: 12.5px !important;
}
.reg-compact .alert {
    padding: 9px 12px !important;
    font-size: 12.5px !important;
    margin-bottom: 10px !important;
}

/* ── 9) redesign(2026-05): 미정의 토큰 별칭 + 토프바 타이틀 모바일 처리 + 온보딩/섹션 헬퍼 ── */
:root { --text-tertiary: var(--text-faint); }            /* flatpickr 등이 참조하던 미정의 변수 안전화 */
@media (max-width: 760px) { .topbar-title-block { display: none; } }  /* 좁은 화면에선 햄버거+액션만 */

/* 신규/빈 상태 온보딩 단계 칩 (대시보드·블로그배포 첫 사용) */
.step-chips { display: flex; gap: 8px; flex-wrap: wrap; margin: 6px 0 18px; }
.step-chips .step-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 9px 15px; border-radius: 999px;
    background: var(--surface-2); border: 1px solid var(--border);
    font-size: 13px; font-weight: 600; color: var(--text-soft);
}
.step-chips .step-chip .step-n {
    width: 19px; height: 19px; border-radius: 999px;
    background: var(--gradient-main); color: #fff;
    display: grid; place-items: center; font-size: 11px; font-weight: 800;
    font-family: var(--font-en);
}
.onboarding-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* 본문 섹션 구분 헤더 (총판 '내 사업'/'고객 관리' 등) */
.section-head { display: flex; align-items: center; gap: 12px; margin: 28px 0 14px; }
.section-head:first-child { margin-top: 4px; }
.section-head .section-eyebrow {
    font-size: 12px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase;
    color: var(--accent-a); white-space: nowrap;
}
.section-head .section-line { flex: 1; height: 1px; background: var(--border); }
.section-head .section-sub { font-size: 12px; color: var(--text-muted); font-weight: 500; white-space: nowrap; }
/* 총판: 승인 대기 + 대행 고객 반반 2열 (좁은 화면 1열) */
@media (max-width: 900px) { .dist-half { grid-template-columns: 1fr !important; } }

