/* UI — "Analytics" theme (Tremor 톤). 기능/마크업 동일, 디자인 레이어 교체.
   골격: 상단 가로 top-nav · KPI 카드 · 깔끔한 데이터 테이블 · 인디고 포인트 · 파스텔 뱃지 */
:root{
  /* BEACON · Huly 다크 (huly.io 라이브 추출) — 니어블랙 베이스, 블루+코랄 액센트, Inter+모노, 글로우/빔 */
  --bg:#090a0c; --bg2:#0c0c0d; --card:#161719; --card2:#1d1e21; --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.14);
  --ink:#e9eaec; --ink2:rgba(255,255,255,.66); --ink3:#9a9da3; --muted:#7c7f86; --head:#6c6f76;
  --indigo:#4d8df0; --indigo2:#5b9bf3; --tint:rgba(77,141,240,.14); --deep:#3a6fc0; /* 블루 액센트(링크·포커스·primary) */
  --navy:#0c0d0f; --navy2:#161719; /* 사이드바 베이스/표면 */
  --beacon:#f0883e; --beacon2:#e8843a; /* 웜 오렌지 액센트(레퍼 팔레트 ref/컬러.png) */
  --brand-g1:#4d8df0; --brand-g2:#5b9bf3; /* primary 버튼 = 블루(huly) */
  --green:#3aa776; --green-bg:rgba(58,167,118,.14); --blue:#4d8df0; --blue-bg:rgba(77,141,240,.14);
  --violet:#b6a8ec; --violet-bg:rgba(182,168,236,.14); --amber:#e8843a; --amber-bg:rgba(232,132,58,.14);
  --red:#e5644e; --red-bg:rgba(229,100,78,.14);
  --topbar-h:58px; --sidebar-w:236px;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace; /* 숫자·데이터 huly 모노 */
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 10px 30px -16px rgba(0,0,0,.7);
  --shadow-pop:0 24px 60px -18px rgba(0,0,0,.8);
}
*{box-sizing:border-box;} html,body{margin:0;padding:0;}
body{
  font-family:"Pretendard",-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic","맑은 고딕","Noto Sans KR",sans-serif;
  background:var(--bg); color:var(--ink); font-size:14px;
  -webkit-font-smoothing:antialiased; font-feature-settings:"tnum";
}
a{color:inherit;text-decoration:none;}

/* ---------- left sidebar ---------- */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:30;
  background:var(--navy);border-right:1px solid rgba(255,255,255,.07);
  display:flex;flex-direction:column;padding:18px 14px 16px;}
.sidebar .brand{display:flex;align-items:center;justify-content:center;gap:9px;padding:8px 4px 22px;border-radius:10px;transition:opacity .15s;}
.sidebar .brand:hover{opacity:.7;}
.sidebar .brand .brand-mark{height:34px;width:auto;display:block;filter:drop-shadow(0 4px 10px rgba(245,166,35,.30));}
.sidebar .brand .brand-word{font-family:"Sora","Pretendard",sans-serif;font-weight:800;font-size:21px;line-height:1;
  letter-spacing:.02em;background:linear-gradient(135deg,#f5a623 0%,#fbc04a 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.sidebar nav{display:flex;flex-direction:column;gap:6px;}
.sidebar nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;white-space:nowrap;
  padding:16px 8px;border-radius:12px;color:#9fb3c9;font-weight:700;font-size:13px;}
.sidebar nav a svg{width:27px;height:27px;flex:none;color:#7e93ab;}
.sidebar nav a:hover{background:rgba(255,255,255,.07);color:#fff;}
.sidebar nav a:hover svg{color:#cfe0f0;}
.sidebar nav a.active{background:rgba(245,166,35,.16);color:var(--beacon);}
.sidebar nav a.active svg{color:var(--beacon);}
.sidebar .spacer{flex:1;}
.sidebar .user-wrap{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;}
.hamburger{display:none;position:fixed;top:14px;left:14px;z-index:40;background:var(--card);border:1px solid var(--line2);border-radius:9px;cursor:pointer;color:var(--ink2);padding:7px;}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(16,24,40,.4);z-index:25;}

/* user dropdown (JS: .user-menu.show) */
.user-wrap{position:relative;}
.user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:7px 8px;border-radius:10px;font-weight:700;color:#cfe0f0;}
.user:hover{background:rgba(255,255,255,.07);}
.user .uava{width:30px;height:30px;border-radius:50%;background:var(--beacon);color:#0b1a2a;
  font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;flex:none;}
.user .uname{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.user svg{margin-left:auto;flex:none;}
.user-menu{position:fixed;bottom:56px;left:10px;width:206px;background:var(--card);border:1px solid var(--line2);
  border-radius:12px;box-shadow:var(--shadow-pop);display:none;overflow:hidden;z-index:80;}
.user-menu.show{display:block;}
.user-menu .um-head{text-align:center;padding:16px 12px 12px;border-bottom:1px solid var(--line);}
.user-menu .um-name{font-weight:800;color:var(--ink);}
.user-menu .um-role{color:var(--muted);font-size:13px;margin-top:2px;}
.user-menu .um-item{display:block;text-align:center;padding:11px 12px;font-weight:600;color:var(--ink2);}
.user-menu .um-item:hover{background:rgba(255,255,255,.06);color:var(--indigo);}

/* ---------- layout ---------- */
.main{margin-left:var(--sidebar-w);padding-top:0;}
.content{padding:34px 40px 90px;max-width:none;}
.page-title{font-size:25px;font-weight:800;color:var(--ink);margin:0 0 22px;letter-spacing:-.01em;}
.page-desc{color:var(--muted);margin:0 0 24px;font-size:14px;}

/* ---------- home (공지 + FAQ 한 화면) ---------- */
.home-sec{margin-bottom:34px;}
.home-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 0 14px;flex-wrap:wrap;}
.home-sec-head .hs-title h2{margin:0;font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em;}
.home-sec-head .hs-title span{display:block;color:var(--muted);font-size:13px;margin-top:3px;}

/* ---------- 순위 모니터링 ---------- */
.rank-warn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;}
.rank-warn-card{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--red);
  border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);}
.rank-warn-card .rw-kw{font-weight:800;color:var(--ink);font-size:14px;}
.rank-warn-card .rw-name{color:var(--muted);font-size:12.5px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rank-warn-card .rw-meta{display:flex;align-items:center;justify-content:space-between;margin-top:10px;}
.rank-warn-card .rw-cur{font-weight:800;font-size:18px;color:var(--ink);}
.rank-warn-empty{background:var(--green-bg);border:1px solid #c6ecd9;color:#0c8f6e;
  border-radius:12px;padding:18px 20px;font-weight:600;}
.rank-delta{font-weight:800;font-size:13px;color:var(--muted);}
.rank-delta.up{color:var(--green);}   /* 순위 상승(개선) */
.rank-delta.down{color:var(--red);}   /* 순위 하락 */
.spark{vertical-align:middle;}

/* 계정 생성주체 태그 */
.owner-tag{display:inline-block;background:none;padding:0;border-radius:0;color:var(--ink2);font-weight:600;font-size:13px;}
.owner-tag.master{background:none;color:var(--indigo);}

/* 순위보고서 라인차트 */
.report-chart{position:relative;margin-top:6px;border:1px solid var(--line);border-radius:12px;padding:10px 8px 4px;background:var(--card);}
.report-chart .rk-dot{cursor:pointer;}
.report-chart .rk-dot:hover{fill:rgba(77,141,240,.16);}
.rk-tip{position:absolute;display:none;transform:translate(-50%,-118%);background:#1b1c1f;color:#fff;
  padding:5px 10px;border-radius:8px;font-size:12px;line-height:1.25;white-space:nowrap;pointer-events:none;z-index:5;
  box-shadow:0 4px 14px rgba(16,24,40,.22);text-align:center;}
.rk-tip b{font-weight:800;font-size:13px;}
.rk-tip span{display:block;font-weight:500;color:#cbd5e1;font-size:11px;margin-top:1px;}
.rk-tip::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1b1c1f;}

/* ---------- KPI cards (was .stats) ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;}
.card.stats{background:none;border:none;border-radius:0;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;padding:0;margin-bottom:26px;}
.stats .stat-title{display:none;}
.stats .stat{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:16px 18px;text-align:left;border-right:none;}
.stats .stat .num{font-size:26px;font-weight:800;color:var(--ink);line-height:1.1;margin-top:7px;}
.stats .stat.blue .num{color:var(--indigo);}
.stats .stat .label{color:var(--muted);font-size:13px;font-weight:600;}

/* ---------- analytics: KPI w/ sparkline + charts (계정/광고) ---------- */
.an-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:14px;}
.an-kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 17px;box-shadow:var(--shadow);}
.an-kpi .l{color:var(--muted);font-size:12.5px;font-weight:600;}
.an-kpi .row{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:8px;}
.an-kpi .v{font-size:25px;font-weight:800;color:var(--ink);line-height:1;}
.an-kpi.i .v{color:var(--indigo);}
.an-kpi .d{font-size:12px;font-weight:700;color:var(--green);margin-top:6px;}
.an-kpi svg{display:block;flex:none;}
/* KPI/통계 카드 클릭 필터 */
.an-kpi.clk,.stats .stat.clk{cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s;}
.an-kpi.clk:hover,.stats .stat.clk:hover{border-color:var(--indigo);transform:translateY(-1px);}
.an-kpi.sel,.stats .stat.sel{border-color:var(--indigo);box-shadow:0 0 0 2px var(--indigo);}
.an-charts{display:grid;grid-template-columns:1.4fr 1fr;gap:14px;margin-bottom:26px;}
.an-panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);}
.an-panel .ph{font-weight:800;font-size:14.5px;}
.an-panel .psub{color:var(--muted);font-size:12px;margin-bottom:14px;}
.an-bars{display:flex;align-items:flex-end;gap:14px;height:160px;padding-top:6px;}
.an-bars .col{flex:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:8px;}
.an-bars .bar{width:60%;background:linear-gradient(180deg,var(--indigo2),var(--indigo));border-radius:7px 7px 0 0;min-height:6px;}
.an-bars .lab{flex:none;color:var(--muted);font-size:12px;}
.an-bars .bv{flex:none;font-size:12px;font-weight:800;color:var(--ink2);}
.an-donut{display:flex;align-items:center;gap:20px;}
.an-leg{display:flex;flex-direction:column;gap:9px;font-size:13px;color:var(--ink2);font-weight:600;}
.an-leg .li{display:flex;align-items:center;gap:8px;}
.an-leg .sw{width:11px;height:11px;border-radius:3px;}
.an-leg b{margin-left:auto;color:var(--ink);}
@media(max-width:900px){.an-charts{grid-template-columns:1fr;}}

