/* ============================================================
   피플인사이트 어드민 — 디자인 시스템
   레이아웃: .app > .side(240px) + .main(.topbar + .content)
   ============================================================ */
:root{
  --ink:#0f172a; --ink-2:#1e293b; --ink-3:#334155;
  --bg:#f1f5f9; --paper:#ffffff; --line:#e2e8f0; --line-d:#cbd5e1;
  --tx:#1e293b; --tx-soft:#64748b; --tx-faint:#94a3b8;
  --brand:#2563eb; --brand-deep:#1d4ed8; --brand-soft:#dbeafe;
  --green:#059669; --green-soft:#d1fae5;
  --red:#dc2626; --red-soft:#fee2e2;
  --amber:#d97706; --amber-soft:#fef3c7;
  --teal:#0d9488; --teal-soft:#ccfbf1;
  --purple:#7c3aed; --purple-soft:#ede9fe;
  --indigo:#4f46e5; --indigo-soft:#e0e7ff;
  --gray:#64748b; --gray-soft:#f1f5f9;
  --r:10px; --r-lg:14px;
  --shadow:0 1px 3px rgba(15,23,42,.07), 0 1px 2px rgba(15,23,42,.04);
  --shadow-lg:0 10px 32px rgba(15,23,42,.16);
  font-size:15px;
}
*{margin:0; padding:0; box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{font-family:"Pretendard Variable",Pretendard,-apple-system,"Malgun Gothic",sans-serif;
  background:var(--bg); color:var(--tx); line-height:1.55; font-size:.94rem;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit;}
input,select,textarea{font-family:inherit; font-size:inherit;}

/* ---------- 레이아웃 ---------- */
.app{display:flex; min-height:100vh;}
.side{width:240px; flex-shrink:0; background:var(--ink); color:#e2e8f0; display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh; z-index:40;}
.side__brand{display:flex; align-items:center; gap:10px; padding:18px 20px; border-bottom:1px solid rgba(255,255,255,.08);}
.side__logo{display:grid; place-items:center; width:32px; height:32px; border-radius:9px; flex-shrink:0;
  background:linear-gradient(135deg,#3b82f6,#1d4ed8); color:#fff; font-weight:900; font-size:16px;}
.side__name{font-weight:800; font-size:.98rem; letter-spacing:-.01em;}
.side__nav{flex:1; padding:12px 10px; overflow-y:auto; display:flex; flex-direction:column; gap:2px;}
.side__group{font-size:.72rem; font-weight:700; letter-spacing:.12em; color:#94a3b8; text-transform:uppercase;
  padding:14px 12px 5px; margin-top:4px;}
.side__group:first-child{margin-top:0;}
.side__link{display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:8px;
  color:#cbd5e1; font-size:.96rem; font-weight:500; transition:background .12s,color .12s;}
.side__link i{width:18px; text-align:center; font-size:.92rem; color:#64748b; transition:color .12s;}
.side__link:hover{background:rgba(255,255,255,.06); color:#fff;}
.side__link:hover i{color:#93c5fd;}
.side__link.is-active{background:rgba(59,130,246,.18); color:#fff; font-weight:700;}
.side__link.is-active i{color:#60a5fa;}
.side__foot{display:flex; align-items:center; gap:8px; padding:14px 16px; border-top:1px solid rgba(255,255,255,.08);}
.side__user{display:flex; align-items:center; gap:10px; flex:1; min-width:0;}
.side__avatar{display:grid; place-items:center; width:34px; height:34px; border-radius:50%; flex-shrink:0;
  background:#475569; color:#fff; font-weight:700; font-size:.88rem;}
.side__user-meta{min-width:0; line-height:1.3;}
.side__user-meta b{display:block; font-size:.86rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.side__user-meta small{font-size:.72rem; color:#94a3b8;}
.side__logout{display:grid; place-items:center; width:32px; height:32px; border-radius:8px; color:#94a3b8;}
.side__logout:hover{background:rgba(255,255,255,.08); color:#f87171;}

.main{flex:1; min-width:0; display:flex; flex-direction:column;}
.topbar{position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--line);
  padding:0 24px; height:56px;}
.topbar__menu{display:none; background:none; border:none; font-size:1.1rem; color:var(--tx-soft); cursor:pointer; padding:6px;}
.topbar__title{font-size:1.06rem; font-weight:800; letter-spacing:-.01em;}
.topbar__right{margin-left:auto; display:flex; align-items:center; gap:12px;}
.topbar__date{font-size:.82rem; color:var(--tx-faint);}
.content{flex:1; padding:24px; max-width:1400px; width:100%; margin-inline:auto;}

/* ---------- 카드 ---------- */
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow); margin-bottom:18px;}
.card__head{display:flex; align-items:center; gap:10px; padding:14px 18px; border-bottom:1px solid var(--line); flex-wrap:wrap;}
.card__title{font-size:.98rem; font-weight:800; display:flex; align-items:center; gap:8px;}
.card__title i{color:var(--brand); font-size:.9rem;}
.card__sub{font-size:.8rem; color:var(--tx-soft);}
.card__right{margin-left:auto; display:flex; align-items:center; gap:8px; flex-wrap:wrap;}
.card__body{padding:18px;}
.card__body--flush{padding:0;}
.card__foot{padding:12px 18px; border-top:1px solid var(--line); display:flex; align-items:center; gap:10px;}

/* ---------- 통계 카드 ---------- */
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:14px; margin-bottom:18px;}
.stat-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow); padding:16px 18px; display:flex; align-items:center; gap:14px;}
.stat-card__icon{display:grid; place-items:center; width:42px; height:42px; border-radius:11px; flex-shrink:0;
  background:var(--brand-soft); color:var(--brand); font-size:1.05rem;}
.stat-card__icon.i-green{background:var(--green-soft); color:var(--green);}
.stat-card__icon.i-red{background:var(--red-soft); color:var(--red);}
.stat-card__icon.i-amber{background:var(--amber-soft); color:var(--amber);}
.stat-card__icon.i-teal{background:var(--teal-soft); color:var(--teal);}
.stat-card__icon.i-purple{background:var(--purple-soft); color:var(--purple);}
.stat-card__n{font-size:1.4rem; font-weight:900; letter-spacing:-.02em; line-height:1.2;}
.stat-card__n small{font-size:.8rem; font-weight:600; color:var(--tx-soft); margin-left:2px;}
.stat-card__l{font-size:.78rem; color:var(--tx-soft); margin-top:1px;}

/* ---------- 테이블 ---------- */
.tbl-wrap{overflow-x:auto;}
.tbl{width:100%; border-collapse:collapse; font-size:.88rem;}
.tbl th{background:#f8fafc; color:var(--tx-soft); font-weight:700; font-size:.78rem; text-align:left;
  padding:9px 12px; border-bottom:1px solid var(--line); white-space:nowrap; letter-spacing:.02em;}
.tbl td{padding:9px 12px; border-bottom:1px solid #f1f5f9; vertical-align:middle;}
.tbl tbody tr:hover{background:#f8fafc;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl .num{text-align:right; font-variant-numeric:tabular-nums;}
.tbl .center{text-align:center;}
.tbl .nowrap{white-space:nowrap;}
.tbl a.lnk{color:var(--brand); font-weight:600;}
.tbl a.lnk:hover{text-decoration:underline;}
.tbl tr.is-attention{background:#fffbeb;}
.tbl tr.is-excluded td{color:var(--tx-faint); text-decoration:line-through;}
.tbl tr.is-excluded td .badge{text-decoration:none;}
.tbl-empty{padding:36px 20px; text-align:center; color:var(--tx-faint); font-size:.9rem;
  display:flex; flex-direction:column; align-items:center; justify-content:center;}
.tbl-empty i, .tbl-empty svg{font-size:1.6rem; margin-bottom:8px; opacity:.5;}

/* ---------- 배지 ---------- */
.badge{display:inline-flex; align-items:center; gap:5px; padding:2px 9px; border-radius:999px;
  font-size:.74rem; font-weight:700; white-space:nowrap; line-height:1.6;}
.b-green{background:var(--green-soft); color:var(--green);}
.b-red{background:var(--red-soft); color:var(--red);}
.b-amber{background:var(--amber-soft); color:var(--amber);}
.b-blue{background:var(--brand-soft); color:var(--brand-deep);}
.b-teal{background:var(--teal-soft); color:var(--teal);}
.b-purple{background:var(--purple-soft); color:var(--purple);}
.b-indigo{background:var(--indigo-soft); color:var(--indigo);}
.b-gray{background:var(--gray-soft); color:var(--gray);}
.badge--dot::before{content:""; width:6px; height:6px; border-radius:50%; background:currentColor;}

/* ---------- 버튼 ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:7px 14px; border-radius:8px;
  border:1px solid var(--line-d); background:var(--paper); color:var(--tx); font-family:inherit;
  font-size:.86rem; font-weight:600; line-height:1.45; vertical-align:middle; text-decoration:none;
  cursor:pointer; transition:background .12s,border-color .12s,color .12s; white-space:nowrap;}
.btn:hover{background:#f8fafc; border-color:#94a3b8;}
.btn i{font-size:.82rem;}
.btn--primary{background:var(--brand); border-color:var(--brand); color:#fff;}
.btn--primary:hover{background:var(--brand-deep); border-color:var(--brand-deep);}
.btn--success{background:var(--green); border-color:var(--green); color:#fff;}
.btn--success:hover{background:#047857; border-color:#047857;}
.btn--danger{background:var(--red); border-color:var(--red); color:#fff;}
.btn--danger:hover{background:#b91c1c; border-color:#b91c1c;}
.btn--danger-ghost{background:var(--paper); border-color:#fca5a5; color:var(--red);}
.btn--danger-ghost:hover{background:var(--red-soft);}
.btn--ghost{background:transparent; border-color:transparent; color:var(--tx-soft);}
.btn--ghost:hover{background:var(--gray-soft); border-color:transparent;}
.btn--sm{padding:4px 10px; font-size:.78rem; border-radius:6px;}
.btn--lg{padding:10px 20px; font-size:.95rem;}
.btn:disabled{opacity:.5; cursor:not-allowed; pointer-events:none;}
.btn-group{display:inline-flex; gap:8px; flex-wrap:wrap;}
/* 카드 헤더 액션 버튼 — 모든 페이지 통일 높이(36px). --sm/일반 구분 없이 동일 규격 */
.card__head .btn{height:36px; padding:0 16px; font-size:.84rem; border-radius:8px; line-height:1;}
.card__head .btn i{font-size:.8rem;}

/* 날짜 네비게이션 — < [날짜] > 통일 컴포넌트 (모든 페이지 공통) */
.datenav-wrap{display:inline-flex; align-items:center; gap:8px;}
.datenav{display:inline-flex; align-items:center; border:1px solid var(--line-d); border-radius:10px; overflow:hidden; background:#fff;}
.datenav__arrow{display:flex; align-items:center; justify-content:center; width:40px; height:38px; flex-shrink:0;
  color:var(--tx-soft); background:#fff; font-size:.8rem; transition:background .12s,color .12s; cursor:pointer;}
.datenav__arrow:hover{background:#f1f5f9; color:var(--brand);}
.datenav__date{border:0; border-left:1px solid var(--line); border-right:1px solid var(--line); border-radius:0;
  height:38px; width:auto; min-width:178px; text-align:center; padding:0 14px; box-sizing:border-box;
  font-family:inherit; font-weight:700; font-size:.9rem; color:var(--tx); background:#fff; cursor:pointer; outline:none;}
.datenav__date:focus{box-shadow:none;}
.datenav__date--month{min-width:138px;}                 /* 월 표시(display)·native month 입력 */
.datenav__date::-webkit-calendar-picker-indicator{cursor:pointer; opacity:.5;}

/* ---------- 폼 ---------- */
.form-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px 16px;}
.form-grid .span-2{grid-column:span 2;}
.form-grid .span-full{grid-column:1 / -1;}
.field{display:flex; flex-direction:column; gap:5px;}
.field > label{font-size:.78rem; font-weight:700; color:var(--tx-soft);}
.field > label .req{color:var(--red); margin-left:2px;}
.field .hint{font-size:.74rem; color:var(--tx-faint);}
.input,.select,.textarea{width:100%; padding:8px 11px; border:1px solid var(--line-d); border-radius:8px;
  background:#fff; font-size:.9rem; color:var(--tx); transition:border-color .12s,box-shadow .12s;}
.input:focus,.select:focus,.textarea:focus{outline:none; border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.input.is-error{border-color:var(--red); box-shadow:0 0 0 3px rgba(220,38,38,.1);}
.input--sm{padding:5px 8px; font-size:.84rem; border-radius:6px;}
.textarea{min-height:84px; resize:vertical;}
.input[readonly]{background:#f8fafc; color:var(--tx-soft);}
.checkline{display:flex; align-items:center; gap:8px; font-size:.88rem; cursor:pointer; user-select:none;}
.checkline input{width:16px; height:16px; accent-color:var(--brand);}
.radio-cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:10px;}
.radio-card{border:1.5px solid var(--line); border-radius:var(--r); padding:12px 14px; cursor:pointer; transition:border-color .12s,background .12s;}
.radio-card:has(input:checked){border-color:var(--brand); background:#f0f6ff;}
.radio-card input{margin-right:8px; accent-color:var(--brand);}
.radio-card b{font-size:.9rem;}
.radio-card p{font-size:.78rem; color:var(--tx-soft); margin-top:4px;}

/* 인라인 편집 셀 */
.cell-edit{min-width:72px; padding:4px 8px; border:1px solid transparent; border-radius:6px;
  background:transparent; font-size:.88rem; width:100%; font-variant-numeric:tabular-nums;}
.cell-edit:hover{border-color:var(--line-d); background:#fff;}
.cell-edit:focus{outline:none; border-color:var(--brand); background:#fff; box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.cell-edit.is-saving{border-color:var(--amber); background:#fffbeb;}
.cell-edit.is-saved{border-color:var(--green); background:#f0fdf4;}
.cell-edit.is-error{border-color:var(--red); background:#fef2f2;}

/* ---------- 필터 바 ---------- */
.filterbar{display:flex; align-items:flex-end; gap:10px; flex-wrap:wrap; margin-bottom:16px;}
.filterbar .field{min-width:140px;}
.filterbar .grow{flex:1;}
.chips{display:flex; gap:6px; flex-wrap:wrap;}
.chip{display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:999px;
  border:1px solid var(--line-d); background:#fff; font-size:.8rem; font-weight:600; color:var(--tx-soft); cursor:pointer;}
.chip:hover{border-color:var(--brand); color:var(--brand);}
.chip.is-on{background:var(--brand); border-color:var(--brand); color:#fff;}
.chip .cnt{font-size:.72rem; opacity:.75;}

/* ---------- 모달 ---------- */
.modal-back{position:fixed; inset:0; background:rgba(15,23,42,.45); z-index:100;
  display:flex; align-items:center; justify-content:center; padding:20px;
  animation:fadeIn .14s ease;}
.modal{background:#fff; border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  width:100%; max-width:520px; max-height:88vh; display:flex; flex-direction:column;
  animation:slideUp .16s ease;}
.modal--lg{max-width:760px;}
.modal--xl{max-width:1000px;}
.modal__head{display:flex; align-items:center; gap:10px; padding:16px 20px; border-bottom:1px solid var(--line);}
.modal__title{font-size:1rem; font-weight:800;}
.modal__close{margin-left:auto; background:none; border:none; font-size:1.05rem; color:var(--tx-faint);
  cursor:pointer; padding:4px 6px; border-radius:6px;}
.modal__close:hover{background:var(--gray-soft); color:var(--tx);}
.modal__body{padding:20px; overflow-y:auto;}
.modal__foot{display:flex; justify-content:flex-end; gap:8px; padding:14px 20px; border-top:1px solid var(--line);}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes slideUp{from{transform:translateY(10px); opacity:0;}to{transform:none; opacity:1;}}

/* ---------- 토스트 ---------- */
#piToastRoot{position:fixed; bottom:22px; right:22px; z-index:200; display:flex; flex-direction:column; gap:8px;}
.toast{display:flex; align-items:center; gap:10px; padding:11px 16px; border-radius:10px;
  background:var(--ink); color:#fff; font-size:.86rem; font-weight:600; box-shadow:var(--shadow-lg);
  animation:slideUp .18s ease; max-width:380px;}
.toast--success{background:var(--green);}
.toast--error{background:var(--red);}
.toast--warn{background:var(--amber);}
.toast i{font-size:.9rem;}

/* ---------- flash ---------- */
.flash{display:flex; align-items:center; gap:10px; padding:11px 16px; border-radius:var(--r);
  font-size:.88rem; font-weight:600; margin-bottom:14px; border:1px solid transparent;}
.flash--success{background:var(--green-soft); color:#065f46; border-color:#a7f3d0;}
.flash--error{background:var(--red-soft); color:#991b1b; border-color:#fecaca;}
.flash--warn{background:var(--amber-soft); color:#92400e; border-color:#fde68a;}
.flash--info{background:var(--brand-soft); color:var(--brand-deep); border-color:#bfdbfe;}

/* ---------- 탭 ---------- */
.tabs{display:flex; gap:2px; border-bottom:1px solid var(--line); margin-bottom:18px; overflow-x:auto;}
.tab{padding:9px 16px; font-size:.88rem; font-weight:600; color:var(--tx-soft);
  border-bottom:2px solid transparent; white-space:nowrap; cursor:pointer;}
.tab:hover{color:var(--tx);}
.tab.is-active{color:var(--brand); border-bottom-color:var(--brand); font-weight:700;}

/* ---------- 마스킹·민감정보 ---------- */
.masked{font-family:ui-monospace,Consolas,monospace; font-size:.86rem; letter-spacing:.03em;}
.unmask-btn{display:inline-flex; align-items:center; gap:4px; margin-left:6px; padding:2px 8px;
  border:1px solid var(--line-d); border-radius:6px; background:#fff; font-size:.72rem; font-weight:600;
  color:var(--tx-soft); cursor:pointer;}
.unmask-btn:hover{border-color:var(--brand); color:var(--brand);}

/* ---------- 칸반 ---------- */
.kanban{display:flex; gap:12px; overflow-x:auto; padding-bottom:8px; align-items:flex-start;}
.kanban__col{flex:0 0 230px; background:#f8fafc; border:1px solid var(--line); border-radius:var(--r);}
.kanban__head{display:flex; align-items:center; gap:7px; padding:10px 12px; border-bottom:1px solid var(--line);
  font-size:.8rem; font-weight:800;}
.kanban__cnt{margin-left:auto; font-size:.72rem; background:var(--gray-soft); color:var(--tx-soft);
  padding:1px 8px; border-radius:999px; font-weight:700;}
.kanban__body{padding:8px; display:flex; flex-direction:column; gap:7px; min-height:50px; max-height:60vh; overflow-y:auto;}
.kanban__card{background:#fff; border:1px solid var(--line); border-radius:8px; padding:10px 12px;
  font-size:.82rem; box-shadow:var(--shadow); display:block;}
.kanban__card:hover{border-color:var(--brand);}
.kanban__card b{display:block; font-size:.86rem;}
.kanban__card small{color:var(--tx-soft);}

/* ---------- 타임라인 (이벤트) ---------- */
.timeline{display:flex; flex-direction:column;}
.tl-item{display:grid; grid-template-columns:18px 1fr; gap:12px; position:relative; padding-bottom:16px;}
.tl-item::before{content:""; position:absolute; left:8px; top:18px; bottom:0; width:2px; background:var(--line);}
.tl-item:last-child::before{display:none;}
.tl-dot{width:18px; height:18px; border-radius:50%; background:var(--brand-soft); border:2px solid var(--brand);
  margin-top:2px; z-index:1;}
.tl-body{font-size:.85rem;}
.tl-body b{font-weight:700;}
.tl-meta{font-size:.74rem; color:var(--tx-faint); margin-top:2px;}

/* ---------- 단계 스텝퍼 ---------- */
.stepper{display:flex; align-items:center; gap:0; flex-wrap:wrap; margin-bottom:18px;}
.step{display:flex; align-items:center; gap:7px; font-size:.78rem; font-weight:600; color:var(--tx-faint);}
.step__n{display:grid; place-items:center; width:24px; height:24px; border-radius:50%;
  background:var(--gray-soft); color:var(--tx-faint); font-size:.72rem; font-weight:800;}
.step.is-done .step__n{background:var(--green); color:#fff;}
.step.is-done{color:var(--green);}
.step.is-now .step__n{background:var(--brand); color:#fff;}
.step.is-now{color:var(--brand); font-weight:800;}
.step__bar{width:26px; height:2px; background:var(--line-d); margin:0 6px;}

/* ---------- 위저드 ---------- */
.wizard-steps{display:flex; gap:8px; margin-bottom:20px;}
.wizard-step{flex:1; text-align:center; padding:9px 6px; border-radius:8px; background:var(--gray-soft);
  font-size:.78rem; font-weight:700; color:var(--tx-faint);}
.wizard-step.is-now{background:var(--brand); color:#fff;}
.wizard-step.is-done{background:var(--green-soft); color:var(--green);}

/* ---------- 설명 리스트 ---------- */
.dl{display:grid; grid-template-columns:130px 1fr; gap:8px 14px; font-size:.88rem;}
.dl dt{color:var(--tx-soft); font-weight:600; font-size:.8rem; padding-top:2px;}
.dl dd{font-weight:500;}

/* ---------- 검산 합계 박스 ---------- */
.verify-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:10px;}
.verify-item{border:1px solid var(--line); border-radius:var(--r); padding:11px 14px; background:#fff;}
.verify-item .vi-l{font-size:.74rem; color:var(--tx-soft); font-weight:700;}
.verify-item .vi-n{font-size:1.1rem; font-weight:800; font-variant-numeric:tabular-nums; margin-top:2px;}
.verify-item.is-diff{border-color:#fca5a5; background:#fff5f5;}
.verify-item.is-ok{border-color:#a7f3d0; background:#f0fdf4;}

/* ---------- 유틸 ---------- */
.muted{color:var(--tx-soft);}
.faint{color:var(--tx-faint);}
.small{font-size:.8rem;}
.mono{font-family:ui-monospace,Consolas,monospace; font-size:.86em;}
.tx-red{color:var(--red);} .tx-green{color:var(--green);} .tx-amber{color:var(--amber);} .tx-blue{color:var(--brand);}
.fw7{font-weight:700;} .fw8{font-weight:800;}
.mt0{margin-top:0!important;} .mt8{margin-top:8px;} .mt12{margin-top:12px;} .mt16{margin-top:16px;} .mt24{margin-top:24px;}
.mb0{margin-bottom:0!important;} .mb8{margin-bottom:8px;} .mb12{margin-bottom:12px;} .mb16{margin-bottom:16px;}
.flex{display:flex; align-items:center; gap:10px;}
.flex-wrap{flex-wrap:wrap;}
.ml-auto{margin-left:auto;}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.w-full{width:100%;}
.hidden{display:none!important;}
.pointer{cursor:pointer;}
.note-banner{display:flex; gap:10px; align-items:flex-start; padding:12px 16px; border-radius:var(--r);
  background:var(--amber-soft); border:1px solid #fde68a; color:#92400e; font-size:.85rem; margin-bottom:16px;}
.note-banner i{margin-top:2px;}
.note-banner--info{background:var(--brand-soft); border-color:#bfdbfe; color:var(--brand-deep);}
.note-banner--danger{background:var(--red-soft); border-color:#fecaca; color:#991b1b;}

/* ---------- 페이지네이션 ---------- */
.pager{display:flex; gap:5px; justify-content:center; padding:14px;}
.pager a,.pager span{display:grid; place-items:center; min-width:30px; height:30px; padding:0 8px;
  border-radius:7px; font-size:.82rem; font-weight:600; color:var(--tx-soft); border:1px solid transparent;}
.pager a:hover{background:var(--gray-soft);}
.pager .is-now{background:var(--brand); color:#fff;}

/* ---------- 로그인 ---------- */
.login-wrap{min-height:100vh; display:flex; align-items:center; justify-content:center; background:
  radial-gradient(800px 400px at 80% -10%, rgba(37,99,235,.18), transparent 60%),
  radial-gradient(600px 350px at 10% 110%, rgba(13,148,136,.14), transparent 60%), var(--ink); padding:20px;}
.login-box{width:100%; max-width:380px; background:#fff; border-radius:18px; box-shadow:var(--shadow-lg); padding:36px 32px;}
.login-box__logo{display:flex; align-items:center; gap:11px; margin-bottom:8px;}
.login-box__logo .side__logo{width:38px; height:38px; font-size:19px; border-radius:11px;}
.login-box__logo b{font-size:1.15rem; letter-spacing:-.01em;}
.login-box__sub{font-size:.82rem; color:var(--tx-soft); margin-bottom:24px;}
.login-box .field{margin-bottom:14px;}
.login-err{background:var(--red-soft); color:#991b1b; border:1px solid #fecaca; border-radius:8px;
  padding:9px 12px; font-size:.82rem; font-weight:600; margin-bottom:14px;}

/* ---------- 반응형 ---------- */
@media (max-width: 1024px){
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .form-grid .span-2{grid-column:span 1;}
}
@media (max-width: 860px){
  .side{position:fixed; left:0; top:0; transform:translateX(-100%); transition:transform .2s ease; box-shadow:var(--shadow-lg);}
  .side.is-open{transform:none;}
  .topbar__menu{display:block;}
  .content{padding:16px;}
  .dl{grid-template-columns:104px 1fr;}
}
