/* ============================================================
   style.css — My Contract 전체 스타일  (개선판 v25-r1)
   ============================================================ */

/* ── RESET & ROOT ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { max-width: 100%; }

:root {
  --bg: #111315; --s: #181A1B; --s2: #1F2123; --s3: #272A2C; --s4: #2E3133;
  --bd: rgba(255,255,255,.09); --bd2: rgba(255,255,255,.15);
  --ink: #FFFFFF; --ink2: #D8D8D8; --ink3: #9A9A9A; --ink4: #606060;
  --red: #FF5A5A;    --red-bg: rgba(255,90,90,.1);     --red-bd: rgba(255,90,90,.25);
  --orange: #FF9A3C; --orange-bg: rgba(255,154,60,.1);  --orange-bd: rgba(255,154,60,.25);
  --green: #4CD97B;  --green-bg: rgba(76,217,123,.1);   --green-bd: rgba(76,217,123,.25);
  --blue: #4B8BF5;   --blue-bg: rgba(75,139,245,.1);    --blue-bd: rgba(75,139,245,.25);
  --gold: #F5C518;   --gold-bg: rgba(245,197,24,.1);    --gold-bd: rgba(245,197,24,.28);
  --r: 16px; --rm: 10px; --rs: 6px; --rl: 16px;
  --sh-sm: 0 2px 8px rgba(0,0,0,.4);
  --sh:    0 4px 24px rgba(0,0,0,.55);
  --sh-lg: 0 20px 70px rgba(0,0,0,.8);
  --bnav-h: 64px;
  /* ▼ Safe Area 변수 — env() 미지원 fallback(0px) 포함 */
  --safe-top:    env(safe-area-inset-top,    0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left,   0px);
  --safe-right:  env(safe-area-inset-right,  0px);
}

/* iOS 고무줄 스크롤 시 배경 노출 방지 */
html { background: var(--bg); }

body {
  min-height: 100%;
  min-height: 100dvh;           /* 주소창 접힘 대응 */
  background: var(--bg);
  font-family: 'Noto Sans KR', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
  overscroll-behavior: none;    /* iOS 배경 노출 방지 */
}

/* 모달 열릴 때 JS가 부착하는 클래스 — overflow:hidden 엄격 적용 */
body.body-locked {
  overflow: hidden;
  /* position:fixed 없이 iOS에서도 하단 스크롤 막기 */
  touch-action: none;
  -webkit-overflow-scrolling: auto;
}

/* ── SHELL ── */
.shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
  max-width: 960px;
  margin: 0 auto;
  background: var(--s);
  border-left: 1px solid var(--bd);
  border-right: 1px solid var(--bd);
}

/* ── NAV ── */
.nav {
  position: sticky; top: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  height: 100px;
  padding: 0 calc(28px + var(--safe-right)) 0 calc(28px + var(--safe-left));
  background: rgba(24,26,27,.92);
  backdrop-filter: blur(20px) saturate(1.6);
  -webkit-backdrop-filter: blur(20px) saturate(1.6);
  border-bottom: 1px solid var(--bd);
}
.logo { display: flex; align-items: center; gap: 8px; text-decoration: none; color: var(--ink); }
.custom-logo { height: 26px; width: auto; display: block; object-fit: contain; }
.logo-ver  { font-size: 9px; font-weight: 700; background: var(--s3); color: var(--ink4); border: 1px solid var(--bd); border-radius: 4px; padding: 2px 6px; letter-spacing: .06em; text-transform: uppercase; margin-left: 2px; }
.nav-r { display: flex; gap: 6px; align-items: center; }

/* ── BUTTONS ── */
.cal-picker-btn {
  display: block; width: 100%; padding: 8px 4px;
  border-radius: var(--rm); border: 1.5px solid transparent;
  background: transparent; font-size: 13px; font-weight: 400;
  cursor: pointer; font-family: inherit; text-align: center;
  color: var(--ink3); transition: background .12s, color .12s;
  -webkit-tap-highlight-color: transparent;
}
.cal-picker-btn:hover { background: var(--s3); color: var(--ink); }
.cal-picker-btn.selected { background: rgba(55,138,221,.15); border-color: var(--blue); color: var(--blue); font-weight: 700; }
.cal-picker-btn.is-today { color: var(--blue); font-weight: 700; }

.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 0 16px; height: 40px;
  border-radius: var(--rm); border: 1px solid var(--bd2);
  background: rgba(255,255,255,.06); color: var(--ink2);
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background .14s, color .14s, border-color .14s, box-shadow .14s;
  white-space: nowrap; font-family: inherit;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.btn:hover  { background: rgba(255,255,255,.12); color: var(--ink); border-color: rgba(255,255,255,.25); }
