/* SmartSelling Design System v2 — ss.css */
/* 이 파일은 ui_prototype.html 에서 추출된 공식 디자인 시스템입니다 */

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

:root{
  --accent:#5e62f4;
  --accent-hover:#4a4de8;
  --accent-light:rgba(94,98,244,.10);
  --accent-text:#5e62f4;
  --sidebar-bg:#ffffff;
  --sidebar-border:#e0e2e8;
  --sidebar-item:#4a4f60;
  --sidebar-item-hover:#1a1d2e;
  --sidebar-hover-bg:rgba(0,0,0,.045);
  --header-bg:#ffffff;
  --page-bg:#e8eaef;
  --svc-color:#03C75A;
  --card-bg:#ffffff;
  --border:#e5e5ea;
  --border-light:#f0f0f5;
  --text:#111118;
  --text-2:#333340;
  --text-muted:#6e6e80;
  --green:#22c55e;
  --red:#ef4444;
  --orange:#f59e0b;
  --blue:#3b82f6;
  --purple:#8b5cf6;
}

body{font-family:'Noto Sans KR',-apple-system,BlinkMacSystemFont,'맑은 고딕',sans-serif;background:var(--page-bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column;font-size:16px}

/* ── NOTICE BAR ── */
.notice-bar{background:#fef3c7;border-bottom:1px solid #fcd34d;padding:0 16px;font-size:12.5px;color:#92400e;display:flex;align-items:center;gap:8px;flex-shrink:0;height:36px;min-height:36px}
.notice-bar.hidden{display:none}
.notice-badge{display:inline-flex;align-items:center;gap:4px;background:#f59e0b;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.notice-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.notice-text strong{font-weight:700;margin-right:4px}
.notice-close{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:rgba(0,0,0,.08);border-radius:5px;cursor:pointer;color:#92400e;font-size:13px;flex-shrink:0;transition:background .13s;line-height:1;font-family:inherit}
.notice-close:hover{background:rgba(0,0,0,.16)}

/* ── TOP HEADER ── */
.top-header{height:72px;background:var(--header-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:6px 18px 0;gap:7px;z-index:200;flex-shrink:0;position:relative}
/* 서비스별 상단 컬러 바 (4px, 절대 위치) */
.top-header::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:var(--svc-color);z-index:1;border-radius:0}
.header-logo{display:flex;align-items:center;gap:7px;font-weight:700;font-size:19px;color:var(--text);text-decoration:none;cursor:pointer;letter-spacing:-.3px}
.logo-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}
.logo-beta{display:inline-flex;align-items:center;background:linear-gradient(135deg,#ff6b35,#ff9340);color:#fff;font-size:11px;font-weight:800;padding:3px 5px;border-radius:6px;letter-spacing:.04em;margin-left:2px;box-shadow:0 2px 8px rgba(255,107,53,.35);vertical-align:middle;line-height:1}
.header-left{width:260px;flex-shrink:0;display:flex;align-items:center;gap:7px}
.header-spacer{flex:1}
/* ── SERVICE SWITCHER — 헤더 탭 방식 ── */
.hs-n{font-size:20px;font-weight:900;font-style:italic;color:#03C75A;line-height:1;flex-shrink:0}
.hs-switcher{display:flex;align-items:flex-end;align-self:stretch;gap:4px;margin-left:0;padding-top:18px}
.hs-tab{display:flex;align-items:center;justify-content:flex-start;gap:9px;padding:4px 24px 4px 20px;height:48px;border-radius:12px 12px 0 0;cursor:pointer;border:1px solid transparent;background:transparent;transition:background .15s,border-color .15s;white-space:nowrap;user-select:none;margin-bottom:0;font-family:inherit;position:relative}
/* 활성 탭: 상단만 라운드인 단순 사각형 */
.hs-tab.active{border-color:var(--border);border-bottom-color:var(--page-bg);background:var(--page-bg);margin-bottom:-1px;border-radius:10px 10px 0 0;overflow:visible}
.hs-tab:hover:not(.active){background:rgba(0,0,0,.05)}
.hs-tab:not(.active) .hs-n{opacity:.4}
.hs-tab-name{font-size:15px;font-weight:700;color:#888;transition:color .15s}
.hs-tab.active .hs-tab-name{font-weight:900;color:#000}
.hs-tab:hover:not(.active) .hs-tab-name{color:#666}
.header-actions{display:flex;align-items:center;gap:6px}

/* 공지/오류 버튼 */
.hdr-notify-btn{display:inline-flex;align-items:center;gap:4px;padding:0 12px;height:32px;border:1px solid #d5dcf5;border-radius:8px;background:#eef1fc;cursor:pointer;font-size:12.5px;font-weight:500;color:#4a5580;font-family:inherit;transition:background .13s,border-color .13s;white-space:nowrap;line-height:1;vertical-align:middle}
.hdr-notify-btn:hover{background:#e4e8f8;border-color:#bcc5ee}
.hdr-notify-btn .hni{font-size:13px;line-height:1;display:flex;align-items:center}
.hdr-notify-btn.error-btn{color:#b84a1a;border-color:#f9cfb8;background:#fef0e8}
.hdr-notify-btn.error-btn:hover{background:#fde4d0;border-color:#f5b996}

/* User button */
.user-wrapper{position:relative}
.user-btn{display:flex;align-items:center;gap:8px;padding:5px 11px 5px 6px;border:1px solid #d8d6f8;border-radius:9px;background:#f4f3ff;cursor:pointer;transition:background .15s;font-family:inherit}
.user-btn:hover{background:#ebe9ff}
.user-email-text{font-size:12.5px;font-weight:500;color:var(--text-2)}
.chevron{font-size:9px;color:var(--text-muted);margin-left:2px;line-height:1;display:inline-block;transform:rotate(90deg);transition:transform .2s}
.chevron.open{transform:rotate(270deg)}

/* ── LOADING MODAL ── */
.loading-overlay{display:none;position:fixed;inset:0;background:rgba(10,12,28,.60);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:3000;align-items:center;justify-content:center}
.loading-overlay.open{display:flex}
.loading-modal{background:#fff;border-radius:20px;padding:36px 40px 32px;width:500px;max-width:92vw;box-shadow:0 32px 100px rgba(0,0,0,.30);position:relative;text-align:center}
.lm-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border:none;background:#f0f1f5;border-radius:8px;cursor:pointer;font-size:15px;color:#666;display:flex;align-items:center;justify-content:center;transition:background .13s;line-height:1}
.lm-close:hover{background:#e0e2ea;color:#333}

/* 스피너 */
.lm-spinner-wrap{width:64px;height:64px;margin:0 auto 22px;position:relative}
.lm-spinner{width:64px;height:64px;border:5px solid #ededf5;border-top-color:var(--accent);border-right-color:var(--purple);border-radius:50%;animation:lm-spin .9s linear infinite}
@keyframes lm-spin{to{transform:rotate(360deg)}}

/* 텍스트 영역 */
.lm-title{font-size:19px;font-weight:700;color:var(--text);margin-bottom:20px;line-height:1.4}
.lm-regions{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.lm-region{background:#f7f8fc;border:1px solid #e8eaf2;border-radius:10px;padding:12px 16px;text-align:left}
.lm-region-label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}
.lm-region-text{font-size:14px;font-weight:500;color:var(--text-2);line-height:1.5;min-height:20px}
.lm-region-text.active{color:var(--accent);font-weight:600}

/* 진행 바 */
.lm-prog-wrap{margin-bottom:22px}
.lm-prog-bar{height:8px;background:#ededf5;border-radius:4px;overflow:hidden;margin-bottom:7px}
.lm-prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--purple));border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.lm-prog-footer{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}
.lm-prog-pct{font-weight:600;color:var(--accent)}

/* 취소 버튼 */
.lm-cancel{width:100%;padding:10px;border:1px solid var(--border);border-radius:9px;background:#fff;font-size:13.5px;font-weight:500;color:var(--text-2);cursor:pointer;font-family:inherit;transition:background .13s}
.lm-cancel:hover{background:#f5f5f8}

/* Dropdown */
.dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;min-width:195px;background:#fff;border:1px solid var(--border);border-radius:11px;box-shadow:0 4px 22px rgba(0,0,0,.10);overflow:hidden;z-index:999}
.dropdown.open{display:block}
.dd-head{padding:13px 15px;border-bottom:1px solid var(--border-light)}
.dd-uname{font-size:13.5px;font-weight:600;color:var(--text)}
.dd-email{font-size:11.5px;color:var(--text-muted);margin-top:1px}
.dd-item{display:flex;align-items:center;gap:9px;padding:9px 15px;font-size:13.5px;color:var(--text-2);cursor:pointer;transition:background .1s}
.dd-item:hover{background:#f5f5f8}
.dd-item.danger{color:var(--red)}
.dd-sep{height:1px;background:var(--border-light)}
/* z-index 190: .top-header(z200)가 만드는 스태킹 컨텍스트보다 낮게 둬야 헤더 안의 드롭다운(z999)이
   오버레이 위로 올라와 클릭된다. 998 이면 오버레이가 드롭다운을 덮어 모든 메뉴 클릭이 막혔던 버그. */
.overlay{display:none;position:fixed;inset:0;z-index:190}
.overlay.open{display:block}

/* ── APP BODY ── */
.app-body{display:flex;flex:1;overflow:hidden;padding-top:8px}

/* ── SIDEBAR TOGGLE BUTTON ── */
.sb-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;cursor:pointer;border-radius:8px;color:var(--text);font-size:20px;transition:background .13s;flex-shrink:0;font-family:inherit;margin-left:-6px}
.sb-toggle:hover{background:rgba(0,0,0,.07)}

/* ── SIDEBAR ── */
.sidebar{width:260px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);border-top-right-radius:18px;border-bottom-right-radius:18px;flex-shrink:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;transition:width .22s cubic-bezier(.4,0,.2,1),background .3s;margin-top:10px}
/* 네이버광고 모드: 사이드바 배경에 극히 미세한 웜톤 */
body.svc-ad .sidebar{background:var(--sidebar-bg)}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(0,0,0,.10);border-radius:2px}

/* PC 접힌 상태 */
.sidebar.collapsed{width:54px}
.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-arrow,
.sidebar.collapsed .store-selector,.sidebar.collapsed .sb-bottom .plan-pill-name,
.sidebar.collapsed .sb-bottom .plan-pill-sub,.sidebar.collapsed .subitems{display:none!important}
.sidebar.collapsed .nav-btn{justify-content:center;padding:9px 0}
.sidebar.collapsed .nav-icon{font-size:18px;width:auto}
.sidebar.collapsed .sb-bottom{padding:8px 5px 12px}
.sidebar.collapsed .plan-pill{justify-content:center;padding:10px 0;gap:0}

/* Mobile 오버레이 */
.sb-dim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.38);z-index:499;backdrop-filter:blur(2px)}
.sb-dim.open{display:block}
@media(max-width:768px){
  .sidebar{position:fixed;top:0;left:0;height:100%;z-index:500;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);width:260px!important}
  .sidebar.mobile-open{transform:translateX(0)}
  .sidebar.collapsed{width:260px!important;transform:translateX(-100%)}
  .sidebar.collapsed.mobile-open{transform:translateX(0)}
  /* 모바일 헤더 반응형 — header-left 260px 고정·hs-switcher가 ☰ 영역 침범하던 문제 해결 */
  .top-header{padding:6px 12px 0;gap:4px}
  .header-left{width:auto;flex-shrink:0;gap:4px}
  .sb-toggle{width:42px;height:42px;font-size:23px;margin-left:0;position:relative;z-index:3}
  .hs-switcher{display:none}            /* 좁은 화면에선 서비스 전환 탭 숨김(메뉴 공간 확보) */
  .header-logo{font-size:17px}
}

/* ── FOOTER ── */
.site-footer{padding:14px 24px 16px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:5px;flex-shrink:0;background:#f9f9fb;margin-top:auto}
.site-footer a{color:var(--text-muted);text-decoration:none;transition:color .13s}
.site-footer a:hover{color:var(--accent)}
.site-footer-row{display:flex;align-items:center;flex-wrap:wrap;font-size:13px;color:var(--text-muted)}
.site-footer-legal{font-size:12px;color:var(--text-muted);opacity:.75}
.site-footer-sep{margin:0 8px;color:#d0d0da}
.site-footer-right{margin-left:auto;font-size:13px;color:var(--text-2);opacity:1;font-weight:500}

.sb-section{padding:6px 0}
.sb-section+.sb-section{border-top:1px solid var(--sidebar-border)}
.sb-section:first-of-type{border-top:none}

/* Nav item */
.nav-item{margin:1px 7px}
.nav-btn{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border:none;background:transparent;cursor:pointer;border-radius:7px;color:#1e2340;font-size:14px;font-weight:600;transition:background .13s,color .13s;text-align:left;font-family:inherit;text-decoration:none}
.nav-btn:hover{background:var(--sidebar-hover-bg);color:#0a0d1a}
.nav-btn:visited{color:#1e2340}
.nav-btn.active{background:var(--accent-light);color:var(--accent-text);font-weight:700}
.nav-btn.parent-active{color:var(--accent);background:rgba(94,98,244,.05)}
.nav-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}
.nav-label{flex:1}
.nav-arrow{font-size:11px;opacity:.45;transition:transform .2s;margin-left:auto}
.nav-arrow.open{transform:rotate(90deg)}

/* Sub items */
.subitems{display:none;padding:2px 0 4px}
.subitems.open{display:block}
.sub-item{display:flex;align-items:center;gap:7px;padding:7px 9px 7px 36px;margin:0 7px;border-radius:6px;color:#5c6480;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,color .12s;text-decoration:none}
.sub-item:visited{color:#5c6480}
.sub-item::before{content:'';width:4px;height:4px;background:#c4c8dc;border-radius:50%;flex-shrink:0;margin-right:2px}
.sub-item:hover{background:rgba(0,0,0,.05);color:#3d4260}
.sub-item.active{color:var(--accent);background:rgba(94,98,244,.09);font-weight:700}
.sub-item.active::before{background:var(--accent)}

/* Sidebar bottom */
.sb-bottom{margin-top:auto;padding:10px 7px 14px;border-top:1px solid var(--sidebar-border)}
.plan-pill{display:flex;align-items:center;gap:9px;padding:11px 12px;background:rgba(94,98,244,.09);border:1px solid rgba(94,98,244,.22);border-radius:9px;margin:0 0 6px;cursor:pointer;transition:background .15s}
.plan-pill:hover{background:rgba(94,98,244,.16)}
.plan-pill-icon{font-size:18px}
.plan-pill-name{font-size:15px;font-weight:700;color:var(--accent)}
.plan-pill-sub{font-size:13px;color:#4a5080;margin-top:2px;font-weight:500}

/* ── STORE SELECTOR ── */
.store-selector{padding:10px 10px 6px}
.store-card{background:#e5f9ee;border:1px solid #86efac;border-radius:12px;padding:14px 12px 12px;cursor:pointer;user-select:none;transition:background .15s}
.store-card:hover{background:#bbf7d0}
.store-card.ss-open{background:#bbf7d0}
.store-card-lbl{font-size:12px;font-weight:600;color:#15803d;text-align:center;margin-bottom:10px;padding:2px 0 4px}
.store-name-box{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;border-radius:8px;padding:8px 11px;border:1px solid #bbf7d0}
.store-name-main{font-size:14px;font-weight:700;color:#1e2340;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;text-align:center}
.sb-divider{height:2px;background:var(--sidebar-border);margin:6px 12px 2px}
.store-tag{font-size:11px;color:var(--text-muted);margin-top:2px;font-weight:500}
.store-chevron{font-size:16px;color:#9ca3af;transition:transform .22s;flex-shrink:0;line-height:1;align-self:center;margin-top:-2px}
.store-chevron.open{transform:rotate(90deg)}
.store-list{display:none;margin:6px 0 0;background:#fff;border:1px solid rgba(0,0,0,.09);border-radius:10px;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.08)}
.store-list.open{display:block}
.store-list-item{display:flex;align-items:center;gap:9px;padding:9px 13px;cursor:pointer;transition:background .12s;border-bottom:1px solid #f0f1f7}
.store-list-item:last-child{border-bottom:none}
.store-list-item:hover{background:#f4f5fa}
.store-list-item.sli-current{background:rgba(94,98,244,.07);pointer-events:none}
.sli-name{font-size:13px;font-weight:600;color:#2a2d3e;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sli-check{font-size:12px;color:var(--accent);flex-shrink:0;font-weight:700}
.sli-add{justify-content:center;color:var(--accent);font-size:12.5px;font-weight:600;gap:5px;border-top:1px dashed #e0e2f0 !important}

/* ── MAIN ── */
.main{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 24px 22px;display:flex;flex-direction:column}
.main::-webkit-scrollbar{width:5px}
.main::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}

.page{display:none}
.page.active{display:block;flex:1}

/* Page header */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:12px}
.ph-title{font-size:19px;font-weight:700;color:var(--text)}
.ph-sub{font-size:12.5px;color:var(--text-muted);margin-top:2px}
.ph-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .13s;font-family:inherit;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover)}
.btn-ghost{background:#fff;border:1px solid var(--border);color:var(--text-2)}
.btn-ghost:hover{background:#f5f5f8}
.btn-sm{padding:5px 11px;font-size:12px}

/* Cards */
.card{background:#fff;border:1px solid var(--border);border-radius:11px;padding:18px}

/* Stats grid */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;margin-bottom:18px}
.stat-card{background:#fff;border:1px solid #d2d6de;border-radius:12px;padding:16px 18px;box-shadow:0 3px 14px rgba(0,0,0,.09)}
.stat-ico{font-size:20px;margin-bottom:8px}
.stat-lbl{font-size:13px;color:var(--text-muted);font-weight:500;margin-bottom:6px}
.stat-bar{height:3px;border-radius:2px;margin:6px 0 4px;width:28px}
.stat-val{font-size:25px;font-weight:700;color:var(--text)}
.stat-chg{font-size:11.5px;margin-top:5px;display:flex;align-items:center;gap:3px}
.up{color:var(--green)}.down{color:var(--red)}.neutral{color:var(--text-muted)}

/* Grid layout */
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:16px}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}

/* Activity list */
.act-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}
.act-item:last-child{border-bottom:none}
.act-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:5px;flex-shrink:0}
.act-text{font-size:14px;color:var(--text-2);line-height:1.5}
.act-time{font-size:11.5px;color:#bbb;margin-top:2px}

/* Table */
.table-wrap{background:#fff;border:1px solid var(--border);border-radius:11px;overflow:hidden}
.table-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-light)}
.table-title{font-size:14px;font-weight:600;color:var(--text)}
.search-row{display:flex;align-items:center;gap:8px}
.search-box{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);border-radius:7px;padding:6px 12px;font-size:13px;color:var(--text-2);max-width:240px}
.search-box input{border:none;outline:none;background:transparent;font-size:13px;color:var(--text-2);width:100%;font-family:inherit}
.search-box input::placeholder{color:#bbb}
.si{color:#bbb;font-size:15px}
table{width:100%;border-collapse:collapse}
th{padding:9px 18px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);background:#fafafa;border-bottom:1px solid var(--border-light);white-space:nowrap}
td{padding:11px 18px;font-size:14px;color:var(--text-2);border-bottom:1px solid #f7f7f9}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafafa}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:600}
.b-green{background:#f0fdf4;color:#15803d}
.b-blue{background:#eff6ff;color:#1d4ed8}
.b-orange{background:#fff7ed;color:#c2410c}
.b-gray{background:#f5f5f8;color:var(--text-muted)}
.b-red{background:#fef2f2;color:#dc2626}
.b-purple{background:#faf5ff;color:#7c3aed}

/* Progress bars */
.prog-wrap{margin:11px 0}
.prog-row{display:flex;justify-content:space-between;margin-bottom:5px;font-size:12.5px}
.prog-name{color:var(--text-2);font-weight:500}
.prog-cnt{color:var(--text-muted);font-size:12px}
.prog-bar{height:5px;background:#f0f0f5;border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px}

/* Product card grid */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:13px;margin-top:14px}
.prod-card{background:#fff;border:1px solid var(--border);border-radius:11px;padding:15px;cursor:pointer;transition:border-color .13s,box-shadow .13s}
.prod-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px rgba(94,98,244,.07)}
.prod-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:7px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.prod-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-muted)}
.prod-rank-row{display:flex;align-items:flex-end;justify-content:space-between;margin-top:10px}
.rank-num{font-size:22px;font-weight:700;color:var(--text);line-height:1}
.rank-unit{font-size:13px;color:var(--text-muted)}
.rank-kw{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.rank-delta{font-size:13px;font-weight:600}
.rank-delta.up{color:var(--green)}.rank-delta.down{color:var(--red)}.rank-delta.same{color:var(--text-muted)}

/* Keyword table */
.kw-vol{font-weight:600;color:var(--text)}
.comp-h{color:var(--red)}.comp-m{color:var(--orange)}.comp-l{color:var(--green)}

/* Form input */
.form-input{width:100%;padding:8px 13px;border:1px solid var(--border);border-radius:7px;font-size:14px;font-family:inherit;color:var(--text);background:#fff;outline:none;transition:border-color .13s,box-shadow .13s}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(94,98,244,.09)}

/* Alert */
.alert{display:flex;align-items:flex-start;gap:8px;padding:11px 14px;border-radius:9px;font-size:13px;margin-bottom:15px}
.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}

/* Usage page plan card */
.plan-card-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px}

/* Section label */
.sec-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:13px}

/* Divider */
.div{height:1px;background:var(--border-light);margin:16px 0}

/* Quick links */
.quick-links{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}
.qlink{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text-2);cursor:pointer;transition:background .13s}
.qlink:hover{background:#f5f5f8}

/* Tag chip */
.chip{display:inline-flex;align-items:center;padding:3px 10px;background:#f0f0f5;border-radius:20px;font-size:12px;color:var(--text-2);gap:4px}

/* ── ZEBRA TABLE ── */
.ztable td{text-align:center;vertical-align:middle}
.ztable tbody tr:nth-child(even) td{background:rgba(94,98,244,.06)}
.ztable tbody tr:hover td{background:#eef1ff !important}

/* Page size selector */
.psize-sel{padding:5px 10px;border:1px solid var(--border);border-radius:7px;font-size:12.5px;font-family:inherit;color:var(--text-2);background:#fff;cursor:pointer;outline:none;transition:border-color .13s}
.psize-sel:focus{border-color:var(--accent)}

/* Pagination bar */
.pagi-bar{display:flex;align-items:center;justify-content:space-between;padding:11px 18px;border-top:1px solid var(--border-light);background:#fafbfc}
.pagi-info{font-size:12.5px;color:var(--text-muted)}
.pagi-btns{display:flex;align-items:center;gap:3px}
.pagi-btn{min-width:30px;height:30px;border:1px solid var(--border);border-radius:7px;background:#fff;cursor:pointer;font-size:13px;color:var(--text-2);display:flex;align-items:center;justify-content:center;padding:0 6px;transition:all .13s;font-family:inherit}
.pagi-btn:hover:not(:disabled){background:#f0f1f5;border-color:#c0c4d4}
.pagi-btn.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.pagi-btn:disabled{opacity:.35;cursor:default}
.pagi-dot{padding:0 3px;color:var(--text-muted);font-size:13px;line-height:30px}

/* ── RIGHT PANEL ── */
.right-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}

/* ── BREADCRUMB BAR ── */
/* margin-top:10px → 좌측 사이드바(margin-top:10px) 상단 라인과 정렬.
   margin 좌우 24px → 아래 본문(.main padding 24px) 카드 좌/우 라인과 정렬.
   border-radius → 다른 카드들과 통일성. */
.bc-bar{display:none;align-items:center;gap:12px;margin:10px 24px 0;padding:10px 16px;border:1px solid var(--border);border-radius:11px;background:var(--card-bg);font-size:13px;color:var(--text-muted);flex-shrink:0;box-shadow:0 2px 8px rgba(17,17,24,.05)}
.bc-bar.show{display:flex}
.bc-back{display:inline-flex;align-items:center;gap:5px;padding:6px 16px;border:1.5px solid #c9b8f0;border-radius:8px;background:#ede9ff;cursor:pointer;font-size:13.5px;font-weight:600;color:#5e62f4;font-family:inherit;transition:all .13s;flex-shrink:0}
.bc-back:hover{background:#ddd8ff;border-color:#a99ce0}
.rk-star{cursor:pointer;font-size:16px;color:#ddd;user-select:none;transition:color .13s;line-height:1}
.rk-star.active{color:#f59e0b}
.rk-star:hover{color:#f1c40f}
.bc-divider{width:1px;height:14px;background:var(--border);margin:0 2px}
.bc-path{display:flex;align-items:center;gap:5px}
.bc-seg{color:var(--text-muted)}
.bc-seg.cur{color:var(--text-2);font-weight:600}
.bc-arrow{color:#ccc;font-size:11px}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:5000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{display:flex;align-items:flex-start;gap:10px;padding:13px 15px;background:#fff;border:1px solid var(--border);border-left:3.5px solid var(--border);border-radius:11px;box-shadow:0 8px 32px rgba(0,0,0,.12);min-width:270px;max-width:370px;pointer-events:all;animation:tIn .22s ease-out}
.toast.removing{animation:tOut .22s ease-in forwards}
@keyframes tIn{from{transform:translateX(110%);opacity:0}to{transform:none;opacity:1}}
@keyframes tOut{to{transform:translateX(110%);opacity:0}}
.toast.t-success{border-left-color:var(--green)}
.toast.t-error{border-left-color:var(--red)}
.toast.t-warning{border-left-color:var(--orange)}
.toast.t-info{border-left-color:var(--blue)}
.toast-ico{font-size:16px;flex-shrink:0;margin-top:1px}
.toast-body{flex:1;min-width:0}
.toast-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.toast-msg{font-size:12.5px;color:var(--text-muted);line-height:1.45}
.toast-x{width:20px;height:20px;border:none;background:transparent;cursor:pointer;color:#bbb;font-size:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:color .13s;padding:0;font-family:inherit}
.toast-x:hover{color:var(--text)}

/* ── CONFIRM DIALOG ── */
.cfm-overlay{display:none;position:fixed;inset:0;background:rgba(10,12,28,.52);z-index:4500;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.cfm-overlay.open{display:flex}
.cfm-modal{background:#fff;border-radius:16px;padding:30px 28px 24px;width:400px;max-width:90vw;box-shadow:0 24px 80px rgba(0,0,0,.22);text-align:center}
.cfm-icon{font-size:36px;margin-bottom:12px}
.cfm-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px}
.cfm-msg{font-size:13.5px;color:var(--text-2);line-height:1.65;margin-bottom:24px;text-align:left}
.cfm-btns{display:flex;gap:8px;justify-content:flex-end}
.btn-danger{background:var(--red);color:#fff;border:none}
.btn-danger:hover{background:#dc2626}

/* ── EMPTY STATE ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}
.empty-ico{font-size:46px;margin-bottom:14px;opacity:.65}
.empty-title{font-size:15px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.empty-desc{font-size:13px;color:var(--text-muted);line-height:1.6;max-width:320px;margin-bottom:20px}

/* ── BUTTON LOADING ── */
.btn.loading{pointer-events:none;opacity:.78}
.btn-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--accent);border-radius:50%;animation:lm-spin .7s linear infinite;vertical-align:-2px;margin-right:5px;flex-shrink:0}
.btn-primary .btn-spinner{border-color:rgba(255,255,255,.35);border-top-color:#fff}

/* ── NOTICE BOARD ── */
.nb-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);overflow-x:auto}
.nb-tab{display:flex;align-items:center;gap:5px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .13s,border-color .13s;white-space:nowrap;user-select:none}
.nb-tab:hover{color:var(--text-2)}
.nb-tab.on{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}
.nb-cnt{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:#f0f0f5;border-radius:20px;font-size:11px;font-weight:700;color:var(--text-muted);padding:0 5px;line-height:1}
.nb-tab.on .nb-cnt{background:var(--accent-light);color:var(--accent)}
.notice-row{cursor:pointer}
.notice-row:hover td{background:#f8f8ff !important}
.notice-row:hover .nt-link{color:var(--accent)}
.nt-link{font-weight:600;color:var(--text-2)}
.b-notice{background:#eff6ff;color:#1d4ed8}
.b-update{background:#faf5ff;color:#7c3aed}
.b-maint{background:#fff7ed;color:#c2410c}
.b-error-tag{background:#fef2f2;color:#dc2626}
.b-resolved{background:#f0fdf4;color:#15803d}
.b-ongoing{background:#fef2f2;color:#dc2626}
.b-checking{background:#fff7ed;color:#c2410c}
/* Notice detail */
.nd-header{padding:22px 24px 18px;border-bottom:1px solid var(--border-light)}
.nd-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.nd-date{font-size:12.5px;color:var(--text-muted)}
.nd-title{font-size:20px;font-weight:700;color:var(--text);line-height:1.4}
.nd-body{padding:24px;font-size:15px;color:var(--text-2);line-height:1.85;white-space:pre-line;min-height:160px}
.nd-nav{display:flex;justify-content:space-between;padding:14px 24px;border-top:1px solid var(--border-light);background:#fafbfc}
.nd-nav-btn{font-size:13px;color:var(--text-muted);cursor:pointer;padding:6px 0;transition:color .13s;background:none;border:none;font-family:inherit;display:inline-flex;align-items:center;gap:4px}
.nd-nav-btn:hover{color:var(--accent)}
.nd-nav-btn.disabled{opacity:.35;cursor:default;pointer-events:none}

/* ── RANK SYSTEM ── */
.rk-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:700;line-height:1.5;white-space:nowrap;min-width:36px}
.rk-top10{background:#ffe8e8;color:#c0392b}
.rk-top30{background:#fff3cd;color:#856404}
.rk-top50{background:#e8f5e9;color:#27ae60}
.rk-over50{background:#f5f5f8;color:#999}
.rk-prod-card{background:linear-gradient(135deg,#ffffff,#f3f5ff);border:1px solid rgba(94,98,244,.28);border-radius:11px;padding:16px 20px;margin-bottom:18px;box-shadow:0 2px 8px rgba(94,98,244,.06)}
.rk-prod-meta{display:flex;flex-wrap:wrap;gap:8px 24px;margin-top:10px;font-size:13px;color:var(--text-2)}
.rk-prod-meta-item{display:flex;align-items:center;gap:6px}
.rk-meta-label{font-size:10.5px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}
.rk-graph-wrap{background:#fff;border:1px solid var(--border);border-radius:11px;overflow:hidden;margin-bottom:18px}
.rk-graph-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-light);flex-wrap:wrap;gap:10px}
.rk-graph-title{font-size:14px;font-weight:600;color:var(--text)}
.rk-legend{display:flex;gap:14px;flex-wrap:wrap}
.rk-legend-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-2)}
.rk-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.rk-graph-body{padding:16px 18px 8px;overflow-x:auto}
.rk-core-row td{background:rgba(255,250,230,.5)}
.rk-core-row:hover td{background:rgba(255,245,200,.6) !important}

/* === 실시간 순위확인 === */
.rt-hist-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .12s;gap:12px}
.rt-hist-item:last-child{border-bottom:none}
.rt-hist-item:nth-child(even){background:rgba(94,98,244,.06)}
.rt-hist-item:hover{background:#eef1ff}
.rt-hist-main{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}
.rt-hist-kw{font-weight:700;color:var(--text);font-size:13.5px}
.rt-hist-sep{color:var(--text-muted);font-size:12px}
.rt-hist-store{color:var(--accent);font-size:13px}
.rt-hist-found{font-size:11.5px;color:var(--text-muted);background:var(--accent-light);padding:1px 8px;border-radius:10px}
.rt-hist-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.rt-hist-time{font-size:11.5px;color:var(--text-muted)}
.rt-prod-item{display:flex;gap:14px;padding:16px;border-bottom:1px solid var(--border-light);align-items:flex-start;transition:background .12s}
.rt-prod-item:last-child{border-bottom:none}
.rt-prod-item:nth-child(even){background:rgba(94,98,244,.028)}
.rt-prod-item:hover{background:#eef1ff}
.rt-rank-box{min-width:58px;text-align:center;flex-shrink:0}
.rt-rank-num{font-size:20px;font-weight:800;line-height:1.2}
.rt-rank-page{font-size:11px;color:var(--text-muted);margin-top:3px}
.rt-prod-thumb{width:72px;height:72px;border-radius:8px;border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;background:#f5f5f8}
.rt-prod-info{flex:1;min-width:0}
.rt-prod-title{font-size:13.5px;font-weight:600;color:var(--text);margin-bottom:5px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rt-prod-price{font-size:14px;font-weight:700;color:var(--text-2);margin-bottom:4px}
.rt-prod-meta{font-size:12px;color:var(--text-muted)}
.rt-prog-bar{background:#e8e8ee;border-radius:3px;overflow:hidden;height:5px}
.rt-prog-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .35s ease;width:0%}

/* === 검색 트렌드 차트 (keyword_search.html 동일) === */
.trend-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.trend-title{font-size:15px;font-weight:700;color:#1a1a2e}
.trend-period{font-size:12px;color:#aaa}
.trend-source{margin-left:auto;font-size:11px;color:#bbb;background:#f5f5f5;padding:2px 8px;border-radius:10px}
.trend-chart{display:flex;align-items:flex-end;gap:5px;height:234px;padding:20px 2px 0;position:relative}
.trend-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;gap:0}
.trend-ratio-label{position:absolute;left:50%;transform:translateX(-50%);font-size:11px;font-weight:800;color:#3730a3;white-space:nowrap;z-index:2}
.trend-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;position:relative;overflow:visible}
.trend-bar{width:70%;border-radius:3px 3px 0 0;transition:height 0.4s ease;min-height:3px;cursor:default}
.trend-bar:hover{filter:brightness(1.15)}
.trend-month{font-size:11px;color:#444;font-weight:700;height:16px;display:flex;align-items:center;flex-shrink:0;white-space:nowrap}
.trend-line-overlay{position:absolute;top:20px;left:0;width:100%;height:calc(100% - 36px);pointer-events:none;overflow:visible}
.trend-dot{position:absolute;left:50%;width:9px;height:9px;background:#f97316;border:2.5px solid #fff;border-radius:50%;transform:translateX(-50%);z-index:3;pointer-events:none;box-shadow:0 1px 4px rgba(249,115,22,.45)}
.trend-note{font-size:11px;color:#bbb;margin-top:8px;text-align:right}

/* === 조합형 키워드 분석 === */
.kw-ab-label{font-size:14px;font-weight:700;padding:0 6px;flex-shrink:0}
.kw-a-label{color:#6366F1}
.kw-b-label{color:#e05555}
.metric-row{display:flex;align-items:stretch;border:1px solid #fcd5d5;border-radius:10px;overflow:hidden;margin-bottom:10px}
.metric-title{background:#fff0f0;color:#c0392b;min-width:168px;flex-shrink:0;padding:14px 16px;display:flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;border-right:1px solid #fcd5d5}
.metric-body{flex:1;background:#fff9f9;padding:14px 16px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.metric-val{font-size:30px;font-weight:900;color:#c0392b;line-height:1}
.metric-val.pw-na{color:#94a3b8}
.metric-unit{font-size:15px;font-weight:700;color:#c0392b}
.metric-unit.pw-na{color:#94a3b8}
.metric-desc{font-size:12px;color:#aaa}
.metric-insight{font-size:13px;font-weight:600}
.metric-insight.perfect{color:#1a7f3c}
.metric-insight.partial{color:#e67e22}
.metric-row.nw{border-color:#b7e4c7}
.metric-row.nw .metric-title{background:#f0faf4;color:#1a7f3c;border-right-color:#b7e4c7}
.metric-row.nw .metric-body{background:#f8fdf9;flex-direction:column;align-items:flex-start;gap:12px}
.nw-sub{display:flex;flex-direction:column;gap:12px;width:100%}
.nw-item{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nw-word-badge{font-size:12px;color:#1a7f3c;background:#d1fae5;padding:2px 10px;border-radius:4px;min-width:58px;text-align:center;font-weight:600;flex-shrink:0}
.nw-nums{display:flex;align-items:baseline;gap:4px}
.nw-cnt{font-size:26px;font-weight:900;color:#1a7f3c;line-height:1}
.nw-tot{font-size:12px;color:#888}
.nw-bar-wrap{width:80px;height:5px;background:#e2f4eb;border-radius:4px;overflow:hidden;flex-shrink:0}
.nw-bar{height:100%;background:#27ae60;border-radius:4px;transition:width .3s}
.nw-insight{font-size:13px;font-weight:600}
.nw-insight.perfect{color:#1a7f3c}
.nw-insight.partial{color:#e67e22}
.nw-part{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:9px 14px;background:#fff8f0;border:1px solid #fde8c8;border-radius:8px;margin-top:4px;width:100%;box-sizing:border-box}
.nw-part-label{font-size:11px;color:#c07020;flex-shrink:0}
.nw-part-badge{font-size:12px;color:#fff;background:#e67e22;padding:2px 8px;border-radius:4px;font-weight:600;flex-shrink:0}
.nw-part-badge.none{background:#b0b0b0}
.nw-part-name{font-size:12px;color:#555;word-break:break-all;flex:1}
.products-section{margin-top:16px}
.products-toggle{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#f5f5f8;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;color:#555;user-select:none;transition:background .13s}
.products-toggle:hover{background:#ebebf0}
.products-toggle .arrow{transition:transform .2s;font-size:10px;flex-shrink:0}
.products-toggle.open .arrow{transform:rotate(90deg)}
.product-list{display:none;border:1px solid #e8e8f0;border-radius:8px;margin-top:8px;overflow:hidden}
.product-list.open{display:block}
.product-row{display:flex;align-items:center;gap:10px;padding:0 12px;height:54px;border-bottom:1px solid #f3f3f3}
.product-row:last-child{border-bottom:none}
.product-row.pw-highlight{background:#fff5f0}
.p-rank{width:20px;height:20px;border-radius:50%;background:#e8e8f0;color:#666;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.p-rank.fixed{background:#6366F1;color:#fff}
.p-name{flex:1;font-size:13px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.p-dist{font-size:11.5px;color:#aaa;flex-shrink:0;min-width:44px;text-align:right}
.hl-a{color:#6366F1;font-weight:700}
.hl-b{color:#e05555;font-weight:700}
.hl-ab-fixed{background:#dbeafe;border:2px solid #3b82f6;border-radius:4px;padding:2px 6px;font-weight:700;color:#1d4ed8;white-space:nowrap}
.wt-hist-row{display:flex;align-items:center;gap:0;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .12s}
.wt-hist-row:last-child{border-bottom:none}
.wt-hist-row:nth-child(even){background:rgba(94,98,244,.028)}
.wt-hist-row:hover{background:#eef1ff}
.wt-hist-no{width:36px;text-align:center;font-size:12px;color:#bbb;flex-shrink:0;padding:12px 0}
.wt-hist-kw{flex:0 0 130px;font-size:14px;font-weight:700;color:var(--text);padding:12px 8px}
.wt-hist-ab{flex:0 0 90px;font-size:12px;color:#888;padding:12px 8px;line-height:1.5}
.wt-hist-cell{flex:1;padding:12px 10px;border-left:1px solid var(--border-light);text-align:center}
.wt-hist-cell-label{font-size:11px;color:#bbb;margin-bottom:2px}
.wt-hist-cell-val{font-size:16px;font-weight:800;color:#c0392b}
.wt-hist-cell-val.green{color:#1a7f3c}
.wt-hist-cell-unit{font-size:11px;font-weight:400;color:#aaa}
.wt-hist-time{flex:0 0 64px;font-size:11.5px;color:#ccc;padding:12px 8px;text-align:right}
.pw-note{font-size:12px;color:#ef4444;margin-top:6px;line-height:1.5;width:100%}
.info-tip{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#6366F1;color:#fff;font-size:11px;font-weight:800;cursor:pointer;margin-left:6px;flex-shrink:0;user-select:none;box-shadow:0 1px 4px rgba(99,102,241,.35);transition:background .12s,transform .1s}
.info-tip:hover{background:#4a4de8;transform:scale(1.1)}
.p-info{font-size:12px;color:#aaa;flex-shrink:0;min-width:80px;text-align:right}
.p-info.pw-max{color:#e74c3c;font-weight:700;font-size:13px}

/* === Tag 자동분석 === */
.parse-summary{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.summary-item{background:#f8f9fa;border-radius:8px;padding:12px 20px;text-align:center;min-width:100px}
.summary-item .num{font-size:22px;font-weight:700;color:#6366F1}
.summary-item .label{font-size:11px;color:#888;margin-top:4px}
.tag-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.tag-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#f8f9fa;border-radius:8px;border:1px solid #eee;transition:all .2s;cursor:pointer;min-width:0;overflow:hidden}
.tag-item:hover{background:#eef1ff;border-color:#c7c9f7}
.tag-rank{min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:#fff;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}
.tag-rank.top3{background:#e74c3c}
.tag-rank.top10{background:#6366F1}
.tag-rank.normal{background:#aaa}
.tag-name{flex:1;font-size:14px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.tag-count{font-size:15px;font-weight:700;color:#6366F1;min-width:30px;text-align:right;flex-shrink:0}
.tag-count-bar{width:60px;height:6px;background:#e8e8f0;border-radius:3px;overflow:hidden;flex-shrink:0}
.tag-count-bar-fill{height:100%;background:#6366F1;border-radius:3px;transition:width .3s}
.copy-all-area{margin-top:14px;padding:12px 14px;background:#f0f0ff;border-radius:8px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tag-preview{flex:1;font-size:12.5px;color:#444;line-height:1.6;min-width:0}
.tag-print-footer{display:none;text-align:center;border-top:1.5px solid #d0d3ff;padding-top:8px;margin-top:12px;font-size:13px;font-weight:700;color:#6366F1}

/* === 키워드 검색량 === */
.kv-stat-chip{display:flex;flex-direction:column;align-items:center;background:var(--page-bg);border:1px solid var(--border);border-radius:10px;padding:10px 18px;min-width:88px}
.kv-stat-label{font-size:11.5px;color:var(--text-muted);margin-bottom:4px;white-space:nowrap}
.kv-stat-val{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.5px}
.kv-stat-sep{font-size:18px;font-weight:300;color:var(--text-muted);align-self:center;padding:0 2px;line-height:1}
.kv-stat-total{background:rgba(94,98,244,.07);border-color:rgba(94,98,244,.3)}
.kv-stat-total .kv-stat-val{color:var(--accent)}
.kv-cat-tab{display:inline-flex;align-items:center;padding:4px 13px;border:1px solid var(--border);border-radius:20px;font-size:12.5px;color:var(--text-muted);cursor:pointer;transition:all .13s;background:#fff;font-family:inherit}
.kv-cat-tab:hover{border-color:var(--accent);color:var(--accent)}
.kv-cat-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.kv-kw-link{color:var(--accent);cursor:pointer;font-weight:600;font-size:13.5px}
.kv-kw-link:hover{text-decoration:underline}

/* ── ZOOM CONTROL ── */
.zoom-ctrl{display:flex;align-items:center;gap:6px;padding:7px 12px 6px;margin-bottom:4px}
.zoom-ctrl-label{font-size:11.5px;color:var(--text-muted);font-weight:500;flex:1;white-space:nowrap}
.zoom-ctrl-btn{height:24px;padding:0 9px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-size:12px;font-weight:700;color:var(--text-2);display:inline-flex;align-items:center;justify-content:center;transition:all .13s;font-family:inherit;white-space:nowrap;flex-shrink:0;letter-spacing:-.5px}
.zoom-ctrl-btn:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent);color:var(--accent)}
.zoom-ctrl-btn:disabled{opacity:.3;cursor:default}
.sidebar.collapsed .zoom-ctrl{display:none!important}

/* ── 상위 판매자 분석 공통 ── */
.ta-section{border-radius:12px;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.10),0 1px 4px rgba(0,0,0,.06);margin-bottom:40px}
.ta-section-hd{display:flex;align-items:center;gap:10px;padding:11px 20px;font-size:14px;font-weight:700;color:#1e2340;border-bottom:1px solid transparent}
.ta-section-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.ta-section-body{background:#fff;padding:16px 20px}
.ta-sec-1 .ta-section-hd,.ta-sec-2 .ta-section-hd,.ta-sec-3 .ta-section-hd,.ta-sec-4 .ta-section-hd,.ta-sec-5 .ta-section-hd{background:#f5f3ff;border-bottom-color:#ede9ff;border-left:4px solid #5e62f4}
.ta-sec-1 .ta-section-num,.ta-sec-2 .ta-section-num,.ta-sec-3 .ta-section-num,.ta-sec-4 .ta-section-num,.ta-sec-5 .ta-section-num{background:#ede9ff;color:#5e62f4}
/* ── 내 상품 분석 (pa) — 상품 카드 ── */
.pcard-hero{background:#f8faff;border-radius:12px;padding:16px;border:1px solid #dde3f5}
.pcard{display:flex;gap:16px;align-items:flex-start;margin-bottom:14px}
.pcard-thumb-ph{width:100px;height:100px;background:linear-gradient(135deg,#e0e7ff,#fce7f3);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:38px;flex-shrink:0;box-shadow:0 4px 12px rgba(99,102,241,.12)}
.pcard-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.pcard-name{font-size:14px;font-weight:700;color:#1e1b4b;line-height:1.65}
.pcard-meta-row{display:flex;align-items:center;gap:0;flex-wrap:wrap;font-size:13px;line-height:1.8}
.pcard-meta-sep{color:#d1d5db;margin:0 6px}
.pcard-info-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.pcard-info-row.attr-row{align-items:flex-start}
.pcard-row-lbl{font-size:13px;font-weight:700;color:#9ca3af;flex-shrink:0;white-space:nowrap}
.pcard-cat-crumb{font-size:13px;color:#374151;font-weight:500;line-height:1.5}
.pattr-wrap{display:flex;flex-wrap:wrap;gap:5px}
.pattr-pill{display:inline-flex;align-items:center;border-radius:20px;padding:3px 10px;font-size:13px;font-weight:500;border:1px solid transparent}
.pattr-pill-key{font-weight:700;margin-right:3px;opacity:.65;font-size:12px}
/* stat 카드 4색 — 파스텔 + 진한 텍스트 */
.pstat-row{display:flex;gap:7px;margin:14px 0 0}
.pstat-card{flex:1;min-width:0;border-radius:10px;padding:12px 6px 10px;text-align:center;background:transparent;border:1.5px solid #e8eaf0}
.pstat-lbl{font-size:12px;font-weight:700;letter-spacing:.02em;margin-bottom:6px}
.pstat-card.is-price .pstat-lbl{color:#1d4ed8}
.pstat-card.is-wish  .pstat-lbl{color:#be123c}
.pstat-card.is-review .pstat-lbl{color:#b45309}
.pstat-card.is-image .pstat-lbl{color:#0e7490}
.pstat-val{font-size:18px;font-weight:900;line-height:1}
.pstat-card.is-price .pstat-val{color:#1e40af}
.pstat-card.is-wish  .pstat-val{color:#9f1239}
.pstat-card.is-review .pstat-val{color:#92400e}
.pstat-card.is-image .pstat-val{color:#155e75}
.pstat-val-unit{font-size:10px;font-weight:600;opacity:.75}
/* ── 상품명 Terms 분석 ── */
.tstat-list{display:flex;flex-direction:column;gap:10px}
.tstat-row{display:flex;align-items:flex-start;gap:14px;padding:13px 15px;border-radius:12px;border:1px solid #f0f0f6}
.tstat-row.tr-terms{background:linear-gradient(90deg,#f5f3ff 0%,#fafafa 100%);border-color:#ede9fe}
.tstat-row.tr-chars{background:linear-gradient(90deg,#f0fdf4 0%,#fafafa 100%)}
.tstat-row.tr-chars.is-over{background:linear-gradient(90deg,#fff1f2 0%,#fafafa 100%);border-color:#fecdd3}
.tstat-row.tr-dups{background:linear-gradient(90deg,#fffbeb 0%,#fafafa 100%);border-color:#fde68a}
.tstat-row.tr-dups.is-nodup{background:linear-gradient(90deg,#f0fdf4 0%,#fafafa 100%);border-color:#bbf7d0}
.tstat-num{width:64px;height:56px;border-radius:12px;display:flex;flex-direction:row;align-items:center;justify-content:center;color:#fff;flex-shrink:0;gap:1px;padding:0 4px}
.tstat-n{font-size:22px;font-weight:900;line-height:1}
.tstat-u{font-size:11px;font-weight:700;opacity:.9;line-height:1}
.tstat-num.c-terms{background:linear-gradient(135deg,#5e62f4,#8b5cf6);box-shadow:0 3px 10px rgba(94,98,244,.28)}
.tstat-num.c-ok   {background:linear-gradient(135deg,#16a34a,#22c55e);box-shadow:0 3px 10px rgba(22,163,74,.25)}
.tstat-num.c-over {background:linear-gradient(135deg,#dc2626,#f87171);box-shadow:0 3px 10px rgba(220,38,38,.25)}
.tstat-num.c-nodup{background:linear-gradient(135deg,#16a34a,#22c55e);box-shadow:0 3px 10px rgba(22,163,74,.25)}
.tstat-num.c-hasdup{background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 3px 10px rgba(217,119,6,.25)}
.tstat-body{flex:1;min-width:0;padding-top:2px}
.tstat-label{font-size:13px;font-weight:700;color:#374151;margin-bottom:7px}
.tstat-detail{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.tstat-sub{font-size:12px;color:#6b7280}
.tstat-ok {color:#16a34a;font-weight:700}
.tstat-over{color:#dc2626;font-weight:700}
.term-badge{background:#fff;border:1.5px solid #a78bfa;border-radius:6px;padding:3px 10px;font-size:13px;color:#4c1d95;font-weight:600}
.dup-chip{display:inline-flex;align-items:center;gap:4px;border-radius:20px;padding:3px 10px;font-size:13px;font-weight:700}
.dup-chip.is-dup{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}
.dup-chip-cnt{font-size:11px;font-weight:400;opacity:.75}
/* ── 순위 카드 ── */
.rank-grid{display:flex;flex-wrap:wrap;gap:8px}
.rank-box{border:1.5px solid #e5e7eb;border-radius:10px;padding:12px 10px;text-align:center;background:#fafafa;flex:1;min-width:90px}
.rank-box.rank-top2{border-color:#3b82f6;background:#eff6ff}
.rank-box-kw{font-size:12px;color:#374151;font-weight:600;margin-bottom:6px;word-break:break-all;line-height:1.4}
.rank-box-num{font-size:26px;font-weight:800;color:#6366f1;line-height:1}
.rank-box-unit{font-size:13px;font-weight:600}
.rank-box-none{font-size:12px;color:#aaa;margin-top:5px}
.rank-box-label{display:inline-block;font-size:10px;font-weight:700;background:#7c3aed;color:#fff;border-radius:4px;padding:2px 6px;margin-top:5px}
/* ── ManuTag ── */
.tag-split-wrap{display:flex;flex-direction:column;gap:14px}
.tag-split-label{font-size:13px;font-weight:700;margin-bottom:7px}
.tag-split-label.label-ok{color:#15803d}
.tag-split-label.label-warn{color:#d97706}
.my-tag-ok{display:inline-block;background:#f0fdf4;border:1.5px solid #86efac;border-radius:20px;padding:4px 11px;font-size:13px;color:#15803d;font-weight:600;margin:2px}
.my-tag-warn{display:inline-block;background:#fff7ed;border:1.5px solid #fdba74;border-radius:20px;padding:4px 11px;font-size:13px;color:#9a3412;font-weight:600;margin:2px}
/* ── 매출 분석 레이아웃 ── */
.pa-sales-wrap{display:flex;gap:16px;align-items:stretch}
.pa-sales-left{flex:0 0 30%;background:#f8faff;border:1px solid #dde3f5;border-radius:10px;padding:10px 16px}
.pa-sales-lbl{font-size:12px;font-weight:700;color:#9ca3af;letter-spacing:.04em;text-transform:uppercase;margin-bottom:5px}
.pa-sales-num{font-size:17px;font-weight:900;color:#d97706;line-height:1.1}
.pa-sales-unit{font-size:12px;font-weight:700;color:#d97706}
.pa-sales-plus{font-size:12px;font-weight:800;color:#d97706}
.pa-sales-cnt-wrap{margin-top:6px;padding-top:6px;border-top:1px dashed #dde3f5}
.pa-sales-cnt-lbl{font-size:12px;font-weight:700;color:#9ca3af;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.pa-sales-cnt-num{font-size:14px;font-weight:900;color:#374151;line-height:1.1}
.pa-sales-right{flex:1;min-width:0;border:1px solid #dde3f5;border-radius:10px;padding:12px 16px;display:flex;flex-direction:column;justify-content:center}
.pa-chart-legend{display:flex;gap:14px;margin-bottom:6px;font-size:11px;font-weight:600;color:#374151}
.pa-legend-item{display:flex;align-items:center;gap:5px}

/* ── Section 1: 판매자 카드 ── */
.sp-seller-row{display:flex;align-items:center;gap:14px;padding:20px 18px;border-bottom:1px solid #f3f4f6;transition:background .12s}
.sp-seller-row:last-child{border-bottom:none}
.sp-seller-row:nth-child(even){background:rgba(94,98,244,.028)}
.sp-seller-row:hover{background:#eef1ff}
.sp-rank-c{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0;color:#fff;box-shadow:0 2px 5px rgba(0,0,0,.18)}
.sp-rank-top{background:#ef4444}
.sp-rank-rest{background:#3b82f6}
.sp-thumb-ph{width:68px;height:68px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:28px}
.sp-info{flex:1;min-width:0}
.sp-name{font-size:14px;color:#1e2340;line-height:1.5;font-weight:500;margin-bottom:6px}
.sp-chips{display:flex;flex-wrap:wrap;gap:4px}
.sp-chip{border-radius:20px;padding:2px 9px;font-size:12px;font-weight:500;white-space:nowrap}
.sp-ch-price{background:#f5f9ff;color:#1d4ed8}
.sp-ch-dlvry{background:#f9fafb;color:#4b5563}
.sp-ch-pc{background:#f4fdf6;color:#15803d}
.sp-ch-keep{background:#fef7fb;color:#9d174d}
.sp-ch-review{background:#fefdf4;color:#92400e}
.sp-ch-char{background:#faf8ff;color:#6d28d9}
.sp-ch-img{background:#f3fefc;color:#0f766e}
.sp-ch-terms{background:#f6f7ff;color:#4338ca}
.sp-ch-dup{background:#fff7f7;color:#b91c1c}
.sp-monthly-box{flex-shrink:0;white-space:nowrap;font-size:14px;font-weight:600;color:#374151}
.sp-monthly-num{font-size:14px;font-weight:800;color:#2563eb}
.sp-monthly-none{font-size:12px;color:#d1d5db;font-weight:400}

/* ── Section 2: 평균 인포그래픽 ── */
.ta-avg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px}
.ta-avg-card{background:#f8f9ff;border:1px solid #e0e3ff;border-radius:10px;padding:16px 12px;text-align:center}
.ta-avg-card-lbl{font-size:14px;font-weight:600;color:#374151;margin-bottom:6px}
.ta-avg-card-val{font-size:22px;font-weight:800;color:#2563eb;line-height:1.2}
.ta-avg-card-val.is-main{font-size:28px;color:#2563eb}
.ta-avg-card-val small{font-size:13px;font-weight:600;color:#6b7280}
.ta-avg-card-unit{font-size:12px;color:#6b7280;font-weight:500}
.ta-bars-title{font-size:13px;font-weight:700;color:#374151;margin-bottom:14px;margin-top:4px}
.ta-bar-row{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.ta-bar-lbl{font-size:13px;color:#6b7280;width:70px;flex-shrink:0;text-align:right}
.ta-bar-track{flex:1;height:12px;background:#f0f1f9;border-radius:6px;overflow:hidden}
.ta-bar-fill{height:100%;border-radius:6px;transition:width .4s}
.ta-bar-val{font-size:13px;font-weight:700;color:#2563eb;width:52px;flex-shrink:0}
.ta-bar-note{font-size:11px;color:#9ca3af;width:72px;flex-shrink:0}
.ta-avg-row{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:11px 16px;font-size:13px;color:#374151;margin-top:6px;line-height:2.0}
.ta-insight-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.ta-insight-chip{display:flex;align-items:center;gap:5px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:7px 12px;font-size:13px;color:#15803d;font-weight:500}
.ta-insight-chip.warn{background:#fff7ed;border-color:#fdba74;color:#9a3412}
.ta-insight-chip.info{background:#f0f9ff;border-color:#93c5fd;color:#1e40af}

/* ── Section 3: 조합형 키워드 ── */
.sp-kw-section{margin-bottom:28px;background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.04);overflow:hidden}
.sp-kw-section:last-child{margin-bottom:0}
.sp-kw-section-hd{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f8f9ff;border-bottom:1px solid #f0f0f5}
.sp-kw-hd-triple .sp-kw-section-hd{background:#f0f4ff}
.sp-kw-hd-double .sp-kw-section-hd{background:#f5f3ff}
.sp-kw-hd-single .sp-kw-section-hd{background:#f0fdf4}
.sp-kw-hd-title{font-size:13px;font-weight:700;color:#1e2340}
.sp-kw-hd-cnt{font-size:13px;font-weight:600;color:#374151;margin-left:auto}
.sp-kw-chips{display:flex;flex-wrap:wrap;gap:7px;padding:14px 16px}
.sp-kw-chip{display:inline-flex;align-items:center;gap:6px;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;border:1.5px solid transparent}
.sp-kw-chip-triple{background:#ffffff;color:#1d4ed8;border-color:#bfdbfe}
.sp-kw-chip-triple:hover{background:#dbeafe;transform:translateY(-1px)}
.sp-kw-chip-double{background:#ffffff;color:#5b21b6;border-color:#ddd6fe}
.sp-kw-chip-double:hover{background:#ede9fe;transform:translateY(-1px)}
.sp-kw-chip-single{background:#ffffff;color:#065f46;border-color:#bbf7d0}
.sp-kw-chip-single:hover{background:#dcfce7;transform:translateY(-1px)}
.sp-kw-badge{font-size:10px;font-weight:700;background:rgba(0,0,0,.08);border-radius:10px;padding:1px 6px;flex-shrink:0}

/* ── INQUIRY SECTION ── */
.inq-types{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.inq-chip{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border:1.5px solid var(--border);border-radius:20px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .13s;background:#fff;user-select:none}
.inq-chip:hover{border-color:var(--accent);color:var(--accent)}
.inq-chip input[type=radio]{display:none}
.inq-chip.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:700}
.inq-reply-box{background:#f0fdf4;border-left:3px solid #10B981;border-radius:0 8px 8px 0;padding:14px 18px;margin-top:4px}
.inq-reply-label{font-size:11.5px;font-weight:700;color:#065F46;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}
.inq-reply-body{font-size:13.5px;color:#14532d;line-height:1.75;white-space:pre-line}
.inq-pending-box{background:#fffbeb;border-left:3px solid #f59e0b;border-radius:0 8px 8px 0;padding:14px 18px;font-size:13.5px;color:#92400e;line-height:1.7;margin-top:4px}
.inq-form-inner{padding:24px}
.inq-form-label{font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:8px}
.inq-textarea{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:7px;font-size:13.5px;font-family:inherit;color:var(--text);background:#fff;outline:none;resize:vertical;min-height:130px;transition:border-color .13s}
.inq-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(94,98,244,.09)}

/* ── 모음전 리스트 (cl-) ── */
.cl-tab-nav{display:flex;gap:0;border-bottom:2px solid #e8e8ff;margin-bottom:0}
.cl-tab{padding:10px 24px;font-size:14px;font-weight:600;color:#888;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-2px;transition:color .15s,border-color .15s;font-family:inherit}
.cl-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.cl-tab:hover{color:var(--accent)}
.cl-view{display:none}
.cl-view.active{display:block}
.cl-store-tag{display:inline-block;padding:2px 8px;border-radius:5px;font-size:12px;font-weight:700;background:#ede9ff;color:var(--accent)}
.cl-store-tag.cl-st2{background:#e0f2fe;color:#0369a1}
.cl-name-link{color:var(--accent);font-weight:600;cursor:pointer}
.cl-name-link:hover{text-decoration:underline}
.cl-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:700}
.cl-done{background:#dcfce7;color:#15803d}
.cl-running{background:#dbeafe;color:#1d4ed8}
.cl-idle{background:#f3f4f6;color:#6b7280}
.cl-failed{background:#fee2e2;color:#b91c1c}
.cl-cowork{background:#fef3c7;color:#92400e}
.cl-act-btn{padding:4px 10px;border:1px solid #d1d5db;border-radius:5px;background:#fff;font-size:12px;font-weight:600;color:#374151;cursor:pointer;font-family:inherit;transition:all .12s}
.cl-act-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.cl-act-btn.cl-rollback:hover:not(:disabled){border-color:#f59e0b;color:#d97706}
.cl-act-btn.cl-del:hover:not(:disabled){border-color:#ef4444;color:#dc2626}

/* ── 새 모음전 생성 (cn-) ── */
.cn-steps{display:flex;align-items:center;padding:20px 24px 4px}
.cn-step{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}
.cn-step-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;background:#e5e7eb;color:#9ca3af;flex-shrink:0}
.cn-step.done .cn-step-dot{background:#22c55e;color:#fff}
.cn-step.active .cn-step-dot{background:var(--accent);color:#fff}
.cn-step-lbl{font-size:11px;font-weight:600;color:#9ca3af;white-space:nowrap}
.cn-step.done .cn-step-lbl,.cn-step.active .cn-step-lbl{color:#374151}
.cn-step-line{flex:1;height:2px;background:#e5e7eb;margin-bottom:16px}
.cn-step-line.done{background:#22c55e}

.cn-section{background:#fff;border:1px solid var(--border);border-radius:12px;margin:14px 20px 0;overflow:hidden}
.cn-section:last-child{margin-bottom:24px}
.cn-section-hd{display:flex;align-items:center;gap:10px;padding:11px 18px;border-bottom:1px solid var(--border-light);background:#f9fafb}
.cn-sn{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;background:#e5e7eb;color:#9ca3af}
.cn-sn.done{background:#22c55e;color:#fff}
.cn-sn.active{background:var(--accent);color:#fff}
.cn-section-title{font-size:14px;font-weight:700;color:#1e2340;flex:1}
.cn-badge{font-size:11px;font-weight:700;padding:2px 9px;border-radius:10px}
.cn-badge.done{background:#dcfce7;color:#15803d}
.cn-badge.active{background:#ede9ff;color:var(--accent)}
.cn-badge.wait{background:#f3f4f6;color:#9ca3af}
.cn-section-body{padding:16px 18px}

.cn-frow{display:flex;align-items:flex-start;gap:14px;margin-bottom:11px}
.cn-frow:last-child{margin-bottom:0}
.cn-flbl{font-size:13px;font-weight:600;color:#374151;width:100px;flex-shrink:0;padding-top:7px}
.cn-finput{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:7px 11px;font-size:13px;font-family:inherit;color:#1e2340}
.cn-fselect{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:7px 11px;font-size:13px;font-family:inherit;color:#1e2340;background:#fff}
.cn-price-tag{display:inline-flex;align-items:center;gap:8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:5px 12px;font-size:12px;color:#1d4ed8;margin-top:6px;font-weight:600}

.cn-pipeline{display:flex;gap:16px;align-items:flex-start}
.cn-slots-col{flex:1;min-width:0}
.cn-slots-hdr{display:grid;grid-template-columns:28px 100px 1fr 72px 24px;gap:6px;padding:0 0 6px;font-size:11px;font-weight:700;color:#9ca3af;border-bottom:1px solid #f0f1f6;margin-bottom:3px}
.cn-slot-row{display:grid;grid-template-columns:28px 100px 1fr 72px 24px;gap:6px;padding:5px 0;border-bottom:1px solid #f9fafc;align-items:center}
.cn-slot-row.is-warn{background:#fffbeb;border-radius:4px;padding:5px 4px}
.cn-slot-row.is-err{background:#fff5f5;border-radius:4px;padding:5px 4px}
.cn-slot-n{font-size:10px;font-weight:800;width:26px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;background:#e5e7eb;color:#6b7280;flex-shrink:0}
.cn-slot-n.base{background:#dbeafe;color:#1d4ed8}
.cn-slot-pno{border:1px solid #d1d5db;border-radius:5px;padding:4px 6px;font-size:12px;font-family:inherit;width:100%}
.cn-slot-name{border:1px solid #d1d5db;border-radius:5px;padding:4px 6px;font-size:12px;font-family:inherit;width:100%}
.cn-slot-story-tag{font-size:10px;font-weight:700;padding:2px 5px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.cn-slot-story-tag.ok{background:#eff6ff;color:#1d4ed8}
.cn-slot-story-tag.none{background:#f3f4f6;color:#9ca3af}
.cn-slot-st{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}
.cn-slot-st.ok{background:#dcfce7;color:#15803d}
.cn-slot-st.warn{background:#fef3c7;color:#92400e}
.cn-slot-st.err{background:#fee2e2;color:#b91c1c}
.cn-slot-st.empty{background:#f3f4f6;color:#d1d5db}
.cn-warn-box{background:#fef9ec;border:1px solid #fcd34d;border-radius:8px;padding:9px 13px;margin-top:11px}
.cn-err-box{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:9px 13px;margin-top:7px}
.cn-warn-hd,.cn-err-hd{font-size:12px;font-weight:700;margin-bottom:4px}
.cn-warn-hd{color:#92400e}
.cn-err-hd{color:#b91c1c}
.cn-warn-item{font-size:12px;color:#92400e;padding:1px 0}
.cn-err-item{font-size:12px;color:#b91c1c;padding:1px 0}
.cn-pipe-btns{display:flex;gap:8px;margin-top:13px;justify-content:flex-end}

.cn-rp{width:200px;flex-shrink:0}
.cn-rp-hdr{font-size:12px;font-weight:700;color:#9ca3af;margin-bottom:8px}
.cn-card{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:8px;overflow:hidden}
.cn-card-img{height:52px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:22px}
.cn-card-body{padding:5px 8px 7px}
.cn-card-slot-lbl{font-size:10px;font-weight:700;color:#9ca3af}
.cn-card-name{font-size:12px;font-weight:600;color:#1e2340;line-height:1.3;margin:2px 0}
.cn-card-price{font-size:11px;color:#6b7280}
.cn-card-story{font-size:10px;font-weight:700;margin-top:3px}
.cn-card-story.ok{color:#2563eb}
.cn-card-story.none{color:#d1d5db}

.cn-story-prog-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.cn-story-prog-bar-wrap{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}
.cn-story-prog-bar{height:100%;background:var(--accent);border-radius:4px;width:40%}
.cn-story-prog-txt{font-size:13px;font-weight:700;color:#374151;white-space:nowrap}
.cn-story-list{display:flex;flex-direction:column;gap:4px}
.cn-story-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #f9fafc}
.cn-story-row:last-child{border-bottom:none}
.cn-story-row-n{font-size:11px;font-weight:800;color:#9ca3af;width:22px;flex-shrink:0}
.cn-story-row-name{flex:1;font-size:13px;color:#374151}
.cn-story-row-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap}
.cn-story-row-tag.ok{background:#dcfce7;color:#15803d}
.cn-story-row-tag.working{background:#ede9ff;color:var(--accent)}
.cn-story-row-tag.wait{background:#f3f4f6;color:#9ca3af}
.cn-story-btns{display:flex;gap:8px;margin-top:13px;justify-content:flex-end}

.cn-reg-checks{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.cn-reg-check{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px}
.cn-reg-check.ok{background:#dcfce7;color:#15803d}
.cn-reg-check.warn{background:#fef3c7;color:#92400e}
.cn-reg-prog-wrap{background:#f3f4f6;border-radius:8px;height:10px;overflow:hidden;margin-bottom:6px}
.cn-reg-prog-bar{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:8px;width:65%}
.cn-reg-prog-txt{font-size:12px;color:#6b7280;margin-bottom:12px;font-weight:600}
.cn-reg-log{background:#1e2340;border-radius:8px;padding:11px 14px;font-family:monospace;font-size:11px;line-height:2;color:#a8b4d8}
.cn-reg-log-ok{color:#4ade80}
.cn-reg-log-working{color:#a78bfa}
.cn-reg-log-wait{color:#4b5875}

/* 새 모음전 — 실제 레이아웃 */
.cn-guide-bar{background:#fff;border-radius:10px;padding:13px 18px;border-left:4px solid var(--accent);font-size:14px;font-weight:700;color:var(--accent);box-shadow:0 1px 6px rgba(0,0,0,.06)}
.cn-info-summary{background:#fff;border-radius:10px;padding:11px 18px;display:flex;align-items:center;gap:24px;border:1px solid var(--border);flex-wrap:wrap}
.cn-si{display:flex;align-items:center;gap:7px}
.cn-si-lbl{font-size:13px;color:#888}
.cn-info-summary strong{font-size:14px;font-weight:700;color:#1e2340}
.cn-edit-btn{margin-left:auto;padding:5px 14px;border:1px solid var(--border);border-radius:7px;background:#fff;font-size:12px;font-weight:600;color:#555;cursor:pointer;font-family:inherit}
.cn-edit-btn:hover{border-color:var(--accent);color:var(--accent)}

.cn-editor{display:flex;gap:14px;padding:0 20px 24px;min-height:calc(100vh - 300px)}
.cn-left{flex:1;min-width:0;background:#fff;border-radius:12px;border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.cn-right{flex:1;min-width:0;background:#fff;border-radius:12px;border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.cn-panel-hd{padding:12px 16px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.cn-panel-hd h3{font-size:15px;font-weight:700;color:#1e2340;margin:0}
.cn-panel-body{flex:1;overflow-y:auto;padding:14px 16px}

.cn-price-range-box{padding:8px 12px;background:#fff8e1;border:1px solid #ffe082;border-radius:7px;font-size:13px;color:#5d3e2e;margin-bottom:12px;line-height:1.6}
.cn-item-hd{display:grid;grid-template-columns:26px 100px 1fr 90px 22px;gap:4px;padding:0 0 5px;border-bottom:2px solid var(--border);margin-bottom:2px}
.cn-item-hd span{font-size:13px;font-weight:700;color:#555;text-align:center}
.cn-item-row{display:grid;grid-template-columns:26px 100px 1fr 90px 22px;gap:4px;align-items:center;padding:3px 0;border-bottom:1px solid #f5f5f5}
.cn-item-row input{padding:6px 7px;border:1px solid #e0e0e0;border-radius:4px;font-size:13px;font-family:inherit;width:100%;color:#222;box-sizing:border-box}
.cn-item-row input:focus{outline:none;border-color:var(--accent)}
.cn-item-row input.st-ok{border-color:#27ae60!important;background:#f0fff4!important}
.cn-item-row input.st-warn{border-color:#e67e22!important;background:#fff8e1!important}
.cn-item-row input.st-error{border-color:#e74c3c!important;background:#fff5f5!important}
.cn-slot-no{font-size:14px;font-weight:700;text-align:center;color:var(--accent)}
.cn-btn-del{width:20px;height:20px;border:none;background:#f0f0f0;color:#999;border-radius:3px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;padding:0;font-family:inherit}
.cn-btn-del:hover{background:#ff4d4d;color:#fff}
.cn-btn-add-slot{width:100%;margin-top:8px;padding:9px;background:#f4f5ff;color:var(--accent);border:1px dashed #c4c6f7;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .13s}
.cn-btn-add-slot:hover{background:#eaebff}
.cn-btn-fetch{display:block;width:100%;margin-top:12px;padding:13px;background:#27ae60;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:filter .15s}
.cn-btn-fetch:hover{filter:brightness(1.07)}
.cn-btn-story{display:block;width:100%;margin-top:10px;padding:13px;background:#ff6600;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:filter .15s}
.cn-btn-story:hover{filter:brightness(1.07)}

/* 미니 옵션 카드 */
.cn-mini-card{display:flex;align-items:stretch;border-radius:10px;overflow:hidden;background:#f8f7f4;border:1px solid #e0ddd8;min-height:130px;margin-bottom:10px;transition:box-shadow .15s}
.cn-mini-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.1)}
.cn-mc-base{border:2px solid var(--accent)}
.cn-mc-img{flex-shrink:0;width:120px;display:flex;align-items:flex-start;padding:10px 0 10px 12px;box-sizing:border-box}
.cn-mc-img-inner{width:100%;aspect-ratio:1/1;border-radius:6px;overflow:hidden;background:#fff;border:1px solid #e0ddd8;display:flex;align-items:center;justify-content:center;font-size:28px}
.cn-mc-body{flex:1;min-width:0;padding:12px 14px 10px 12px;display:flex;flex-direction:column;justify-content:space-between}
.cn-mc-badge{display:inline-block;align-self:flex-start;color:#fff;font-size:12px;font-weight:700;padding:3px 12px;border-radius:20px;margin-bottom:6px}
.cn-mc-name{font-size:14px;font-weight:700;color:#391d16;line-height:1.35;word-break:keep-all;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.cn-mc-bottom{margin-top:5px}
.cn-mc-price-area{text-align:right;line-height:1.3}
.cn-mc-orig{display:block;font-size:12px;color:#aaa;text-decoration:line-through}
.cn-mc-price{display:block;font-size:18px;font-weight:700;color:#fc5230}
.cn-mc-detail-btn{display:block;width:80%;margin:6px auto 0;padding:4px 0;border:1.5px solid #391d16;border-radius:20px;font-size:12px;font-weight:600;color:#391d16;background:#fff;text-align:center;cursor:default}
.cn-mc-story{margin-top:4px;font-size:12px;font-family:monospace;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 자동등록 영역 */
.cn-autoreg-area{padding:14px 16px;border-top:1px solid var(--border-light);flex-shrink:0}
.cn-btn-autoreg{width:100%;padding:13px;font-size:15px;font-weight:700;background:#e74c3c;color:#fff;border:none;border-radius:8px;cursor:pointer;font-family:inherit;transition:filter .15s}
.cn-btn-autoreg:hover{filter:brightness(1.07)}
.cn-autoreg-warn{margin-top:8px;padding:9px 13px;background:#fffbeb;border:1.5px solid #f59e0b;border-radius:8px;font-size:12px;color:#92400e;line-height:1.7}
.cn-prog-wrap{height:6px;background:#eee;border-radius:3px;margin:10px 0 4px;overflow:hidden}
.cn-prog-fill{height:100%;border-radius:3px;background:#27ae60;transition:width .3s}
.cn-prog-text{font-size:13px;color:#666;text-align:center}

/* ── 옵션카드 생성 (co-) ── */
.co-work-area{display:flex;gap:0;align-items:flex-start;padding:0 20px 24px}
.co-form-panel{width:420px;flex-shrink:0;background:#fff;border-radius:12px;border:1px solid var(--border);border-top:3px solid var(--accent);box-shadow:0 2px 10px rgba(94,98,244,.09);overflow:hidden}
.co-preview-panel{flex:1;min-width:0;max-width:660px;background:#fff;border-radius:12px;border:1px solid var(--border);border-top:3px solid #27ae60;box-shadow:0 2px 10px rgba(39,174,96,.09);overflow:hidden}
.co-arrow{display:flex;align-items:flex-start;justify-content:center;padding-top:160px;width:80px;flex-shrink:0;font-size:36px;color:var(--accent);font-weight:900;user-select:none}
.co-panel-hd{padding:18px 20px 14px;border-bottom:1px solid var(--border-light)}
.co-panel-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 2px}
.co-panel-sub{font-size:12.5px;color:var(--text-muted)}
.co-panel-body{padding:20px}
.co-group{margin-bottom:16px}
.co-group label{display:block;font-size:14px;font-weight:600;color:#555;margin-bottom:6px}
.co-group .co-req{color:#e74c3c}
.co-group .co-hint{font-size:12px;font-weight:500;color:#e74c3c;margin-left:4px}
.co-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:#fafbfc;box-sizing:border-box;font-family:inherit;outline:none;transition:border-color .13s}
.co-input:focus{border-color:var(--accent);background:#fff}
.co-textarea{resize:vertical;min-height:58px}
.co-divider{border:none;border-top:1px dashed var(--border-light);margin:4px 0 16px}
.co-img-selector{display:flex;flex-direction:column;gap:8px}
.co-img-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1.5px solid var(--border);border-radius:9px;cursor:pointer;transition:border-color .15s,background .15s;background:#fafbfc}
.co-img-row.selected{border-color:var(--accent);background:#f5f4ff}
.co-img-row.unselected{opacity:.45;pointer-events:none}
.co-img-radio{width:16px;height:16px;border-radius:50%;border:2px solid #bbb;flex-shrink:0;transition:border-color .15s;display:flex;align-items:center;justify-content:center}
.co-img-row.selected .co-img-radio{border-color:var(--accent)}
.co-img-radio-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:none}
.co-img-row.selected .co-img-radio-dot{display:block}
.co-img-row-label{font-size:13px;font-weight:700;color:#555;white-space:nowrap;flex-shrink:0;min-width:72px}
.co-img-row.selected .co-img-row-label{color:var(--accent)}
.co-img-row-body{display:flex;gap:6px;align-items:center;flex:1;min-width:0}
.co-img-row-body input[type="text"]{flex:1;min-width:0;padding:7px 10px;border:1px solid var(--border);border-radius:7px;font-size:13.5px;color:var(--text);background:#fff;font-family:inherit;outline:none}
.co-img-row-body input[type="text"]:focus{border-color:var(--accent)}
.co-img-row-body input[type="file"]{flex:1;min-width:0;font-size:13px;font-family:inherit}
.co-img-thumb{width:40px;height:40px;border-radius:5px;object-fit:cover;border:1px solid #ddd;display:none;flex-shrink:0}
.co-story-box{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 10px;border-radius:8px;font-size:13px}
.co-story-has{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}
.co-story-none{background:#f8f9fa;border:1px solid var(--border);color:#999}
.co-story-label{flex-shrink:0;font-weight:700}
.co-story-link{flex:1;word-break:break-all;font-size:11px;color:#166534;text-decoration:none}
.co-story-link:hover{text-decoration:underline}
.co-status{margin-top:12px;min-height:20px;padding:0 20px 8px}
.co-msg{padding:10px 14px;border-radius:8px;font-size:14px}
.co-msg-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}
.co-msg-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}
.co-msg-ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}
/* 카드 미리보기 — 실제 카드 디자인 그대로 유지 */
.co-preview-outer{overflow:hidden;border-radius:8px;border:1px solid #e8e8f0;background:#f8f7f4}
.co-prev-card{display:flex;width:860px;height:392px;background:#f8f7f4;overflow:hidden;font-family:'Pretendard','Noto Sans KR',-apple-system,sans-serif}
.co-prev-img-wrap{flex-shrink:0;display:flex;align-items:flex-start;padding:27px 0 27px 50px}
.co-prev-img-inner{width:337px;height:338px;border-radius:8px;overflow:hidden;background:#e8e5e0;border:2px solid #c5c0b8;display:flex;align-items:center;justify-content:center}
.co-prev-img-inner img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.co-prev-img-ph{color:#bbb;font-size:13px;text-align:center}
.co-prev-content{flex:1;padding:27px 46px 27px 50px;display:flex;flex-direction:column;align-items:stretch}
.co-prev-top{display:flex;flex-direction:column;align-items:flex-start}
.co-prev-badge{display:inline-block;align-self:flex-start;background:#391d16;color:#fff;font-weight:600;font-size:27px;padding:14px 52px;border-radius:30px;margin-top:8px;margin-bottom:18px;letter-spacing:1px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.co-prev-name{font-weight:700;font-size:36.5px;color:#391d16;line-height:1.3;word-break:keep-all}
.co-prev-price-area{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;text-align:right}
.co-prev-orig{font-size:28px;color:#aaa;text-decoration:line-through;margin-bottom:10px;line-height:1;display:none}
.co-prev-price{font-size:35.75px;font-weight:700;color:#fc5230;line-height:1}
.co-prev-btn-wrap{display:flex;flex-direction:column;align-items:stretch}
.co-prev-detail-btn{display:block;width:80%;margin:0 auto;padding:13px 0;border:2px solid #391d16;border-radius:30px;font-weight:600;font-size:24.9px;color:#391d16;background:#fff;text-align:center;letter-spacing:2px}

/* ── 쇼핑스토리 생성 (cs-) ── */
.cs-guide-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:14px 20px;border-bottom:1px solid var(--border-light)}
.cs-stage-guide{font-size:17px;font-weight:600;color:var(--accent)}
.cs-store-lbl{font-size:13.5px;color:#555;flex-shrink:0}
.cs-store-lbl strong{color:var(--text)}
.cs-bottom-row{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px;border-top:1px solid var(--border-light)}
.cs-btn-reset{padding:11px 24px;border:1.5px solid #ccc;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;background:#fff;color:#555;display:none;font-family:inherit}
.cs-btn-reset:hover{background:#f4f5f7;border-color:#aaa}
.cs-btn-action{padding:12px 32px;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;color:#fff;white-space:nowrap;transition:filter .15s;font-family:inherit}
.cs-btn-action:disabled{opacity:.45;cursor:not-allowed}
.cs-btn-action:not(:disabled):hover{filter:brightness(1.08)}
.cs-code-input{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:6px;font-size:14px;font-family:monospace;box-sizing:border-box;font-weight:600;color:#555;outline:none}
.cs-code-input::placeholder{color:#bbb;font-weight:600}
.cs-code-input:focus{border-color:var(--accent);border-width:2px}
.cs-code-input.cs-ro{background:#f4f5f7;color:#555;cursor:default}
.cs-code-input.cs-invalid{border-color:#fca5a5;background:#fff5f5}
.cs-title-input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;box-sizing:border-box;color:#333;outline:none;font-family:inherit}
.cs-title-input:focus{border-color:#ff6600;box-shadow:0 0 0 2px rgba(255,102,0,.1)}
.cs-story-ok{display:inline-block;padding:4px 12px;background:#dbeafe;color:#1d4ed8;border-radius:20px;font-size:15px;font-weight:700;font-family:monospace;text-decoration:none}
.cs-story-ok:hover{background:#bfdbfe}
.cs-story-fail{color:#dc2626;font-size:12px}
.cs-story-pending{color:#aaa;font-size:12px}
.cs-story-going{color:#ff6600;font-size:12px;font-weight:600}
.cs-warn{margin:0 0 12px;padding:10px 16px;background:#fffbeb;border:1px solid #f59e0b;border-radius:8px;font-size:13px;color:#92400e;line-height:1.5}
.cs-status{margin-top:12px;min-height:20px}
.cs-msg-error{padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px}
.cs-msg-info{padding:10px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1d4ed8;font-size:13px}

/* ── AD LIST 전용 컴포넌트 ── */
.al-stat-tab-wrap{display:flex;gap:6px}
.al-stat-tab{padding:6px 18px;font-size:13px;font-weight:600;border-radius:20px;border:1.5px solid var(--border);background:#fff;color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit}
.al-stat-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.al-kpi-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.al-kpi-card{flex:1;min-width:120px;background:#f8f9ff;border:1.5px solid #e8e8ff;border-radius:10px;padding:12px 16px;text-align:center;transition:all .15s}
.al-kpi-card.clickable{cursor:pointer}
.al-kpi-card.clickable:hover{background:#ededff}
.al-kpi-card.inactive{opacity:.38;background:#f5f5f5;border-color:#ddd}
.al-kpi-lbl{font-size:13px;color:var(--text-muted);margin-bottom:6px}
.al-kpi-val{font-size:22px;font-weight:800;color:var(--text)}
.al-stat-chart-wrap{background:#fafafa;border:1px solid var(--border);border-radius:8px;padding:14px 16px 6px;position:relative;margin-top:4px}
.al-stat-legend{display:flex;gap:16px;font-size:13px;margin-bottom:8px;flex-wrap:wrap}
.al-stat-legend-item{display:flex;align-items:center;gap:5px;font-weight:500;color:var(--text-2)}
.al-action-btn{display:inline-flex;align-items:center;padding:5px 12px;font-size:13px;font-weight:600;color:var(--accent);background:#fff;border:1px solid var(--accent);border-radius:5px;white-space:nowrap;cursor:pointer;font-family:inherit;transition:background .13s}
.al-action-btn:hover{background:#eef2ff}
.al-action-report{display:inline-flex;align-items:center;padding:5px 12px;font-size:13px;font-weight:600;color:#16a34a;background:#fff;border:1px solid #16a34a;border-radius:5px;white-space:nowrap;cursor:pointer;font-family:inherit;transition:background .13s}
.al-action-report:hover{background:#f0fdf4}

/* ── AD REPORT 전용 컴포넌트 ── */
.ar-day-tab{padding:13px 22px;font-size:14px;font-weight:600;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;color:var(--text-muted);transition:color .15s,border-color .15s;font-family:inherit}
.ar-day-tab:hover{color:var(--accent)}
.ar-day-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.ar-bulk-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f8f8ff;border-bottom:1px solid var(--border);flex-wrap:wrap}
.ar-bid-input{width:72px;padding:4px 6px;font-size:13px;font-weight:600;border:1px solid var(--border);border-radius:5px;text-align:right;color:var(--text-2);font-family:inherit;transition:border-color .15s}
.ar-bid-input:focus{outline:none;border-color:var(--accent)}
.ar-bid-input.dirty{border-color:#f59e0b;background:#fffbeb}
.ar-tog{padding:4px 10px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;min-width:48px;border:1px solid;font-family:inherit;user-select:none}
.ar-tog.on{background:#dcfce7;color:#16a34a;border-color:#86efac}
.ar-tog.off{background:#f3f4f6;color:#6b7280;border-color:#d1d5db}
.ar-tog.dirty{outline:2px solid #f59e0b;outline-offset:1px}
.ar-apply-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:#1e1b4b;padding:14px 24px;box-shadow:0 -4px 16px rgba(0,0,0,.25);align-items:center;justify-content:space-between;gap:12px}
.ar-apply-bar.show{display:flex}
.ar-result-modal{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.5);align-items:center;justify-content:center}
.ar-result-modal.show{display:flex}
.ar-grp-modal{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.5);align-items:center;justify-content:center}
.ar-grp-modal.show{display:flex}

/* ── AD FULL REPORT 전용 ── */
#aff-ldBar{display:none;position:fixed;top:0;left:0;right:0;z-index:9999;height:3px;background:linear-gradient(90deg,#6366F1,#a5b4fc,#6366F1);background-size:200% 100%;animation:affLda 1.2s infinite linear;}
@keyframes affLda{0%{background-position:200% 0}100%{background-position:-200% 0}}
#aff-chTip{position:fixed;display:none;z-index:9000;pointer-events:none;background:#1e1b4b;color:#fff;border-radius:10px;padding:10px 14px;font-size:12px;min-width:175px;box-shadow:0 4px 24px rgba(0,0,0,.4);line-height:1.9;}
#aff-chTip .t-date{font-size:13px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:5px;margin-bottom:6px;}
#aff-chTip .t-row{display:flex;justify-content:space-between;gap:18px;}
#aff-chTip .t-lbl{color:rgba(255,255,255,.6);}
#aff-chTip .t-val{font-weight:700;}
.aff-tbl-scroll{height:316px;overflow-y:scroll;}
.aff-data-table{width:100%;border-collapse:collapse;table-layout:fixed;}
.aff-data-table thead th{position:sticky;top:0;z-index:2;background:#e8ecf7;font-size:12px;font-weight:700;color:#374151;padding:9px 12px;text-align:center;border-bottom:2px solid #c5cde8;white-space:nowrap;}
.aff-data-table td{padding:11px 12px;font-size:13px;text-align:right;border-bottom:1px solid #e5e7eb;white-space:nowrap;}
.aff-data-table tbody tr:hover td{background:#f5f6ff!important;}
.aff-data-table td.nc{text-align:left;font-weight:600;color:#1a1a2e;overflow:hidden;text-overflow:ellipsis;}
.aff-row-drill td.nc{cursor:pointer;color:#2563eb;}
.aff-row-drill td.nc:hover{text-decoration:underline;}
.aff-row-sel td{background:#eef2ff!important;}
.aff-row-sel td.nc{color:#4f46e5!important;}
.aff-st-on{display:inline-block;padding:2px 7px;border-radius:10px;font-size:11px;background:#dcfce7;color:#16a34a;font-weight:600;}
.aff-st-off{display:inline-block;padding:2px 7px;border-radius:10px;font-size:11px;background:#f3f4f6;color:#9ca3af;font-weight:600;}
.aff-tfoot-row td{background:#eef2ff!important;font-weight:700;border-top:2px solid #6366F1;}
.aff-nd{color:#ddd;}
.aff-nc-gr{color:#16a34a;}.aff-nc-bl{color:#2563eb;}.aff-nc-or{color:#ea580c;}
.aff-bc-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;cursor:default;}
.aff-bc-badge.clickable{cursor:pointer;transition:opacity .15s;}
.aff-bc-badge.clickable:hover{opacity:.65;}
.aff-bc-sep{color:#4b5563;font-size:16px;font-weight:700;margin:0 1px;line-height:1;}
.aff-bc-lbl{font-size:12px;font-weight:700;color:#4b5563;white-space:nowrap;letter-spacing:.3px;text-transform:uppercase;}
.aff-lvl-ch{background:#fdf4ff;color:#c084fc;border:1px solid #f3e8ff;}
.aff-lvl-ca{background:#f0f9ff;color:#0284c7;border:1px solid #e0f2fe;}
.aff-lvl-gr{background:#f0fdf4;color:#059669;border:1px solid #d1fae5;}
.aff-lvl-cr{background:#f9fafb;color:#9ca3af;border:1px solid #f1f5f9;}
#aff-bgLoad{display:none;position:fixed;bottom:18px;right:18px;background:rgba(30,27,75,.9);color:#c7d2fe;border-radius:20px;padding:7px 16px;font-size:12px;z-index:8999;pointer-events:none;}