/* ---------- toolbar ---------- */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap;}
select.select{height:42px;min-width:120px;padding:0 12px;border:1px solid var(--line2);border-radius:10px;background:var(--card);color:var(--ink);font-size:14px;}
.search-wrap{display:flex;align-items:stretch;height:42px;border:1px solid var(--line2);border-radius:10px;overflow:hidden;background:var(--card);}
.search-wrap input{height:100%;width:320px;max-width:50vw;padding:0 14px;border:none;outline:none;font-size:14px;background:transparent;}
.search-wrap button{height:100%;width:46px;border:none;background:var(--indigo);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.search-wrap button:hover{background:#15707f;}

/* ---------- buttons ---------- */
.btn{height:40px;padding:0 17px;border-radius:9px;font-weight:700;font-size:14px;cursor:pointer;
  border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:.12s;}
.btn-primary{background:linear-gradient(135deg,var(--brand-g1) 0%,var(--brand-g2) 100%);color:#fff;
  box-shadow:0 6px 14px -6px rgba(77,141,240,.45);}
.btn-primary:hover{filter:saturate(1.08) brightness(1.03);}
.btn-danger{background:linear-gradient(135deg,#e5644e 0%,#cf5340 100%);color:#fff;
  box-shadow:0 6px 14px -6px rgba(229,100,78,.5);}
.btn-danger:hover{filter:saturate(1.08) brightness(1.03);}
.btn-ghost{background:var(--card);color:var(--ink2);border-color:var(--line2);}
.btn-ghost:hover{background:rgba(255,255,255,.06);color:var(--ink);}

/* ---------- rank status (ad page) ---------- */
.rank-status{display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin-bottom:16px;box-shadow:var(--shadow);}
.rank-status .rs-label{display:flex;align-items:center;gap:8px;color:var(--ink2);font-weight:600;font-size:13px;}
.rank-status .rs-label svg{color:var(--indigo);}
.rank-status .rs-label b{color:var(--ink);}
.rank-status .rs-sched{color:var(--muted);font-weight:600;margin-left:6px;padding-left:12px;border-left:1px solid var(--line2);}
.rank-status .rs-btn{height:36px;padding:0 16px;}

/* ---------- list head ---------- */
.list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:10px;flex-wrap:wrap;}
.selected-count{color:var(--ink2);font-weight:700;display:flex;align-items:center;gap:8px;font-size:13px;}
.selected-count svg{color:var(--indigo);}
.selected-count b{background:var(--tint);color:var(--indigo);border-radius:999px;padding:2px 9px;}
.actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ---------- table ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:var(--card);box-shadow:var(--shadow);}
table.grid{width:100%;border-collapse:collapse;background:var(--card);}
table.grid thead th{background:rgba(255,255,255,.04);color:var(--head);font-weight:700;font-size:11.5px;letter-spacing:.02em;
  padding:12px 12px;text-align:center;border-bottom:1px solid var(--line2);white-space:nowrap;}
table.grid tbody td{padding:12px 12px;text-align:center;border-bottom:1px solid var(--line);color:var(--ink2);white-space:nowrap;font-size:13px;}
table.grid tbody tr:last-child td{border-bottom:none;}
table.grid tbody tr:hover{background:rgba(255,255,255,.04);}
table.grid.dense thead th,table.grid.dense tbody td{padding-left:9px;padding-right:9px;font-size:12.5px;}
/* 넓은 표(광고관리)는 좁은 화면에서 컬럼 압축 대신 가로 스크롤 — .table-wrap의 overflow-x:auto와 함께 동작 */
table.grid.wide{min-width:1280px;}
/* 체크박스/정렬헤더는 셀 가운데 정렬에 맞춰 중앙 배치 */
table.grid .sorthead{justify-content:center;}
table.grid td.title-cell,table.grid th.title-cell{white-space:normal;max-width:220px;}
/* 광고관리 상품명: 최대한 넓게 */
table.grid td.prod-name,table.grid th.prod-name{white-space:normal;min-width:340px;max-width:none;width:auto;}
table.grid td.memo-cell{max-width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted);}
table.grid td.left{text-align:left;}
.link{color:var(--indigo);font-weight:700;background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;padding:0;}
.pin-badge{display:inline-block;background:var(--red-bg);color:var(--red);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;margin-right:8px;vertical-align:middle;}