.btn:active { opacity: .8; }
.btn.primary { background: var(--ink); color: #111315; border-color: transparent; font-weight: 800; height: 38px; padding: 0 18px; }
.btn.primary:hover { background: rgba(255,255,255,.88); box-shadow: 0 4px 18px rgba(0,0,0,.4); }
.btn.danger  { background: var(--red-bg); color: var(--red); border-color: var(--red-bd); }
.btn.danger:hover  { background: rgba(255,90,90,.18); }
.btn.upgrade { background: linear-gradient(135deg, var(--gold), #FF9A3C); color: #111315; border-color: transparent; font-weight: 800; }
.btn.upgrade:hover { opacity: .9; box-shadow: 0 4px 20px rgba(245,197,24,.3); }

/* ── AI 전용 실행 버튼 (파랑~보라 그라디언트) ── */
.btn.ai-magic {
  background: linear-gradient(135deg, var(--blue), #7C3AED);
  color: #fff; border: none; font-weight: 800;
  height: 38px; padding: 0 18px;
  transition: all .2s ease;
}
.btn.ai-magic:hover {
  opacity: .95;
  box-shadow: 0 4px 16px rgba(124,58,237,.4);
  transform: translateY(-1px);
}

.btn-icon {
  width: 36px; height: 36px; border-radius: var(--rm);
  border: 1px solid var(--bd2); background: rgba(255,255,255,.06);
  color: var(--ink3); display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .14s, color .14s, border-color .14s;
  font-size: 16px; font-family: inherit;
  -webkit-tap-highlight-color: transparent;
}
.btn-icon:hover { background: rgba(255,255,255,.12); color: var(--ink); border-color: rgba(255,255,255,.25); }

/* ── TAGS ── */
.tag { display: inline-flex; align-items: center; font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 4px; border: 1px solid; }
.tag.red    { background: var(--red-bg);    color: var(--red);    border-color: var(--red-bd);    }
.tag.orange { background: var(--orange-bg); color: var(--orange); border-color: var(--orange-bd); }
.tag.green  { background: var(--green-bg);  color: var(--green);  border-color: var(--green-bd);  }
.tag.blue   { background: var(--blue-bg);   color: var(--blue);   border-color: var(--blue-bd);   }
.tag.gray   { background: var(--s3);        color: var(--ink3);   border-color: var(--bd2);       }
.tag.gold   { background: var(--gold-bg);   color: var(--gold);   border-color: var(--gold-bd);   }

/* ── TABS (데스크탑) ── */
.tabs {
  display: flex;
  padding: 0 calc(28px + var(--safe-right)) 0 calc(28px + var(--safe-left));
  background: rgba(24,26,27,.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--bd); overflow-x: auto; gap: 48px; justify-content: center;
  scrollbar-width: none;
}
.tabs::-webkit-scrollbar { display: none; }
.tab {
  flex-shrink: 0; display: inline-flex; align-items: center; gap: 5px;
  padding: 0 2px; height: 50px; margin-right: 0;
  font-size: 15px; font-weight: 600; color: var(--ink4);
  cursor: pointer; border-bottom: 2px solid transparent;
  transition: color .14s, border-color .14s; white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
.tab i { font-size: 20px; }
.tab.active { color: var(--ink); border-bottom-color: var(--ink); font-weight: 800; }
.tab:hover:not(.active) { color: var(--ink2); }

/* ── VIEWS ── */
.view { display: none; padding: 32px 28px; animation: fadeUp .18s ease; max-width: 100%; }
.view.active { display: block; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }

/* ── KPI ── */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 12px; }
.kpi-asset-row { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 0; margin-bottom: 28px; }
@media (max-width: 600px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } .kpi-asset-row { flex-direction: column; align-items: flex-start; gap: 6px; } .kpi-val { font-size: clamp(18px, 6vw, 28px); } }
.kpi { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--r); padding: 20px 18px; transition: transform .2s, box-shadow .2s; cursor: default; }
.kpi:hover { transform: translateY(-2px); box-shadow: var(--sh); }
.kpi-lbl { font-size: 12px; font-weight: 700; color: var(--ink4); letter-spacing: .07em; text-transform: uppercase; margin-bottom: 12px; }
.kpi-val { font-size: clamp(22px, 5vw, 38px); font-weight: 900; color: var(--ink); line-height: 1.15; padding-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.05em; }
.kpi-val.danger { color: var(--red); }
.kpi-val.warn   { color: var(--orange); }
.kpi-val.good   { color: var(--green); }
.kpi-sub { font-size: 13px; color: var(--ink4); margin-top: 6px; }

/* ── TIER GATE BANNER ── */
.tier-gate {
  display: flex; align-items: center; gap: 14px;
  background: linear-gradient(135deg, rgba(245,197,24,.07), rgba(255,154,60,.05));
  border: 1px solid var(--gold-bd); border-radius: var(--r);
  padding: 16px 20px; margin-bottom: 20px;
}
.tier-gate-icon { width: 42px; height: 42px; border-radius: 12px; background: var(--gold-bg); border: 1px solid var(--gold-bd); display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 20px; flex-shrink: 0; }
.tier-gate-body { flex: 1; }
.tier-gate-t { font-size: 14px; font-weight: 800; color: var(--gold); margin-bottom: 4px; }
.tier-gate-d { font-size: 12px; color: rgba(245,197,24,.7); line-height: 1.6; }

/* ── SECTION HEADER ── */
.sec-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; gap: 10px; }
.sec-t  { font-size: 18px; font-weight: 800; }
.sec-row { display: flex; align-items: center; margin-bottom: 20px; }

/* ── CONTRACT LIST ── */
.clist { border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; }
.ci {
  position: relative; background: var(--s2); border-bottom: 1px solid var(--bd);
  border-left: 3px solid transparent; padding: 18px 22px;
  display: flex; align-items: center; gap: 14px;
  cursor: pointer; transition: background .12s;
  -webkit-tap-highlight-color: transparent;
}
.ci:last-child { border-bottom: none; }
.ci:hover { background: var(--s3); }
.ci.danger { border-left-color: var(--red); }
.ci.warn   { border-left-color: var(--orange); }
.ci.safe   { border-left-color: var(--bd2); }
.ci-ico { width: 50px; height: 50px; border-radius: var(--rm); border: 1px solid var(--bd); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 26px; background: var(--s3); color: var(--ink2); }
.ci-ico.red    { background: var(--red-bg);    color: var(--red);    border-color: var(--red-bd);    }
.ci-ico.orange { background: var(--orange-bg); color: var(--orange); border-color: var(--orange-bd); }
.ci-body { flex: 1; min-width: 0; }
.ci-name { font-size: 16px; font-weight: 700; color: var(--ink); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ci-meta { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink3); flex-wrap: wrap; }
.ci-r    { text-align: right; flex-shrink: 0; padding-right: 4px; }
.ci-amt  { font-size: 19px; font-weight: 800; color: var(--ink); }
.ci-dday { display: inline-flex; align-items: center; font-size: 12px; font-weight: 700; margin-top: 5px; padding: 4px 10px; border-radius: 4px; }
.dday-danger { background: var(--red-bg);    color: var(--red);    }
.dday-warn   { background: var(--orange-bg); color: var(--orange); }
.dday-safe   { background: var(--green-bg);  color: var(--green);  }
.dday-expired{ background: var(--s3);          color: var(--ink3);   }
.ci-del-btn {
  display: none; position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
  width: 28px; height: 28px; border-radius: 6px;
  border: 1px solid var(--red-bd); background: var(--red-bg); color: var(--red);
  cursor: pointer; align-items: center; justify-content: center;
  font-size: 14px; transition: all .12s; font-family: inherit;
}
.ci:hover .ci-del-btn { display: flex; }
.ci:hover .ci-r { padding-right: 36px; }

/* ── 모바일에서 카드 삭제 버튼 숨기기 (실수 클릭 방지) ── */
/* 터치 기기(max-width: 768px)에서는 hover가 없으므로 삭제 버튼 완전 숨김 */
/* 삭제는 계약 상세 패널의 "계약 삭제" 버튼으로만 가능 */
@media (max-width: 768px) {
  .ci-del-btn { display: none !important; }
  .ci:hover .ci-r { padding-right: 0; }
}

/* ── PDF FEATURE TEASER ── */
.pdf-teaser { display: flex; align-items: center; gap: 12px; background: var(--blue-bg); border: 1px solid var(--blue-bd); border-radius: var(--rm); padding: 13px 16px; margin-top: 14px; }
.pdf-teaser i { font-size: 22px; color: var(--blue); flex-shrink: 0; }
.pdf-teaser-body { flex: 1; }
.pdf-teaser-t { font-size: 13px; font-weight: 700; margin-bottom: 2px; }
.pdf-teaser-d { font-size: 11px; color: var(--ink4); }

/* ── UPLOAD ── */
.upload-zone { border: 1.5px dashed rgba(255,255,255,.2); border-radius: var(--r); padding: 56px 28px; text-align: center; cursor: pointer; position: relative; background: rgba(255,255,255,.02); transition: border-color .18s, background .18s; }
.upload-zone:hover, .upload-zone.drag-over { border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.06); }
.upload-zone input[type=file] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }
.upload-ico { width: 52px; height: 52px; background: rgba(255,255,255,.08); border-radius: var(--r); display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; border: 1px solid rgba(255,255,255,.14); font-size: 28px; color: var(--ink2); }
.upload-t { font-size: 18px; font-weight: 800; margin-bottom: 5px; }
.upload-s { font-size: 12px; color: var(--ink4); }

/* ── NATURAL LANGUAGE INPUT ── */
.nl-wrap { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; margin-top: 20px; }
.nl-head { padding: 16px 20px; background: var(--s3); border-bottom: 1px solid var(--bd); font-size: 16px; font-weight: 700; display: flex; align-items: center; gap: 10px; color: var(--ink); }
.nl-body { padding: 16px 18px; }
.nl-ta   { width: 100%; min-height: 88px; padding: 12px 14px; border: 1px solid var(--bd); border-radius: var(--rm); font-size: 13px; color: var(--ink); background: rgba(255,255,255,.05); resize: vertical; outline: none; font-family: inherit; line-height: 1.6; transition: border-color .14s; }
.nl-ta:focus { border-color: var(--blue); }
.nl-example-tag { font-size:14px; padding:10px 18px; border:1px solid var(--bd2); border-radius:100px; cursor:pointer; background:transparent; color:var(--ink3); font-weight:500; transition:color .15s, background .15s, border-color .15s; white-space:nowrap; }
.nl-example-tag:hover { color:var(--ink); background:rgba(255,255,255,.12); border-color:var(--ink3); }

/* ── RESULT ── */
.result-wrap { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; margin-top: 24px; }
.result-head { display: flex; align-items: center; justify-content: space-between; padding: 15px 18px; background: var(--s3); border-bottom: 1px solid var(--bd); font-size: 14px; font-weight: 800; }
.result-body { padding: 20px; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 18px; }
@media (max-width: 480px) { .field-grid { grid-template-columns: 1fr; } }
.field-card { background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: var(--rm); padding: 13px 15px; }
.field-lbl  { font-size: 10px; color: var(--ink4); margin-bottom: 5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.field-val  { font-size: 14px; font-weight: 700; color: var(--ink); }
.risk-item  { display: flex; align-items: flex-start; gap: 10px; padding: 14px 16px; border-radius: var(--rm); margin-bottom: 10px; font-size: 15px; line-height: 1.6; border: 1px solid; }
.risk-item:last-child { margin-bottom: 0; }
.risk-item.danger { background: var(--red-bg);    color: #FFB3B3; border-color: var(--red-bd);    }
.risk-item.warn   { background: var(--orange-bg); color: #FFD4A3; border-color: var(--orange-bd); }
.risk-item.ok     { background: var(--green-bg);  color: #A8F0BF; border-color: var(--green-bd);  }
.risk-ico { font-size: 20px; flex-shrink: 0; margin-top: 1px; }

/* ── LOADING / SPINNER ── */
.loading-box { text-align: center; padding: 52px 20px; }
.spinner { width: 28px; height: 28px; border: 2px solid rgba(255,255,255,.1); border-top-color: var(--ink); border-radius: 50%; animation: spin .65s linear infinite; margin: 0 auto 14px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── CALENDAR ── */
.cal-nav   { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.cal-month { font-size: 18px; font-weight: 800; color: var(--ink); }
.cal-grid  { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.cal-dh    { text-align: center; font-size: 10px; font-weight: 700; color: var(--ink4); padding: 8px 4px; }
.cal-cell  { min-height: 72px; max-height: 110px; overflow: hidden; background: var(--s2); border: 1px solid var(--bd); border-radius: var(--rs); padding: 7px 6px; transition: background .12s; }
.cal-cell:hover       { background: var(--s3); }
.cal-cell.today       { border-color: var(--blue); background: var(--blue-bg); }
.cal-cell.other-month { opacity: .3; }
.cal-num         { font-size: 11px; font-weight: 700; color: var(--ink2); margin-bottom: 3px; }
.cal-num.sun     { color: var(--red); }
.cal-num.sat     { color: var(--blue); }
.cal-ev { font-size: 11px; padding: 2px 5px; border-radius: 3px; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 600; cursor: pointer; transition: opacity .12s; }
.cal-ev.red    { background: var(--red-bg);    color: var(--red);    }
.cal-ev.orange { background: var(--orange-bg); color: var(--orange); }
.cal-ev.green  { background: var(--green-bg);  color: var(--green);  }
.cal-ev:hover  { opacity: .75; }

/* ── SWITCH / 갈아타기 ── */
.switch-card    { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; margin-bottom: 12px; }
.switch-head    { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; }
.switch-name    { font-size: 17px; font-weight: 800; margin-bottom: 6px; }
.switch-sub     { font-size: 14px; color: var(--ink3); }
.switch-badge   { padding: 6px 14px; border-radius: 100px; font-size: 16px; font-weight: 900; white-space: nowrap; }
.switch-body    { padding: 0 20px 18px; font-size: 15px; color: var(--ink3); line-height: 1.7; }
.switch-actions { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }

/* ── CPA CARDS ── */
.cpa-section { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--bd); }
.cpa-label   { font-size: 14px; font-weight: 800; color: var(--ink4); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.cpa-label::after { content: ''; flex: 1; height: 1px; background: var(--bd); }
.cpa-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (max-width: 480px) { .cpa-grid { grid-template-columns: 1fr; } }
/* ── 모바일: 모달 내부 그리드 1열 강제 ── */
@media (max-width: 480px) {
  /* 전문가 상담 / 내용증명 등 모달 내 auto-fit 그리드 최소폭 보장 */
  .modal [style*="repeat(auto-fit"] {
    grid-template-columns: 1fr !important;
  }
  /* 발신인/수신인 입력 행: 이름+연락처 세로 쌓기 */
  .modal [style*="minmax(130px"] {
    grid-template-columns: 1fr !important;
  }
}

.cpa-card { display: flex; align-items: center; gap: 10px; padding: 12px 14px; background: var(--s3); border: 1px solid var(--bd); border-radius: var(--rm); text-decoration: none; cursor: pointer; transition: background .14s, border-color .14s, transform .14s; }
.cpa-card:hover { background: var(--s4); border-color: var(--bd2); transform: translateY(-1px); }
.cpa-icon  { width: 44px; height: 44px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0; }
.cpa-body  { flex: 1; min-width: 0; }
.cpa-name  { font-size: 15px; font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.cpa-desc  { font-size: 13px; color: var(--ink4); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cpa-arrow { font-size: 22px; font-weight: 300; color: var(--ink4); flex-shrink: 0; transition: transform .14s, color .14s; }
.cpa-card:hover .cpa-arrow { transform: translateX(2px); color: var(--ink2); }

/* ── INFO BANNER ── */
.info-banner {
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(75,139,245,.06); border: 1px solid var(--blue-bd);
  border-radius: var(--rm); padding: 12px 14px; margin-bottom: 14px;
  font-size: 15px; color: var(--ink3); line-height: 1.65;
}
.info-banner i { color: var(--blue); font-size: 22px; flex-shrink: 0; margin-top: 1px; }

.cpa-disclaimer { margin-top: 8px; font-size: 14px; color: var(--ink4); line-height: 1.6; padding: 10px 12px; background: rgba(255,255,255,.02); border-radius: 6px; border: 1px solid var(--bd); }

/* ── CHAT ── */
.chat-shell  { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--r); display: flex; flex-direction: column; height: calc(100vh - 195px); height: calc(100dvh - 195px); min-height: 480px; overflow: hidden; }
.chat-msgs   { flex: 1; overflow-y: auto; padding: 22px 20px; display: flex; flex-direction: column; gap: 14px; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; }
.chat-msgs::-webkit-scrollbar       { width: 4px; }
.chat-msgs::-webkit-scrollbar-track { background: transparent; }
.chat-msgs::-webkit-scrollbar-thumb { background: var(--s4); border-radius: 4px; }
.msg        { display: flex; gap: 9px; max-width: 84%; }
.msg.user   { align-self: flex-end; flex-direction: row-reverse; }
.msg-av     { width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 800; flex-shrink: 0; transition: transform 0.2s; }
.msg-av.ai   {
  background: linear-gradient(135deg, var(--blue), #7C3AED);
  color: #fff;
  animation: aiPulse 2.5s infinite;
}
.msg-av.user { background: var(--s4); color: var(--ink2); font-size: 12px; }

@keyframes aiPulse {
  0%   { box-shadow: 0 0 0 0   rgba(124,58,237,.45); }
  70%  { box-shadow: 0 0 0 8px rgba(124,58,237,.0);  }
  100% { box-shadow: 0 0 0 0   rgba(124,58,237,.0);  }
}
.bubble      { padding: 12px 15px; font-size: 15px; border-radius: 14px; line-height: 1.65; }
.msg.ai   .bubble { background: var(--s3); border: 1px solid var(--bd);  border-radius: 4px 14px 14px 14px; }
.msg.user .bubble { background: rgba(255,255,255,.12); border: 1px solid var(--bd2); border-radius: 14px 4px 14px 14px; }
.chat-in-row {
  display: flex; gap: 8px;
  padding: 12px 16px calc(12px + var(--safe-bottom)) 16px; /* 홈바 침범 방지 */
  border-top: 1px solid var(--bd); background: rgba(24,26,27,.7);
}
.chat-in { flex: 1; height: 44px; padding: 0 16px; border-radius: 100px; border: 1px solid var(--bd2); background: rgba(255,255,255,.06); color: var(--ink); outline: none; font-size: 13.5px; font-family: inherit; transition: border-color .14s; }
.chat-in:focus { border-color: var(--blue); }
.send-btn { width: 44px; height: 44px; border-radius: 50%; background: var(--ink); color: #111; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 18px; transition: background .14s, opacity .14s; flex-shrink: 0; }
.send-btn:hover { background: rgba(255,255,255,.88); }

/* ── MODALS ── */
.overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.75); z-index: 3000;
  display: none; align-items: center; justify-content: center;
  /* safe-area 기반 패딩 — 홈바/노치 침범 방지 */
  padding:
    calc(20px + var(--safe-top))
    calc(20px + var(--safe-right))
    calc(20px + var(--safe-bottom))
    calc(20px + var(--safe-left));
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  overscroll-behavior: contain; /* 모달 뒤 페이지 스크롤 방지 */
}
.overlay.open { display: flex; }

.modal {
  background: var(--s2); border: 1px solid var(--bd2); border-radius: 20px;
  width: 100%; max-width: 500px;
  padding: 24px 24px calc(24px + var(--safe-bottom)) 24px;
  box-shadow: var(--sh-lg);
  max-height: calc(88vh - var(--safe-top) - var(--safe-bottom));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--s4) transparent;
}
.modal::-webkit-scrollbar { width: 4px; }
.modal::-webkit-scrollbar-track { background: transparent; margin: 16px 0; }
.modal::-webkit-scrollbar-thumb { background: var(--s4); border-radius: 10px; }
.modal::-webkit-scrollbar-thumb:hover { background: var(--ink4); }
.modal.wide    { max-width: 580px; }
.modal.pricing { max-width: 540px; }
.modal-h     { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.modal-title { font-size: 17px; font-weight: 800; }
.modal-x     { background: none; border: none; color: var(--ink4); font-size: 22px; cursor: pointer; line-height: 1; transition: color .12s; font-family: inherit; padding: 4px; }
.modal-x:hover { color: var(--ink); }

/* ── PRICING MODAL ── */
.pricing-hero     { text-align: center; padding: 20px 0 22px; border-bottom: 1px solid var(--bd); margin-bottom: 20px; }
.pricing-eyebrow  { font-size: 11px; font-weight: 700; color: var(--gold); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px; }
.pricing-headline { font-size: 20px; font-weight: 900; line-height: 1.35; margin-bottom: 8px; }
.pricing-sub      { font-size: 12px; color: var(--ink4); line-height: 1.65; }
.pricing-proof    { display: inline-flex; align-items: center; gap: 6px; background: var(--gold-bg); border: 1px solid var(--gold-bd); border-radius: 100px; padding: 5px 14px; margin-top: 12px; font-size: 12px; font-weight: 700; color: var(--gold); }
.plan-toggle      { display: flex; background: var(--s3); border: 1px solid var(--bd); border-radius: var(--rm); padding: 4px; gap: 4px; margin-bottom: 20px; }
.plan-toggle-btn  { flex: 1; height: 36px; border-radius: 8px; border: none; background: transparent; color: var(--ink4); font-size: 13px; font-weight: 700; cursor: pointer; transition: background .14s, color .14s; font-family: inherit; }
.plan-toggle-btn.active { background: var(--ink); color: #111315; }
.plan-toggle-save { font-size: 12px; color: var(--green); font-weight: 800; margin-left: 5px; letter-spacing: -.01em; }
.plan-cards       { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
@media (max-width: 460px) { .plan-cards { grid-template-columns: 1fr; } }
.plan-card        { background: var(--s3); border: 1px solid var(--bd); border-radius: var(--r); padding: 20px 18px; position: relative; transition: border-color .14s; }
.plan-card.featured { background: linear-gradient(160deg, rgba(245,197,24,.06), rgba(255,154,60,.04)); border-color: var(--gold-bd); }
.plan-badge        { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); background: linear-gradient(135deg, var(--gold), #FF9A3C); color: #111315; font-size: 10px; font-weight: 900; padding: 3px 12px; border-radius: 100px; white-space: nowrap; }
.plan-tier-name    { font-size: 11px; font-weight: 700; color: var(--ink4); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.plan-name         { font-size: 18px; font-weight: 900; margin-bottom: 10px; }
.plan-price        { line-height: 1; margin-bottom: 4px; }
.plan-price-num    { font-size: 30px; font-weight: 900; }
.plan-price-period { font-size: 12px; color: var(--ink4); margin-left: 2px; }
.plan-divider      { border: none; border-top: 1px solid var(--bd); margin: 14px 0; }
.plan-features     { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.plan-feat         { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink3); }
.plan-feat i       { font-size: 14px; flex-shrink: 0; }
.plan-feat i.ok    { color: var(--green); }
.plan-feat i.na    { color: var(--ink4); opacity: .35; }
.plan-cta          { width: 100%; justify-content: center; height: 44px; margin-top: 4px; }

/* ── API KEY ── */
.api-input   { width: 100%; height: 46px; padding: 0 14px; border: 1px solid var(--bd2); border-radius: var(--rm); background: rgba(255,255,255,.05); color: var(--ink); margin-bottom: 14px; outline: none; font-family: inherit; font-size: 13px; transition: border-color .14s; }
.api-input:focus { border-color: var(--blue); }
.api-note    { font-size: 12px; color: var(--ink4); line-height: 1.65; margin-top: 14px; }
.api-dot     { width: 7px; height: 7px; border-radius: 50%; background: var(--ink4); display: inline-block; flex-shrink: 0; transition: background .3s; }
.api-dot.connected { background: var(--green); }

/* ── SMS ── */
.sms-ta { width: 100%; height: 140px; background: rgba(255,255,255,.05); border: 1px solid var(--bd); color: var(--ink); padding: 12px; border-radius: var(--rm); resize: none; font-family: inherit; font-size: 13px; line-height: 1.65; outline: none; transition: border-color .14s; }
.sms-ta:focus { border-color: var(--blue); }

/* ── HITL ── */
.hitl-warning  { background: var(--orange-bg); border: 1px solid var(--orange-bd); padding: 11px 14px; border-radius: var(--rm); font-size: 12px; color: #FFD4A3; margin-bottom: 16px; line-height: 1.65; }
.hitl-grid     { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 18px; }
@media (max-width: 480px) { .hitl-grid { grid-template-columns: 1fr; } }
.hitl-field    { background: var(--s3); padding: 10px 12px; border-radius: var(--rm); border: 1px solid var(--bd); }
.hitl-lbl      { font-size: 10px; color: var(--ink4); margin-bottom: 5px; font-weight: 700; }
.hitl-in       { width: 100%; background: transparent; border: none; color: var(--ink); font-weight: 700; outline: none; border-bottom: 1px solid var(--bd2); padding-bottom: 3px; font-family: inherit; font-size: 14px; transition: border-color .14s; }
.hitl-in:focus { border-bottom-color: var(--blue); }
.hitl-footer   { border-top: 1px solid var(--bd); padding-top: 16px; }
.hitl-cb-row   { display: flex; align-items: flex-start; gap: 9px; font-size: 13px; cursor: pointer; margin-bottom: 14px; line-height: 1.5; }
.hitl-cb-row input { width: 15px; height: 15px; accent-color: var(--green); margin-top: 2px; flex-shrink: 0; }

/* ── DETAIL PANEL ── */
.dp-backdrop   { position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 2400; display: none; backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); }
.dp-backdrop.open { display: block; }
.detail-panel  {
  position: fixed; top: 0; right: 0; bottom: 0; width: 400px; max-width: 100%;
  background: var(--s2); border-left: 1px solid var(--bd2); z-index: 2500;
  transform: translateX(100%); transition: transform .28s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column; overflow: hidden;
  /* 우측·하단 Safe Area 보호 */
  padding-right: var(--safe-right);
  padding-bottom: var(--safe-bottom);
}
.detail-panel.open { transform: translateX(0); }
.dp-head   { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; border-bottom: 1px solid var(--bd); flex-shrink: 0; }
.dp-title  { font-size: 20px; font-weight: 800; }
.dp-body {
  flex: 1; overflow-y: auto; padding: 22px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--s4) transparent;
}
.dp-body::-webkit-scrollbar { width: 5px; }
.dp-body::-webkit-scrollbar-track { background: transparent; margin: 10px 0; }
.dp-body::-webkit-scrollbar-thumb { background: var(--s4); border-radius: 10px; }
.dp-body::-webkit-scrollbar-thumb:hover { background: var(--ink4); }
.dp-section { margin-bottom: 22px; }
.dp-sec-t  { font-size: 12px; font-weight: 800; color: var(--ink4); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 10px; }
.dp-field  { padding: 12px 14px; background: var(--s3); border-radius: var(--rm); border: 1px solid var(--bd); margin-bottom: 8px; }
.dp-field:last-child { margin-bottom: 0; }
.dp-fl { font-size: 12px; color: var(--ink4); margin-bottom: 4px; }
.dp-fv { font-size: 16px; font-weight: 700; }
.dp-footer {
  padding: 20px 22px calc(36px + var(--safe-bottom));
  background: rgba(31,33,35,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--bd);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  flex-shrink: 0;
}
.dp-footer .btn {
  flex: none !important;
  height: 52px !important;
  font-size: 15px;
  border-radius: 12px;
  justify-content: center;
  gap: 8px;
}
.dp-footer .btn i {
  font-size: 18px;
}
.dp-delete-btn {
  width: 100%; padding: 10px; border: none; background: none;
  color: var(--ink4); font-size: 12px; cursor: pointer;
  font-family: inherit; transition: color .15s;
}
.dp-delete-btn:hover { color: var(--red); }

/* ── EDIT MODAL ── */
.edit-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 16px; }
@media (max-width: 480px) { .edit-grid { grid-template-columns: 1fr; } }
.edit-field { background: var(--s3); padding: 10px 12px; border-radius: var(--rm); border: 1px solid var(--bd); }
.edit-lbl   { font-size: 10px; color: var(--ink4); margin-bottom: 5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.edit-in    { width: 100%; background: transparent; border: none; color: var(--ink); font-weight: 700; outline: none; border-bottom: 1px solid var(--bd2); padding-bottom: 3px; font-family: inherit; font-size: 14px; transition: border-color .14s; }
.edit-in:focus { border-bottom-color: var(--blue); }

/* ── DISCLAIMER ── */
.disclaimer     { display: flex; gap: 12px; align-items: flex-start; background: var(--orange-bg); border: 1px solid var(--orange-bd); border-radius: var(--r); padding: 16px 18px; margin-bottom: 22px; }
.disclaimer-ico { width: 34px; height: 34px; flex-shrink: 0; background: rgba(255,154,60,.18); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--orange); font-size: 17px; }
.disclaimer-body { flex: 1; }
.disclaimer-t   { font-size: 12px; font-weight: 800; color: var(--orange); margin-bottom: 4px; }
.disclaimer-d   { font-size: 12px; color: #FFD4A3; line-height: 1.65; }

/* ── TOAST ── */
.toast {
  position: fixed; left: 50%;
  bottom: calc(24px + var(--safe-bottom)); /* 홈바 위로 올림 */
  transform: translateX(-50%) translateY(80px); opacity: 0;
  background: rgba(18,20,21,.96); padding: 11px 20px; border-radius: var(--rm);
  font-size: 13px; font-weight: 600; color: var(--ink); z-index: 9999;
  transition: opacity .28s ease, transform .28s ease;
  border: 1px solid var(--bd2); display: flex; align-items: center; gap: 8px;
  white-space: nowrap; box-shadow: var(--sh);
  pointer-events: none; /* 클릭 방해 방지 */
}
.toast.show    { transform: translateX(-50%) translateY(0); opacity: 1; }
.toast.success { border-color: var(--green-bd);  }
.toast.error   { border-color: var(--red-bd);    }
.toast.warn    { border-color: var(--orange-bd); }
.toast.gold    { border-color: var(--gold-bd);   }

/* ── DIVIDER ── */
.divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; font-size: 12px; color: var(--ink4); }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--bd); }

/* ── EMPTY STATE ── */
.empty-state { padding: 52px 20px; text-align: center; color: var(--ink4); }
.empty-ico   { font-size: 40px; margin-bottom: 12px; opacity: .3; }
.empty-t     { font-size: 14px; font-weight: 700; margin-bottom: 5px; color: var(--ink3); }
.empty-d     { font-size: 12px; line-height: 1.6; }

/* ── BOTTOM NAV (모바일) ── */
.bottom-nav { display: none; }

@media (max-width: 768px) {
  .tabs { display: none !important; }

  .bottom-nav {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0;
    /* 홈바를 포함한 실제 높이 */
    height: calc(var(--bnav-h) + var(--safe-bottom));
    background: rgba(18,20,21,.97);
    border-top: 1px solid var(--bd); z-index: 300;
    justify-content: space-around;
    /* 아이콘 영역은 위쪽, 홈바 영역은 빈 공간 */
    padding-bottom: var(--safe-bottom);
    padding-left:  var(--safe-left);
    padding-right: var(--safe-right);
  }

  .bn-item {
    flex: 1; background: none; border: none; color: var(--ink4);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 600; cursor: pointer; gap: 3px;
    transition: color .14s; font-family: inherit;
    min-height: var(--bnav-h); /* 터치 타겟 확보 */
    -webkit-tap-highlight-color: transparent;
  }
  .bn-item i      { font-size: 26px; }
  .bn-item.active { color: var(--ink); font-weight: 800; }
  .bn-item.center { justify-content: center; }
  .bn-plus {
    width: 60px; height: 60px;
    background: var(--ink);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #111; font-size: 30px;
    transform: translateY(-16px);
    border: 5px solid #121415;
    box-shadow: 0 6px 20px rgba(0,0,0,.55), 0 2px 8px rgba(0,0,0,.3);
    transition: transform .2s cubic-bezier(.34,1.56,.64,1), background .2s, box-shadow .2s;
  }
  .bn-item.center:active .bn-plus {
    transform: translateY(-12px) scale(0.92);
    background: #e0e0e0;
    box-shadow: 0 3px 10px rgba(0,0,0,.4);
  }

  /* 바텀 네비 전체 높이(홈바 포함)만큼 컨텐츠 여백 */
  .shell { padding-bottom: calc(var(--bnav-h) + var(--safe-bottom)); }

  /* 채팅 뷰 높이: dvh 기준, 바텀 네비 높이 제외 */
  .chat-shell { height: calc(100dvh - 195px - var(--safe-bottom)); }

  .view  { padding: 24px 16px; }
  /* 모바일 nav: 상단 노치/다이나믹 아일랜드 보호 */
  .nav   {
    padding: var(--safe-top) calc(20px + var(--safe-right)) 0 calc(20px + var(--safe-left));
    height: calc(60px + var(--safe-top));
    align-items: center;
  }
  .modal { padding: 18px 18px calc(18px + var(--safe-bottom)) 18px; }

  .nav-r .btn span { display: none; }
  .nav-r .btn      { padding: 0 12px; gap: 0; height: 38px; }
  .nav-r .btn.primary { display: none !important; }
  #user-name { display: none; }
  #user-info > div { padding: 4px; }
}

/* ── SEARCH / SORT / CHIP FILTER ── */
.search-sort-row { display: flex; gap: 8px; margin-bottom: 10px; align-items: center; }
.search-wrap { position: relative; flex: 1; }
.search-wrap i { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); font-size: 15px; color: var(--ink4); pointer-events: none; }
.search-input { width: 100%; box-sizing: border-box; background: var(--s2); border: 1px solid var(--bd2); border-radius: var(--rm); padding: 9px 12px 9px 32px; font-size: 13px; color: var(--ink); font-family: inherit; outline: none; transition: border-color .15s; }
.search-input::placeholder { color: var(--ink4); }
.search-input:focus { border-color: var(--ink3); }
.sort-wrap { position: relative; flex-shrink: 0; }
.sort-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--s2); border: 1px solid var(--bd2); border-radius: var(--rm);
  padding: 9px 12px; font-size: 12px; color: var(--ink2);
  font-family: inherit; outline: none; cursor: pointer; white-space: nowrap;
  transition: border-color .15s, color .15s;
}
.sort-btn:hover { border-color: var(--blue); color: var(--ink); }
.sort-menu {
  display: none; position: absolute; right: 0; top: calc(100% + 6px); z-index: 200;
  background: var(--s2); border: 1px solid var(--bd2); border-radius: var(--rm);
  padding: 4px; min-width: 120px; box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
.sort-menu.open { display: flex; flex-direction: column; }
.sort-opt {
  background: none; border: none; text-align: left;
  padding: 8px 12px; font-size: 12px; color: var(--ink3);
  font-family: inherit; cursor: pointer; border-radius: 6px;
  transition: background .12s, color .12s;
}
.sort-opt:hover { background: var(--s1); color: var(--ink); }
.sort-opt.active { color: var(--blue); font-weight: 700; }
.chip { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 100px; border: 1px solid var(--bd2); background: var(--s2); color: var(--ink3); font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: background .12s, color .12s, border-color .12s; font-family: inherit; }
.chip.active { background: var(--ink); color: #111; border-color: var(--ink); }
.chip-count { font-size: 10px; font-weight: 800; opacity: .7; }

/* ── MOBILE / SAFE-AREA ── */
@media (orientation: landscape) and (max-width: 896px) {
  .overlay {
    padding:
      calc(12px + var(--safe-top))
      calc(20px + var(--safe-right))
      calc(12px + var(--safe-bottom))
      calc(20px + var(--safe-left));
  }
}

/* ── PHASE 3: Push Settings UI ── */
.push-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.push-info { flex: 1; min-width: 0; }
.push-title { font-size: 14px; font-weight: 700; color: var(--ink); margin-bottom: 5px; display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.push-status-badge { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 100px; }
.push-desc { font-size: 12px; color: var(--ink3); line-height: 1.6; }
.push-schedule-info { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--bd); display: flex; flex-direction: column; gap: 8px; }
.push-sched-item { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink3); }

/* ── PWA Install Banner ── */
#pwa-install-banner { position: sticky; top: 0; z-index: 200; }

/* ── PHASE 4: Analytics Dashboard ── */
#analytics-wrap { width: 100%; max-width: 100%; box-sizing: border-box; }
.ana-card { background: var(--s2); border: 1px solid var(--bd); border-radius: var(--rl); padding: 20px 22px; overflow: hidden; max-width: 100%; box-sizing: border-box; }
.ana-card-t { font-size: 15px; font-weight: 600; color: #9a9a9a; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--bd); }
.ana-card-t i { font-size: 18px; color: #9a9a9a; }
.ana-empty { font-size: 15px; color: var(--ink4); text-align: center; padding: 28px 0; }
.donut-slice { transition: opacity .15s; cursor: default; }

/* ── 프라이버시 블라인드 모드 ── */
.blind-amt { position:relative; cursor:pointer; user-select:none; }
.blind-amt.blinded { filter:blur(6px); transition:filter .2s; }
.blind-amt:not(.blinded) { filter:none; transition:filter .2s; }
.blind-eye {
  display:none;
  position:absolute;
  right:-18px; top:50%; transform:translateY(-50%);
  font-size:13px; color:var(--ink4);
  pointer-events:none;
}
.blind-amt.blinded .blind-eye { display:inline-block; }

/* ── KPI 블라인드 모드 ── */
.kpi-blind { position:relative; }
.kpi-blind.kpi-hidden::before {
  content:'•••••';
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:flex-start;
  font-size:inherit; font-weight:800; letter-spacing:6px;
  background:transparent;
}
#kpi-cost.kpi-hidden::before   { color:#ff9a3c; }
#kpi-annual.kpi-hidden::before { color:var(--green); }
#kpi-asset.kpi-hidden::before  { color:#4B8BF5; }
.kpi-blind.kpi-hidden { color:transparent !important; user-select:none; }
.kpi-eye { font-size:20px !important; transition:color .2s; }
.kpi-eye:hover { color:var(--ink2) !important; }

/* ── 갱신 히스토리 ── */
/* 보관됨/갱신됨은 목록에서 숨김 — 상세 패널 타임라인에서만 확인 */

/* ── 푸시 자동 배너 애니메이션 ── */
@keyframes slideUp { from { opacity:0; transform:translateX(-50%) translateY(16px); } to { opacity:1; transform:translateX(-50%) translateY(0); } }