/* role / status pills */
.role{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-weight:700;font-size:12.5px;}
.role.광고주{background:rgba(58,167,118,.14);color:#3aa776;}    /* 초록 */
.role.대행사{background:rgba(240,136,62,.14);color:#f0883e;}    /* 주황 */
.role.총판사{background:rgba(229,100,78,.14);color:#e5644e;}    /* 빨강 */
.role.마스터{background:var(--tint);color:var(--indigo);}
.status{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-weight:700;font-size:12.5px;}
.status .dot{width:6px;height:6px;border-radius:50%;}
.status.정상{background:var(--green-bg);color:var(--green);} .status.정상 .dot{background:var(--green);}
.status.대기{background:rgba(240,136,62,.14);color:#f0883e;} .status.대기 .dot{background:#f0883e;}
.status.오류{background:rgba(240,136,62,.14);color:#f0883e;} .status.오류 .dot{background:#f0883e;}
.type-추가,.type-신규,.type-발주,.type-연장,.type-환불{display:inline-flex;align-items:center;padding:3px 11px;border-radius:999px;font-weight:700;font-size:12.5px;text-shadow:0 0 8px currentColor;box-shadow:0 0 12px -4px currentColor, inset 0 0 0 1px currentColor;}
.type-추가,.type-신규,.type-발주{background:rgba(58,167,118,.14);color:#3aa776;}   /* 초록 */
.type-연장{background:rgba(240,136,62,.14);color:#f0883e;}                          /* 주황 */
.type-환불{background:rgba(229,100,78,.14);color:#e5644e;}                          /* 빨강 */
.empty{text-align:center;color:var(--muted);padding:50px 0;}
input[type=checkbox]{width:16px;height:16px;accent-color:var(--indigo);cursor:pointer;}

/* ---------- pagination ---------- */
.pager{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:24px;}
.pager a,.pager span{min-width:34px;height:34px;padding:0 8px;border-radius:9px;border:1px solid var(--line2);
  background:var(--card);display:inline-flex;align-items:center;justify-content:center;color:var(--ink2);font-weight:700;}
.pager a:hover{background:rgba(255,255,255,.06);}
.pager .cur{background:var(--indigo);color:#fff;border-color:var(--indigo);}
.pager .gap{border:none;background:none;}
.pager-right{display:flex;align-items:center;gap:14px;justify-content:flex-end;margin-top:20px;color:var(--muted);}
.pager-right .goto{display:flex;align-items:center;gap:8px;}
.pager-right .goto .box{border:1px solid var(--line2);border-radius:8px;width:42px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);font-weight:700;}

/* ---------- faq ---------- */
.faq-list{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-item:last-child{border-bottom:none;}
.faq-q{display:flex;align-items:center;gap:16px;padding:22px 26px;cursor:pointer;font-weight:700;color:var(--ink);}
.faq-q .q{color:var(--indigo);font-weight:800;font-size:16px;width:14px;}
.faq-q .faq-check{flex:none;width:16px;height:16px;cursor:pointer;accent-color:var(--brand-g1);}
.faq-q .chev{margin-left:auto;transition:transform .2s;color:#b7bdc8;}
.faq-item.open .faq-q .chev{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;color:var(--ink2);background:rgba(255,255,255,.04);}
.faq-item.open .faq-a{max-height:400px;}
.faq-a .inner{display:flex;gap:16px;padding:22px 26px;line-height:1.6;}
.faq-a .inner .a{color:var(--indigo);font-weight:800;font-size:16px;width:14px;flex:none;}
.faq-a .inner .atext{white-space:pre-line;}
.faq-a .inner .faq-edit-btn{margin-left:auto;align-self:flex-start;flex:none;padding:6px 14px;font-size:12.5px;}

/* ---------- date filter (log) ---------- */
.daterow{display:flex;align-items:center;gap:8px;margin-bottom:22px;flex-wrap:wrap;}
.daterow input[type=date]{height:42px;border:1px solid var(--line2);border-radius:10px;padding:0 12px;}
.daterow .quick{height:42px;padding:0 16px;border:1px solid var(--line2);background:var(--card);border-radius:10px;font-weight:700;cursor:pointer;color:var(--ink2);display:inline-flex;align-items:center;justify-content:center;line-height:1;white-space:nowrap;}
.daterow .quick.active{background:var(--indigo);color:#fff;border-color:var(--indigo);}
.daterow .spacer{flex:1;}

/* ---------- modal ---------- */
.modal-back{position:fixed;inset:0;background:rgba(17,24,39,.5);display:none;align-items:center;justify-content:center;z-index:50;}
.modal-back.show{display:flex;}
.modal{background:var(--card);border-radius:16px;width:480px;max-width:92vw;max-height:90vh;overflow-y:auto;padding:26px 28px;box-shadow:var(--shadow-pop);}
.modal h3{margin:0 0 18px;font-size:18px;font-weight:800;}
.modal label{display:block;font-weight:700;margin:14px 0 6px;font-size:13px;color:var(--ink2);}
.modal input,.modal textarea,.modal select{width:100%;border:1px solid var(--line2);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;background:var(--card2);color:var(--ink);}
.modal textarea{min-height:90px;resize:vertical;}
.modal .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;}

/* ---------- drawer ---------- */
.drawer-back{position:fixed;inset:0;background:rgba(17,24,39,.5);display:none;z-index:60;
  align-items:center;justify-content:center;padding:16px;}
.drawer-back.show{display:flex;}
.drawer{position:relative;width:420px;max-width:94vw;max-height:90vh;overflow-y:auto;background:var(--card);
  border-radius:18px;box-shadow:0 24px 60px rgba(16,24,40,.22);z-index:61;padding:28px 26px;
  opacity:0;transform:translateY(12px) scale(.98);transition:opacity .2s ease, transform .2s ease;}
.drawer-back.show .drawer{opacity:1;transform:none;}
.drawer h3{margin:0 0 22px;font-size:18px;font-weight:800;}
.drawer label{display:block;font-weight:700;margin:16px 0 7px;font-size:13px;color:var(--ink2);}
.drawer label .req{color:var(--red);}
.drawer input,.drawer select,.drawer textarea{width:100%;border:1px solid var(--line2);border-radius:10px;padding:11px 12px;font-size:14px;font-family:inherit;background:var(--card2);color:var(--ink);}
.drawer textarea{min-height:80px;resize:vertical;}
.drawer input:disabled,.drawer select:disabled{background:rgba(255,255,255,.06);color:var(--muted);}
.drawer .hint{font-size:12px;color:var(--indigo);margin-top:6px;}
.drawer .hint.warn b{color:var(--red);}
.drawer-actions{display:flex;gap:10px;margin-top:26px;}
.drawer-actions .btn{flex:1;height:44px;}

/* ---------- column filter dropdown ---------- */
.filter-pop{position:absolute;z-index:40;background:var(--card);border:1px solid var(--line2);border-radius:12px;
  box-shadow:var(--shadow-pop);width:300px;padding:14px;display:none;}
.filter-pop.show{display:block;}
.filter-pop .fsearch{display:flex;margin-bottom:10px;}
.filter-pop .fsearch input{flex:1;height:40px;border:1px solid var(--line2);border-right:none;border-radius:10px 0 0 10px;padding:0 12px;}
.filter-pop .fsearch button{width:44px;border:none;background:var(--indigo);color:#fff;border-radius:0 10px 10px 0;cursor:pointer;}
.filter-pop .frow{display:flex;align-items:center;gap:10px;padding:9px 4px;font-weight:600;}
.filter-pop .frow.head{justify-content:space-between;border-bottom:1px solid var(--line);}
.filter-pop .flist{max-height:180px;overflow-y:auto;}
.filter-pop .factions{display:flex;gap:8px;margin-top:12px;}
.filter-pop .factions .btn{flex:1;height:38px;}
th .fbtn{background:none;border:none;cursor:pointer;color:#b7bdc8;padding:0 0 0 6px;vertical-align:middle;}
th .fbtn.active{color:var(--indigo);}
.fbtn{background:none;border:none;cursor:pointer;color:#aab2c0;padding:2px;border-radius:7px;}
.fbtn:hover{color:var(--indigo);background:rgba(255,255,255,.06);}
.sorthead{display:inline-flex;align-items:center;gap:3px;color:inherit;cursor:pointer;}
.sorthead:hover{color:var(--indigo);}
.sorthead.active{color:var(--indigo);}
.sort-arrows{display:inline-flex;color:#b7bdc8;}
.sorthead.active .sort-arrows{color:var(--indigo);}

/* ---------- toast ---------- */
.toast-wrap{position:fixed;top:24px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--card);border:1px solid var(--line2);border-left:4px solid var(--red);border-radius:10px;
  padding:14px 22px;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:10px;font-weight:700;color:var(--ink2);animation:toastin .2s ease;}
.toast .x{color:var(--ink3);font-size:18px;}
.toast.ok{border-left-color:#3aa776;box-shadow:var(--shadow-pop), 0 0 16px -4px rgba(58,167,118,.55);}
.toast.ok .x{color:#3aa776;}
.toast.err{border-left-color:#e5644e;box-shadow:var(--shadow-pop), 0 0 16px -4px rgba(229,100,78,.55);}
.toast.err .x{color:#e5644e;}
@keyframes toastin{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}

/* ---------- 순위보고서 modal — huly Tracker 2패인 상세 (Tracker.dc.html 이식) ---------- */
@keyframes ovin{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.rep-modal{width:760px;max-width:92vw;max-height:86vh;overflow-y:auto;background:#161719;
  border:1px solid #28292d;border-radius:16px;box-shadow:var(--shadow-pop);animation:ovin .16s ease;}
.rep-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #232428;}
.rep-crumb{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink3);}
.rep-crumb svg{color:var(--beacon);}
.rep-crumb .sl{color:#4a4c52;}
.rep-x{width:30px;height:30px;border:none;background:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#8a8d93;cursor:pointer;}
.rep-x:hover{background:#232428;color:var(--ink);}
.rep-body{display:flex;}
.rep-main{flex:1;min-width:0;padding:22px 24px;}
.rep-side{width:248px;flex-shrink:0;padding:22px;border-left:1px solid #232428;display:flex;flex-direction:column;gap:20px;}
.rep-thumbwrap{width:170px;height:170px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.04);display:grid;place-items:center;color:var(--beacon);margin-bottom:16px;}
.rep-thumbwrap img{width:100%;height:100%;object-fit:contain;}
.rep-title{font-size:21px;font-weight:600;line-height:1.3;letter-spacing:-.3px;color:var(--ink);margin-bottom:13px;}
.rep-tagrow{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:2px;}
.rep-sec{font-size:12px;font-weight:700;letter-spacing:.4px;color:#6c6f76;margin:22px 0 10px;}
.rep-info{display:flex;flex-direction:column;gap:11px;font-size:13.5px;}
.ri-row{display:flex;gap:14px;}
.ri-k{width:86px;flex-shrink:0;color:var(--muted);}
.ri-v{color:var(--ink2);word-break:break-all;}
.rs-lab{font-size:11.5px;color:#6c6f76;margin-bottom:8px;}
.rs-big{font-family:var(--mono);font-size:25px;font-weight:700;color:var(--beacon);line-height:1;}
.rs-val{font-size:13.5px;color:var(--ink2);}
.rs-val.mono{font-family:var(--mono);}
/* 종료 예정(당일=종료일) 강조 */
.end-today{display:inline-block;padding:3px 11px;color:#e5644e;background:rgba(229,100,78,.16);border:none;border-radius:999px;font-weight:700;font-size:12.5px;white-space:nowrap;box-shadow:0 0 12px -4px #e5644e, inset 0 0 0 1px rgba(229,100,78,.45);}
tr.row-end>td{background:rgba(229,100,78,.07);}
tr.row-end:hover>td{background:rgba(229,100,78,.12);}
tr.row-end>td:first-child{box-shadow:inset 3px 0 0 #e5644e;}
.report-empty{text-align:center;color:var(--muted);padding:30px 0;}
.report-empty .circle{width:34px;height:34px;border:2px solid var(--line2);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;}

/* ---------- notice edit/detail ---------- */
.form-row{display:grid;grid-template-columns:130px 1fr;align-items:start;border-bottom:1px solid var(--line);}
.form-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:6px 24px;box-shadow:var(--shadow);}
.form-row > .flabel{color:var(--indigo);font-weight:700;padding:26px 0;}
.form-row > .ffield{padding:18px 0;}
.form-row .opts{display:flex;gap:24px;align-items:center;}
.form-row .opts label{display:flex;gap:8px;align-items:center;font-weight:600;}
.form-row .daterange{display:flex;align-items:center;gap:12px;}
.form-row input[type=text],.form-row textarea{width:100%;border:1px solid var(--line2);border-radius:10px;padding:12px;font-family:inherit;font-size:14px;background:var(--card2);color:var(--ink);}
.form-row input[type=date]{border:1px solid var(--line2);border-radius:10px;padding:11px 14px;flex:1;}
.form-row textarea{min-height:260px;resize:vertical;}
.page-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;}
.detail-card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);}
.detail-head{display:flex;justify-content:space-between;align-items:center;padding:22px 26px;border-bottom:1px solid var(--line);}
.detail-head h2{margin:0;font-size:17px;} .detail-head .date{color:var(--muted);}
.detail-body{padding:26px;line-height:1.7;color:var(--ink2);white-space:pre-wrap;min-height:200px;}

/* ---------- login (PRISM · 라이트 럭스 + 프리즘 히어로) ---------- */
.login-wrap{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;}
/* 에어리 그라데이션 메시 배경 */
.lg-mesh{position:fixed;inset:0;z-index:0;overflow:hidden;
  background:
    radial-gradient(40% 60% at 50% 0%, rgba(120,170,255,.18), transparent 60%),
    radial-gradient(55% 45% at 50% 8%, rgba(240,136,62,.14), transparent 62%),
    radial-gradient(50% 50% at 84% 96%, rgba(77,141,240,.14), transparent 72%),
    linear-gradient(180deg,#0a0b0d 0%,#070809 60%,#0a0b0d 100%);}
.lg-mesh::before,.lg-mesh::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;will-change:transform;}
.lg-mesh::before{width:46vw;height:46vw;left:-8vw;top:-10vw;
  background:radial-gradient(circle at 40% 40%, rgba(240,136,62,.35), rgba(240,136,62,0) 68%);animation:lgDrift1 26s ease-in-out infinite alternate;}
.lg-mesh::after{width:42vw;height:42vw;right:-8vw;bottom:-10vw;
  background:radial-gradient(circle at 60% 40%, rgba(46,124,184,.5), rgba(46,124,184,0) 68%);animation:lgDrift2 30s ease-in-out infinite alternate;}
@keyframes lgDrift1{from{transform:translate3d(0,0,0) scale(1);}to{transform:translate3d(5vw,4vh,0) scale(1.12);}}
@keyframes lgDrift2{from{transform:translate3d(0,0,0) scale(1.05);}to{transform:translate3d(-5vw,-3vh,0) scale(1);}}
.lg-grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.lg-stage{position:relative;z-index:2;width:100%;max-width:500px;margin-right:auto;margin-left:8vw;padding:48px 24px 44px;
  display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  animation:lgRise .6s cubic-bezier(.2,.7,.2,1) both;}
@keyframes lgRise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}

/* 브랜드 락업: 크리스탈 마크 + PRISM 워드마크 */
.lg-brand{display:flex;align-items:center;justify-content:flex-start;gap:14px;margin:2px 0 2px;}
.lg-markwrap{position:relative;display:inline-block;line-height:0;}
.lg-mark{height:54px;width:auto;display:block;filter:brightness(0) invert(1);}
/* 보석 위 반짝임(트윙클) — 또렷하게 */
.lg-spark{position:absolute;pointer-events:none;opacity:0;z-index:4;
  background:radial-gradient(circle, #ffffff 0%, rgba(230,252,246,.9) 26%, rgba(120,230,200,.35) 48%, rgba(255,255,255,0) 66%);
  clip-path:polygon(50% 0,59% 41%,100% 50%,59% 59%,50% 100%,41% 59%,0 50%,41% 41%);
  filter:drop-shadow(0 0 6px rgba(150,240,210,.95)) drop-shadow(0 0 12px rgba(120,230,200,.6));
  animation:lgTwinkle 2.2s ease-in-out infinite;}
.lg-spark.s1{top:4%;left:58%;width:24px;height:24px;animation-delay:0s;}
.lg-spark.s2{top:40%;left:12%;width:17px;height:17px;animation-delay:.55s;}
.lg-spark.s3{top:62%;left:68%;width:20px;height:20px;animation-delay:1.1s;}
.lg-spark.s4{top:24%;left:40%;width:14px;height:14px;animation-delay:1.6s;}
@keyframes lgTwinkle{
  0%,100%{opacity:0;transform:scale(.25) rotate(0deg);}
  40%,60%{opacity:1;transform:scale(1.05) rotate(90deg);}
}
@media (prefers-reduced-motion:reduce){.lg-spark{animation:none;opacity:0;}}
.lg-word{font-family:"Sora","Pretendard",sans-serif;font-weight:800;font-size:60px;line-height:1;
  letter-spacing:.01em;padding-left:1px;color:#fff;}
/* 좌측 히어로 카피 (huly 스타일 헤딩+서브) */
.lg-tagline{font-size:23px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.32;margin:20px 0 11px;max-width:470px;}
.lg-sub{font-size:14.5px;line-height:1.62;color:var(--ink3);margin:0;max-width:470px;}

/* 글래스 카드 */
.lg-card{margin-top:24px;width:100%;max-width:404px;text-align:left;border-radius:22px;padding:30px 28px 28px;
  background:linear-gradient(180deg, rgba(28,30,33,.78), rgba(14,15,17,.78));backdrop-filter:blur(26px) saturate(150%);-webkit-backdrop-filter:blur(26px) saturate(150%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 30px 70px -24px rgba(0,0,0,.85);}
.lg-field{margin-bottom:14px;}
.lg-field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin-bottom:7px;letter-spacing:-.01em;}
.lg-input-wrap{position:relative;}
.lg-ic{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted);pointer-events:none;}
.lg-card input[type=text],.lg-card input[type=password]{width:100%;height:50px;padding:0 16px 0 42px;font-family:inherit;font-size:14.5px;
  color:var(--ink);background:rgba(255,255,255,.04);border:1px solid var(--line2);border-radius:13px;outline:none;
  transition:border-color .18s ease,box-shadow .18s ease,background .18s ease;}
.lg-card input::placeholder{color:var(--muted);}
.lg-card input:hover{border-color:rgba(255,255,255,.22);}
.lg-card input:focus{border-color:var(--indigo);background:rgba(255,255,255,.06);box-shadow:0 0 0 4px rgba(77,141,240,.18);}
.login-error{background:var(--red-bg);border:1px solid #f5c6c0;color:var(--red);border-radius:10px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:14px;}

/* 아이디 기억하기 */
.lg-check{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:13.5px;color:var(--ink2);user-select:none;margin:4px 2px 22px;}
.lg-check input{position:absolute;opacity:0;width:0;height:0;}
.lg-check .lg-box{width:19px;height:19px;border-radius:6px;border:1.5px solid var(--line2);background:rgba(255,255,255,.04);display:grid;place-items:center;transition:all .16s ease;}
.lg-check .lg-box svg{width:12px;height:12px;color:#fff;opacity:0;transform:scale(.6);transition:all .16s ease;}
.lg-check input:checked + .lg-box{background:linear-gradient(135deg,#4d8df0,#5b9bf3);border-color:transparent;}
.lg-check input:checked + .lg-box svg{opacity:1;transform:scale(1);}
.lg-check input:focus-visible + .lg-box{box-shadow:0 0 0 4px rgba(47,166,180,.18);}

/* 로그인 버튼 */
/* Huly식 라이트 알약 버튼 + 코랄 글로우 헤일로 */
.lg-btn{width:100%;height:52px;border:none;border-radius:999px;font-family:inherit;font-size:15px;font-weight:700;letter-spacing:.01em;
  color:#16171a;cursor:pointer;background:linear-gradient(180deg,#fcfcfd 0%,#d9dade 100%);position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7), 0 0 0 1px rgba(240,136,62,.30), 0 0 22px 2px rgba(240,136,62,.50), 0 0 55px 8px rgba(240,136,62,.28);
  transition:transform .14s ease,box-shadow .2s ease,filter .2s ease;}
.lg-btn:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 0 0 1px rgba(240,136,62,.42), 0 0 30px 4px rgba(240,136,62,.7), 0 0 72px 12px rgba(240,136,62,.4);}
.lg-btn:active{transform:translateY(0);}

@media (max-width:480px){
  .lg-stage{padding:36px 20px 32px;max-width:400px;}
  .lg-hero{width:210px;height:210px;}
  .lg-hero img{width:176px;height:176px;}
  .lg-rays{width:280px;height:280px;}
  .lg-rays.tint{width:312px;height:312px;}
  .lg-heading{font-size:22px;}
  .lg-word{font-size:44px;}
  .lg-mark{height:40px;}
  .lg-card{padding:26px 22px 24px;}
}
@media (prefers-reduced-motion:reduce){
  .lg-mesh::before,.lg-mesh::after,.lg-glow,.lg-rays,.lg-stage{animation:none!important;}
}

/* ---------- floating download ---------- */
.fab{position:fixed;right:30px;bottom:30px;width:52px;height:52px;border-radius:50%;
  background:var(--indigo);border:none;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(77,141,240,.4);cursor:pointer;color:#fff;z-index:30;}
.fab:hover{background:#15707f;}
.fab svg{transition:transform .25s ease;}
.fab.up svg{transform:rotate(180deg);}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hamburger{display:flex;}
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow-pop);}
  body.nav-open .sidebar{transform:translateX(0);}
  body.nav-open .sidebar-backdrop{display:block;}
  .main{margin-left:0;}
  .content{padding:64px 16px 80px;}
  .search-wrap input{width:100%;max-width:none;}
  .list-head{flex-direction:column;align-items:flex-start;}
  .drawer{width:100%;max-width:100%;}
  .pager-right{flex-wrap:wrap;}
  .fab{right:16px;bottom:16px;}
}

/* ============ 모바일 최적화 (≤600px) ============ */
@media (max-width:600px){
  .content{padding:60px 12px 72px;}
  h1{font-size:23px;}

  /* 데이터 테이블: 셀 축소 + 부드러운 가로 스크롤 + 식별칼럼 고정 */
  .table-wrap{-webkit-overflow-scrolling:touch;}
  table.grid thead th,table.grid tbody td{padding:10px 8px;font-size:12px;}
  table.grid.dense thead th,table.grid.dense tbody td{padding:9px 7px;font-size:11.5px;}
  table.grid td.prod-name,table.grid th.prod-name{min-width:148px;max-width:180px;}
  table.grid.wide{min-width:0;}                         /* 모바일선 강제 1280 해제 → 자연폭 스크롤 */
  table.grid thead th:first-child,table.grid tbody td:first-child{
    position:sticky;left:0;background:var(--card);z-index:1;box-shadow:1px 0 0 var(--line2);}
  table.grid thead th:first-child{background:rgba(255,255,255,.04);}

  /* 드로어·모달 → 하단 시트(bottom sheet) */
  .drawer-back,.modal-back{align-items:flex-end;padding:0;}
  .drawer,.modal{width:100%;max-width:100%;max-height:90vh;border-radius:18px 18px 0 0;padding:22px 18px 26px;}
  .drawer{transform:translateY(100%);}
  .drawer-back.show .drawer{transform:none;}
  .modal{transform:translateY(100%);transition:transform .22s ease;}
  .modal-back.show .modal{transform:none;}

  /* 터치 타깃 */
  .btn{min-height:42px;}
  select.select,.search-wrap input{height:44px;}

  /* 운영·리스트 헤더 행 줄바꿈 */
  .rank-status{flex-wrap:wrap;gap:10px;}
  .rs-btn{width:100%;}
  .list-head .actions{flex-wrap:wrap;}

  /* 운영(/ops) 설정표: 라벨칸 inline width:200px 강제 해제 → 값 공간 확보 */
  table.grid td.left{width:auto !important;}
}

/* ========================================================================
   BEACON · Huly 시그니처 (huly.io 디자인 언어 — 라이트빔·글로우·모노·깊이)
   ======================================================================== */
/* 사이드바: 로고 뒤 회전 라이트빔 + 깊이 */
.sidebar{background:linear-gradient(180deg,#0c0d0f 0%,#090a0c 100%);overflow:hidden;}
.sidebar::before{content:"";position:absolute;top:-60px;left:50%;width:280px;height:280px;transform:translateX(-50%);
  background:conic-gradient(from 0deg, transparent 0deg, rgba(240,136,62,.20) 16deg, transparent 40deg);
  animation:bcnBeam 8s linear infinite;pointer-events:none;z-index:0;}
@keyframes bcnBeam{to{transform:translateX(-50%) rotate(360deg);}}
.sidebar .brand,.sidebar nav,.sidebar .user-wrap{position:relative;z-index:1;}
.sidebar .brand .brand-mark{filter:drop-shadow(0 4px 14px rgba(240,136,62,.45));}
.sidebar .brand .brand-word{background:linear-gradient(135deg,#f0883e 0%,#e8843a 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.sidebar nav a.active{background:rgba(240,136,62,.13);color:var(--beacon);
  box-shadow:inset 0 0 0 1px rgba(240,136,62,.28), 0 0 26px -6px rgba(240,136,62,.5);}
.sidebar nav a.active svg{color:var(--beacon);}
.user .uava{background:linear-gradient(135deg,#f0883e,#e8843a);color:#0c0d0f;box-shadow:0 4px 14px -4px rgba(240,136,62,.6);}

/* 메인 배경 글로우(쿨+웜 라디얼) — huly 톤 */
body{background:
  radial-gradient(60% 40% at 82% -4%, rgba(77,141,240,.10), transparent 60%),
  radial-gradient(50% 36% at 4% 0%, rgba(240,136,62,.07), transparent 55%),
  var(--bg);
  background-attachment:fixed;}

/* 카드: 표면 그라데이션 + 상단 인셋 하이라이트 + 호버 리프트 */
.an-kpi,.an-panel,.table-wrap,.form-card,.detail-card,.faq-list{
  background:linear-gradient(180deg, var(--card) 0%, var(--bg2) 100%);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.05);}
.an-kpi{transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;}
.an-kpi.clk:hover{transform:translateY(-3px);border-color:var(--line2);
  box-shadow:0 22px 44px -20px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.06);}
.an-kpi.sel{border-color:rgba(77,141,240,.55);box-shadow:0 0 0 1px rgba(77,141,240,.4), 0 18px 40px -20px rgba(77,141,240,.4);}

/* 숫자·데이터 = huly 모노 */
.an-kpi .v{font-family:var(--mono);letter-spacing:-.02em;}
.an-kpi.i .v{text-shadow:0 0 22px rgba(77,141,240,.45);}
.rankb,.tag{font-family:var(--mono);}
table.grid td{font-variant-numeric:tabular-nums;}

/* 상태칩 글로우 */
.status .dot{box-shadow:0 0 8px currentColor;}

/* 막대차트 글로우 */
.an-bars .bar{box-shadow:0 0 20px -4px rgba(77,141,240,.55);}
.an-bars .bar:last-child,.an-bars .col:last-child .bar{}

/* primary 버튼(블루) 발광 + 호버 */
.btn-primary{box-shadow:0 8px 22px -8px rgba(77,141,240,.6), inset 0 1px 0 rgba(255,255,255,.18);}
.btn-primary:hover{box-shadow:0 12px 28px -8px rgba(77,141,240,.7), inset 0 1px 0 rgba(255,255,255,.24);}
.btn-ghost:hover{border-color:var(--line2);}

/* 링크 호버 발광 */
.link:hover{text-shadow:0 0 14px rgba(77,141,240,.5);}

/* ========================================================================
   BEACON · Huly 앱 셸 (아이콘 레일 + 내비 패널 + 메인 토프바) — huly.io 앱 구조 재현
   ======================================================================== */
:root{ --rail-w:60px; --np-w:236px; }
/* 아이콘 레일 */
.rail{position:fixed;top:0;left:0;bottom:0;width:var(--rail-w);z-index:31;overflow:hidden;
  background:linear-gradient(180deg,#0b0c0e,#090a0c);border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:18px;}
.rail::before{content:"";position:absolute;top:-50px;left:50%;width:200px;height:200px;transform:translateX(-50%);
  background:conic-gradient(from 0deg,transparent 0deg,rgba(240,136,62,.22) 16deg,transparent 40deg);
  animation:bcnBeam 8s linear infinite;pointer-events:none;z-index:0;}
.rail-mark{z-index:1;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,#16191d,#0e0f11);border:1px solid rgba(240,136,62,.35);
  box-shadow:0 0 0 4px rgba(240,136,62,.05),0 8px 20px -8px rgba(240,136,62,.5);transition:.2s;}
.rail-mark img{width:24px;height:24px;filter:drop-shadow(0 0 8px rgba(240,136,62,.5));}
.rail-mark:hover{transform:translateY(-1px);}
.rail-nav{z-index:1;display:flex;flex-direction:column;gap:6px;}
.rail-ico{position:relative;width:42px;height:42px;border-radius:13px;display:grid;place-items:center;color:var(--muted);transition:.18s;}
.rail-ico svg{width:21px;height:21px;}
.rail-ico:hover{color:var(--ink);background:rgba(255,255,255,.06);}
.rail-ico.on{color:var(--beacon);background:rgba(240,136,62,.13);box-shadow:inset 0 0 0 1px rgba(240,136,62,.28),0 0 22px -6px rgba(240,136,62,.55);}
.rail-ico.on::before{content:"";position:absolute;left:-9px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:var(--beacon);box-shadow:0 0 10px var(--beacon);}
.rail-ava{margin-top:auto;z-index:1;width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;font-weight:800;font-size:13px;
  color:#0c0d0f;background:linear-gradient(135deg,#f0883e,#e8843a);box-shadow:0 4px 14px -4px rgba(240,136,62,.6);}

/* 내비 패널 (검색 포함) */
.navpanel{position:fixed;top:0;left:var(--rail-w);bottom:0;width:var(--np-w);z-index:30;
  background:#0c0d0f;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:14px 12px 12px;}
.ws{display:flex;align-items:center;gap:10px;padding:6px 8px 14px;}
.ws-mark{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:14px;color:#0c0d0f;background:linear-gradient(135deg,#f0883e,#e8843a);}
.ws-name{font-family:"Sora",sans-serif;font-weight:800;font-size:15px;color:var(--ink);letter-spacing:.01em;}
.ws-role{margin-left:auto;font-size:10.5px;font-weight:700;color:var(--ink3);background:rgba(255,255,255,.06);padding:2px 7px;border-radius:6px;}
.np-search{display:flex;align-items:center;gap:8px;height:36px;padding:0 10px;margin:2px 0 14px;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--muted);}
.np-search input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--ink);font-family:inherit;font-size:13px;}
.np-search input::placeholder{color:var(--muted);}
.np-search kbd{font-family:var(--mono);font-size:10px;color:var(--ink3);background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:5px;padding:2px 5px;}
.np-sec{font-size:11px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px 8px;}
.np-nav{display:flex;flex-direction:column;gap:2px;}
.np-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;color:var(--ink2);font-weight:600;font-size:13.5px;transition:.15s;}
.np-item svg{width:18px;height:18px;flex:none;color:var(--ink3);}
.np-item:hover{background:rgba(255,255,255,.06);color:var(--ink);}
.np-item:hover svg{color:var(--ink2);}
.np-item.on{background:var(--tint);color:var(--indigo);box-shadow:inset 2px 0 0 var(--indigo);}
.np-item.on svg{color:var(--indigo);}
button.np-item{width:100%;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;}
.np-item.danger{color:var(--red);}
.np-item.danger svg{color:var(--red);}
.np-item.danger:hover{background:var(--red-bg);color:var(--red);}
.np-item.danger:hover svg{color:var(--red);}
/* 광고관리 컨텍스트: 검색·필터 폼 */
.np-searchform{display:flex;flex-direction:column;gap:8px;margin-bottom:4px;}
.np-searchform .np-search{margin:0;}
.np-cat{height:34px;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink2);font-family:inherit;font-size:13px;padding:0 10px;cursor:pointer;}
.np-cat option{background:#161719;color:var(--ink);}
/* 검색창 내부 우측 미니 필터 */
.np-search input{flex:1;min-width:0;}
.np-cat-mini{flex:none;width:auto;max-width:88px;height:24px;border:none;border-radius:6px;
  background:rgba(255,255,255,.07);color:var(--ink3);font-family:inherit;font-size:11px;padding:0 4px;cursor:pointer;}
.np-cat-mini:hover{color:var(--ink2);}
.np-cat-mini option{background:#161719;color:var(--ink);}

/* 메인 + 토프바 */
.main{margin-left:calc(var(--rail-w) + var(--np-w));}
/* 홈: 내비 패널 없음 → 본문은 레일 폭만 */
.home-nonav .main{margin-left:var(--rail-w);}
/* 홈 → 다른 페이지 진입 시 내비 패널 좌→우 슬라이드 인 */
@keyframes npSlideIn{from{transform:translateX(-100%);opacity:0;}to{transform:translateX(0);opacity:1;}}
.from-home .navpanel{animation:npSlideIn .4s cubic-bezier(.2,.7,.2,1) both;}
.topbar{position:sticky;top:0;z-index:20;height:56px;display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;border-bottom:1px solid var(--line);
  background:rgba(9,10,12,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);}
.crumb{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink3);}
.crumb a{color:var(--ink3);font-weight:600;}.crumb a:hover{color:var(--ink2);}
.crumb .sep{color:var(--muted);}
.crumb b{display:flex;align-items:center;gap:8px;color:var(--ink);font-weight:700;}
.crumb b svg{width:16px;height:16px;color:var(--beacon);}
.content{padding:24px 32px 90px;}
.page-title{display:none;}

@media (max-width:980px){
  .rail{transform:translateX(-100%);transition:transform .22s ease;}
  .navpanel{transform:translateX(-100%);transition:transform .22s ease;left:0;box-shadow:var(--shadow-pop);}
  body.nav-open .rail{transform:translateX(0);}
  body.nav-open .navpanel{transform:translateX(0);left:var(--rail-w);}
  body.nav-open .sidebar-backdrop{display:block;}
  .main{margin-left:0;}
  .topbar{padding:0 16px 0 60px;}
  .content{padding:18px 16px 80px;}
}

/* ===== huly 리스트(업체 아바타 행) + 효과 ===== */
.biz{display:flex;align-items:center;gap:11px;min-width:0;}
.biz-av{width:34px;height:34px;border-radius:9px;overflow:hidden;flex:none;display:grid;place-items:center;
  background:linear-gradient(135deg,#1b1d20,#141518);border:1px solid var(--line2);color:var(--muted);}
.biz-av img{width:100%;height:100%;object-fit:cover;}
.biz-av.ph{color:var(--beacon);}
.biz-nm{font-weight:700;}
/* huly 테이블 톤 */
table.grid thead th{color:var(--ink3);font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;font-weight:600;background:transparent;}
table.grid tbody tr{transition:background .14s ease;}
table.grid tbody tr:hover{background:rgba(77,141,240,.06);}
/* 순위 = 코랄 모노 */
button.link[onclick^="openReport"]{font-family:var(--mono);font-weight:700;color:var(--beacon);}
button.link[onclick^="openReport"]:hover{text-shadow:0 0 12px rgba(240,136,62,.5);}
/* 상태 dot 펄스 */
.status .dot{animation:dotPulse 2.6s ease-in-out infinite;}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 currentColor;}50%{box-shadow:0 0 7px 0 currentColor;}}
/* primary 버튼 샤인 스윕 */
.btn-primary{position:relative;overflow:hidden;}
.btn-primary::after{content:"";position:absolute;top:0;left:-70%;width:45%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);}
.btn-primary:hover::after{animation:shine .75s ease;}
@keyframes shine{from{left:-70%;}to{left:140%;}}
/* 카드·테이블 진입 페이드 */
.an-kpi,.an-panel,.table-wrap{animation:rise .42s cubic-bezier(.2,.7,.2,1) both;}
@keyframes rise{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
/* 검색 버튼 호버 글로우 */
.search-wrap button:hover{box-shadow:0 0 18px -2px rgba(77,141,240,.6);}

/* 간소 상태 스트립 (huly Tracker 컬럼헤더 톤) — 광고관리 상단 통계 */
.stat-strip{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:20px;}
.stat-item{display:flex;align-items:center;gap:9px;padding:9px 14px;border-radius:10px;cursor:pointer;transition:background .15s ease;}
.stat-item:hover{background:rgba(255,255,255,.05);}
.stat-item.sel{background:rgba(255,255,255,.08);}
.stat-item .sdot{width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor;flex:none;}
.stat-item .sname{font-size:13px;font-weight:700;letter-spacing:.3px;color:var(--ink);}
.stat-item .scount{font-family:var(--mono);font-size:13px;color:var(--muted);}

/* 태그 칩 (순위보고서 모달 — 키워드/업종) */
.ktag{font-size:11.5px;font-weight:600;padding:2.5px 9px;border-radius:20px;}
.ktag.kw{background:#c3d8f5;color:#22466b;}
.ktag.cat{background:#efb097;color:#6e2f17;}

/* ========================================================================
   그레이스케일 모드 — 셸·버튼·링크·배경은 무채색.
   포인트색(레퍼 팔레트)은 수치·지표에만: 순위(.krank)·통계 카운트(.scount/.sdot)·
   상태칩(.status)·차트/스파크라인/도넛·순위 델타
   ======================================================================== */
/* 배경 글로우 탈색 */
body{background:
  radial-gradient(60% 40% at 82% -4%, rgba(255,255,255,.035), transparent 60%),
  radial-gradient(50% 36% at 4% 0%, rgba(255,255,255,.025), transparent 55%),
  var(--bg);background-attachment:fixed;}
/* 아이콘 레일: 오렌지 빔·글로우 제거 */
.rail::before{display:none;}
.rail-mark{background:#16191d;border-color:rgba(255,255,255,.55);box-shadow:0 0 0 1px rgba(255,255,255,.22),0 0 14px rgba(255,255,255,.45),0 0 30px rgba(255,255,255,.20);}
.rail-mark:hover{box-shadow:0 0 0 1px rgba(255,255,255,.4),0 0 20px rgba(255,255,255,.65),0 0 42px rgba(255,255,255,.32);}
.rail-mark img{filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,.9)) drop-shadow(0 0 18px rgba(255,255,255,.45));}
.rail-ico.on{color:#fff;background:rgba(255,255,255,.10);box-shadow:none;}
.rail-ico.on::before{background:#fff;box-shadow:none;}
.rail-ava{background:#2a2c30;color:var(--ink);box-shadow:none;}
.crumb b svg{color:var(--ink2);}
/* 버튼 무채색 (primary=라이트, ghost/danger=윤곽) */
.btn-primary{background:#e9eaec;color:#16171a;box-shadow:none;}
.btn-primary:hover{background:#fff;box-shadow:none;filter:none;}
.btn-danger{background:transparent;color:var(--ink2);border:1px solid var(--line2);box-shadow:none;}
.btn-danger:hover{background:rgba(255,255,255,.06);color:var(--ink);filter:none;}
/* 페이저 활성 무채색 */
.pager .cur{background:#e9eaec;color:#16171a;border-color:transparent;}
/* 링크 무채색 */
.link{color:var(--ink2);}
.link:hover{color:var(--ink);text-decoration:underline;text-shadow:none;}
button.link[onclick^="openReport"]:hover{text-shadow:none;}
/* 테이블 행 호버 */
table.grid tbody tr:hover{background:rgba(255,255,255,.04);}
/* 검색 버튼·FAB 무채색 */
.search-wrap button{background:#26282c;}
.search-wrap button:hover{background:#303237;box-shadow:none;}
.fab{background:#26282c;box-shadow:0 10px 24px rgba(0,0,0,.5);}
.fab:hover{background:#303237;}
/* KPI 패널 글로우 무채색 (차트 데이터색은 유지) */
.an-kpi.sel{border-color:var(--line2);box-shadow:0 0 0 1px var(--line2);}
.an-kpi.i .v{text-shadow:none;}
/* 태그 칩(키워드/업종) 무채색 */
.ktag.kw,.ktag.cat{background:rgba(255,255,255,.08);color:var(--ink2);}
/* 통계 스트립: 라벨 무채색, 카운트는 점 색(포인트) 상속 */
.stat-item .sname{color:var(--ink2);font-weight:600;}
.stat-item .scount{color:currentColor;font-weight:800;}
/* 정렬 헤더 무채색 */
.sorthead:hover,.sorthead.active,.sorthead.active .sort-arrows{color:var(--ink);}

/* ===== 포인트색 네온사인 글로우 (ref/포인트.png) — 수치·지표만 발광 ===== */
.stat-item .scount{text-shadow:0 0 9px currentColor, 0 0 20px currentColor;}
.stat-item .sdot{box-shadow:0 0 8px currentColor, 0 0 15px currentColor;}
button.link[onclick^="openReport"]{text-shadow:0 0 9px rgba(240,136,62,.75), 0 0 20px rgba(240,136,62,.4);}
button.link[onclick^="openReport"]:hover{text-shadow:0 0 12px rgba(240,136,62,.95), 0 0 26px rgba(240,136,62,.55);}
.status{text-shadow:0 0 9px currentColor;}
.status .dot{box-shadow:0 0 8px currentColor, 0 0 14px currentColor;}
/* 레일 아이콘: 각 포인트색 + 활성 인디케이터/글로우 색 매칭 */
.rail-ico svg{filter:drop-shadow(0 0 5px currentColor);}
.rail-ico.on::before{background:currentColor;box-shadow:0 0 10px currentColor;}
.rail-ico.on svg{filter:drop-shadow(0 0 8px currentColor) drop-shadow(0 0 14px currentColor);}

/* ===== 흰색 네온 글로우 (브랜드·타이틀·라이트 버튼) ===== */
.lg-word{text-shadow:0 0 14px rgba(255,255,255,.55), 0 0 32px rgba(255,255,255,.22);}
.lg-mark{filter:brightness(0) invert(1) drop-shadow(0 0 9px rgba(255,255,255,.6));}
.crumb b{text-shadow:0 0 10px rgba(255,255,255,.4);}
.btn-primary{box-shadow:0 0 14px rgba(255,255,255,.35), 0 0 30px rgba(255,255,255,.15);}
.btn-primary:hover{box-shadow:0 0 18px rgba(255,255,255,.5), 0 0 38px rgba(255,255,255,.22);}
.pager .cur{box-shadow:0 0 12px rgba(255,255,255,.4);}

/* 상태 배지 내부 점 제거 (정상/오류/대기) */
.status .dot{display:none !important;}
/* 순위 = 상태처럼 알약 배지 */
.rankpill{display:inline-flex;align-items:center;justify-content:center;min-width:48px;padding:4px 11px;border-radius:999px;
  font-family:var(--mono);font-weight:700;font-size:12px;line-height:1;cursor:pointer;border:none;
  background:rgba(77,141,240,.14);color:#4d8df0;transition:background .15s ease,box-shadow .15s ease;
  text-shadow:0 0 8px rgba(77,141,240,.8);box-shadow:0 0 12px -4px rgba(77,141,240,.55), inset 0 0 0 1px rgba(77,141,240,.25);}
.rankpill:hover{background:rgba(77,141,240,.26);box-shadow:0 0 18px -2px rgba(77,141,240,.7), inset 0 0 0 1px rgba(77,141,240,.4);text-shadow:0 0 12px rgba(77,141,240,1);}
/* 상태 배지도 순위처럼 테두리+박스 네온 (상태색) */
.status{box-shadow:0 0 12px -4px currentColor, inset 0 0 0 1px currentColor;}

/* ===== 전역 네온: 컬러 들어간 부분 전부 발광 ===== */
/* 링크(스틸블루) */
.link{text-shadow:0 0 8px currentColor;}
/* 레일 아이콘(컬러별) */
.rail-ico svg{filter:drop-shadow(0 0 5px currentColor);}
.rail-ico.on svg{filter:drop-shadow(0 0 7px currentColor) drop-shadow(0 0 15px currentColor);}
/* 내비 패널 메뉴 아이콘(컬러 기하도형) */
.np-item svg{filter:drop-shadow(0 0 5px currentColor);}
.np-item.on{text-shadow:0 0 8px currentColor;}
/* 통계 스트립 점·선택 */
.stat-item .sdot{box-shadow:0 0 9px currentColor, 0 0 4px currentColor;}
.stat-item.sel{text-shadow:0 0 8px currentColor;}
.stat-item .scount{text-shadow:0 0 7px currentColor;}
/* 순위 변동 화살표 */
.rank-delta.up,.rank-delta.down{text-shadow:0 0 8px currentColor;}
/* 칸반 컬럼 점 / 카드 순위 */
.kdot{box-shadow:0 0 10px currentColor;}
.krank{text-shadow:0 0 8px currentColor;}
/* danger 버튼 발광 */
.btn-danger{box-shadow:0 0 16px -3px rgba(229,100,78,.65), inset 0 1px 0 rgba(255,255,255,.18);}
.btn-danger:hover{box-shadow:0 0 22px -2px rgba(229,100,78,.8), inset 0 1px 0 rgba(255,255,255,.24);}
/* 브랜드 워드마크 발광 (네온) */
.ws-name{color:#fff;text-shadow:0 0 6px rgba(255,255,255,.9), 0 0 14px rgba(255,255,255,.55), 0 0 26px rgba(255,255,255,.3);}
/* 종료예정 빨강 행 강조 */
.end-today{text-shadow:0 0 8px currentColor;}
/* 계정관리: 권한·생성주체 배지 네온 (상태색) */
.role{text-shadow:0 0 8px currentColor;box-shadow:0 0 12px -4px currentColor, inset 0 0 0 1px currentColor;}
.owner-tag{box-shadow:none;text-shadow:none;}
/* 계정관리: 광고 추가(+) 버튼 초록 네온 */
.add-neon svg{stroke:#3aa776;filter:drop-shadow(0 0 5px rgba(58,167,118,.9)) drop-shadow(0 0 11px rgba(58,167,118,.5));transition:filter .15s ease;}
.add-neon:hover svg{filter:drop-shadow(0 0 7px #3aa776) drop-shadow(0 0 16px rgba(58,167,118,.7));}
/* 정산로그 패널: 기간 필터 */
.np-period{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;}
.np-date{height:34px;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:12.5px;padding:0 10px;color-scheme:dark;}
.np-period-go{height:34px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:13px;background:var(--tint);color:var(--indigo);}
.np-period-go:hover{filter:brightness(1.12);}
.np-quick{display:flex;flex-wrap:wrap;gap:6px;}
.np-chip{font-size:12px;font-weight:600;padding:5px 10px;border-radius:8px;background:rgba(255,255,255,.05);color:var(--ink2);border:1px solid var(--line);}
.np-chip:hover{background:rgba(255,255,255,.09);color:var(--ink);}
.np-chip.on{background:var(--tint);color:var(--indigo);border-color:transparent;}
.np-quick + .np-sec{margin-top:16px;}
/* 순위모니터링 급하락 '경고' 상태 = 빨강 알약 */
.status.경고{background:rgba(229,100,78,.14);color:#e5644e;}
.status.경고 .dot{background:#e5644e;}
/* 설정 패널: 이용시간 */
.np-usage{display:flex;flex-direction:column;gap:12px;}
.np-u-row{display:flex;flex-direction:column;gap:6px;}
.np-u-row > label{font-size:12px;font-weight:600;color:var(--ink2);}
.np-u-times{display:flex;align-items:center;gap:6px;}
.np-u-times span{color:var(--muted);}
.np-time{flex:1;min-width:0;height:32px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.04);color:var(--ink);font-family:inherit;font-size:12px;padding:0 6px;color-scheme:dark;}
.np-usage .np-period-go{margin-top:4px;width:100%;}
/* 관리 톱니바퀴 흰색 네온 */
.gear-neon svg{stroke:#fff;filter:drop-shadow(0 0 4px rgba(255,255,255,.85)) drop-shadow(0 0 10px rgba(255,255,255,.5));transition:filter .15s ease;}
.gear-neon:hover svg{filter:drop-shadow(0 0 6px #fff) drop-shadow(0 0 16px rgba(255,255,255,.75));}
