
:root{
  --bg:#e8edf5;
  --bg-mid:#eef2f8;
  --surface:#ffffff;
  --surface-soft:#f8fafc;
  --surface-strong:#f1f5f9;
  --border:#cfd8e6;
  --border-soft:#e2e8f0;
  --text:#0f172a;
  --text-soft:#334155;
  --muted:#64748b;
  --primary:#2563eb;
  --primary-hover:#1d4ed8;
  --dark:#334155;
  --success:#16a34a;
  --warning:#d97706;
  --danger:#dc2626;
  --purple:#7c3aed;
  --shadow:0 1px 2px rgba(15,23,42,.04),0 8px 28px rgba(15,23,42,.07),0 24px 48px rgba(15,23,42,.05);
  --shadow-soft:0 4px 20px rgba(15,23,42,.06);
  --radius-xl:20px;
  --radius-lg:16px;
  --radius-md:12px;
  --radius-sm:10px;
  --input-h:48px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html,body{margin:0;padding:0}
body{
  font-family:"Pretendard Variable","Pretendard","Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",system-ui,sans-serif;
  font-size:15px;
  line-height:1.65;
  background:linear-gradient(165deg,var(--bg-mid) 0%,var(--bg) 45%,#f4f6fb 100%);
  color:var(--text);
  letter-spacing:-0.018em;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-hover)}
body > .wrap,.wrap{width:100%;max-width:none;margin:0;padding:24px}
@media (max-width:768px){body > .wrap,.wrap{padding:14px}}

.card,.topbox,.searchbox,.tablebox,.login-box,.form-box,.help-box{
  background:var(--surface);
  border:1px solid rgba(148,163,184,.22);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
}
.card,.topbox,.searchbox,.tablebox,.form-box{padding:22px 24px;margin-bottom:16px}
@media (max-width:768px){.card,.topbox,.searchbox,.tablebox,.form-box{padding:16px 18px}}
.card:last-child,.topbox:last-child,.searchbox:last-child,.tablebox:last-child{margin-bottom:0}
.mobile-scroll{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:4px;
}
.mobile-scroll::-webkit-scrollbar{height:10px}
.mobile-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}
.small,.desc,.meta,.count,.form-help,.help{font-size:14px;color:var(--muted)}
.count{font-weight:700}
.empty,.empty-box{
  padding:40px 20px;
  text-align:center;
  color:var(--muted);
  background:var(--surface-soft);
  border:1px dashed var(--border);
  border-radius:var(--radius-lg);
}
/* 테이블에서 colspan 한 칸 빈 목록: 셀은 항상 table-cell (관리자 상단 공통 스타일의 flex .empty와 충돌 방지) */
table tbody td.empty[colspan]{
  display:table-cell !important;
  width:auto !important;
  max-width:none;
  white-space:normal;
  vertical-align:middle;
}
.notice-box,.alert-box,.help-box,.warn,.error,.notice-ok{
  border-radius:var(--radius-lg);
  padding:14px 16px;
  margin-bottom:16px;
  font-size:15px;
}
.notice-box,.help-box{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}
.warn{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c}
.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}
.notice-ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}
.alert-recall-overdue{background:#fff1f2;border:1px solid #fecdd3;color:#be123c}
.alert-recall-today{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}
.alert-action{display:inline-flex;align-items:center;justify-content:center;margin-left:10px;height:36px;padding:0 13px;border-radius:999px;background:#fff;border:1px solid currentColor;color:inherit;font-weight:800}

h1,h2,h3{margin:0 0 10px;color:var(--text)}
.title{font-size:26px;font-weight:800;margin-bottom:8px;text-align:center;letter-spacing:-0.02em}
.section-title{
  margin:24px 0 12px;
  padding:0 0 0 14px;
  border-top:none;
  border-left:4px solid var(--primary);
  font-size:17px;
  font-weight:800;
  color:var(--text);
  line-height:1.35;
  letter-spacing:-0.02em;
}
.section-title:first-of-type{margin-top:8px}
.card > .section-title:first-child{margin-top:0}
.table-title{font-weight:800;margin-bottom:6px;font-size:15px;color:var(--text)}
.table-subtitle{margin-bottom:8px}
.current-parent{font-weight:700}.role-box{font-size:15px;color:var(--muted)}.filter-title{margin-bottom:10px;font-weight:800;color:var(--text)}
.top-links,.quick-links,.pagination{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pagination{margin-top:18px;justify-content:center}
.pagination a,.pagination strong{
  min-width:40px;height:40px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;font-size:14px;font-weight:800
}
.pagination a{background:#fff;border:1px solid var(--border);color:var(--text-soft)}
.pagination a:hover{background:var(--surface-soft)}
.pagination strong{background:var(--primary);color:#fff;border:1px solid var(--primary)}

form{margin:0}
.row,.form-row,.form-group{margin-bottom:16px}
label{display:block;margin-bottom:6px;font-size:13px;font-weight:800;color:var(--text-soft);letter-spacing:0.01em}
input[type="text"],input[type="password"],input[type="date"],input[type="datetime-local"],input[type="number"],select,textarea{
  width:100%;min-width:0;height:var(--input-h);padding:0 15px;border:1px solid var(--border);border-radius:13px;background:#fff;font-size:15px;color:var(--text);outline:none;transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
textarea{height:auto;min-height:124px;padding:13px 15px;resize:vertical}
input[type="file"]{width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:13px;background:#fff;font-size:14px}
input:focus,select:focus,textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.10)}
input[readonly]{background:var(--surface-soft)}
.grid-2,.search-grid,.search-inline,.inline-grid,.actions,.btn-group,.landing-admin-utils,.landing-admin-menu,.summary-grid,.tab-row,.searchform,.util,.toolbar-row,.history-actions{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
}
.grid-2 > *, .inline-grid > *{flex:1 1 calc(50% - 5px)}
.search-grid > *, .search-inline > *{flex:1 1 180px}
.actions{margin-top:18px}
@media (max-width:768px){.grid-2 > *, .inline-grid > *{flex-basis:100%}}

button,.btn,.btn-edit,.btn-back,.btn-delete,.btn-save,.btn-submit,.btn-reset,.nav,.tab-btn,.landing-admin-utils a,.landing-admin-menu a,.top-links a,.quick-links a,.btn-small{
  display:inline-flex;align-items:center;justify-content:center;height:40px;min-width:0;padding:0 14px;border-radius:11px;border:1px solid transparent;background:var(--dark);color:#fff;font-size:14px;font-weight:800;line-height:1;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all .15s ease;box-shadow:none;
}
button:hover,.btn:hover,.btn-edit:hover,.btn-back:hover,.btn-delete:hover,.btn-save:hover,.btn-submit:hover,.btn-reset:hover,.nav:hover,.tab-btn:hover,.landing-admin-utils a:hover,.landing-admin-menu a:hover,.top-links a:hover,.quick-links a:hover,.btn-small:hover{transform:translateY(-1px);opacity:.98;color:#fff;box-shadow:var(--shadow-soft)}
.btn,.btn-dark{background:#475569}
.btn-blue,.btn-edit,.btn-save,.btn-submit,.btn-small{background:var(--primary)}
.btn-green{background:var(--success)}
.btn-purple{background:var(--purple)}
.btn-red,.btn-delete{background:var(--danger)}
.btn-black{background:var(--dark)}
.btn-reset,.btn-back,.nav,.quick-links a{background:#fff;color:var(--text);border-color:var(--border)}
.btn-reset:hover,.btn-back:hover,.nav:hover,.quick-links a:hover{color:var(--text);background:var(--surface-soft)}
.btn-disabled{background:#94a3b8 !important;border-color:#94a3b8 !important;color:#fff !important;cursor:not-allowed !important;transform:none !important;box-shadow:none !important}
.submit-btn{min-width:140px}
.action-form,.inline-form{display:inline-block;margin:0}
.btn-group{align-items:stretch;gap:8px}
.btn-group > a,.btn-group > button,.btn-group > form{margin:0}
.btn-group > form > button{width:100%}
.btn-group > a,.btn-group > button,.btn-group > form{flex:0 0 auto}
.btn-group.btn-group-fluid > a,.btn-group.btn-group-fluid > button,.btn-group.btn-group-fluid > form{flex:1 1 120px}

.landing-admin-top-wrap{margin-bottom:22px}
.landing-admin-top-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:14px}
.landing-admin-title{font-size:26px;font-weight:800;line-height:1.45;color:var(--text)}
.landing-admin-title .subtle{font-weight:500;color:var(--muted)}
.landing-admin-title .user{font-weight:800}
.landing-admin-utils{justify-content:flex-end}
.landing-admin-utils a{background:#fff;color:var(--text);border-color:var(--border);height:40px}
.landing-admin-utils a:hover{background:var(--surface-soft);color:var(--text)}
.landing-admin-menu a{height:46px;min-width:124px;border-radius:13px;background:#fff;color:var(--text);border-color:var(--border);font-size:15px}
.landing-admin-menu a.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 8px 20px rgba(37,99,235,.15)}
@media (max-width:700px){.landing-admin-top-head{flex-direction:column;align-items:flex-start}.landing-admin-utils{justify-content:flex-start}.landing-admin-menu a,.landing-admin-utils a{flex:1 1 calc(50% - 5px)}}

.summary-grid{margin-bottom:18px;align-items:stretch}
.summary-item,.item{flex:1 1 180px;padding:19px;border-radius:17px;background:var(--surface-soft);border:1px solid var(--border);font-size:15px;font-weight:700;color:var(--text)}
.summary-item strong,.item strong{display:block;margin-top:6px;font-size:26px;font-weight:800;letter-spacing:-0.02em}
.summary-item.blue{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.summary-item.green{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}
.summary-item.orange{background:#fff7ed;border-color:#fed7aa;color:#c2410c}
.summary-item.gray{background:#f8fafc;border-color:#e2e8f0;color:#334155}

.role-box,.info,.meta{margin-bottom:14px}
.info-box{padding:17px;border:1px solid var(--border);border-radius:14px;background:#fff}
.info-label{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:6px}
.info-value{font-size:15px;font-weight:700;color:var(--text);word-break:break-word}

.tab-row{margin:18px 0}
.tab-btn{background:#fff;color:var(--text);border-color:var(--border)}
.tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}

.search-box,.searchbox{padding:20px;border:1px solid var(--border);border-radius:17px;background:#f8fafc;margin-bottom:18px}
.searchform input,.searchform select,.search-box input,.search-box select{background:#fff}
.search-inline > button,.search-inline > a{flex:0 0 auto}

.admin-table,table{width:100%;border-collapse:separate;border-spacing:0}
.admin-table th,.admin-table td,table th,table td{padding:12px 14px;border-bottom:1px solid var(--border-soft);text-align:left;vertical-align:middle;font-size:14px;background:#fff}
.admin-table thead th,table thead th{position:sticky;top:0;z-index:1;background:linear-gradient(180deg,#f8fafc 0%,#f1f5f9 100%);font-size:12px;font-weight:800;color:#475569;text-transform:none;letter-spacing:0.02em;white-space:nowrap;border-top:1px solid var(--border-soft);border-bottom:1px solid #cbd5e1}
.admin-table tr td:first-child,.admin-table tr th:first-child,table tr td:first-child,table tr th:first-child{border-left:1px solid var(--border)}
.admin-table tr td:last-child,.admin-table tr th:last-child,table tr td:last-child,table tr th:last-child{border-right:1px solid var(--border)}
.admin-table thead tr:first-child th:first-child,table thead tr:first-child th:first-child{border-top-left-radius:14px}
.admin-table thead tr:first-child th:last-child,table thead tr:first-child th:last-child{border-top-right-radius:14px}
.admin-table tbody tr:last-child td:first-child,table tbody tr:last-child td:first-child{border-bottom-left-radius:14px}
.admin-table tbody tr:last-child td:last-child,table tbody tr:last-child td:last-child{border-bottom-right-radius:14px}
.admin-table tbody tr:hover td,table tbody tr:hover td{background:#f7f9fc}
.num,.rate{text-align:right;font-variant-numeric:tabular-nums}
.code,.path-box{font-family:Consolas,Monaco,monospace}
.url-input{width:100%;height:42px;padding:0 12px;border:1px solid var(--border);background:#f8fafc;border-radius:10px;font-size:13px;color:var(--text-soft)}
.badge,.history-badge,.rank-badge,.contact-badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800;line-height:1;background:#eef2ff;color:#3730a3}
.badge-working{background:#eff6ff;color:#1d4ed8}
.badge-recall{background:#fff7ed;color:#c2410c}
.badge-drop{background:#fef2f2;color:#b91c1c}
.badge-done{background:#f0fdf4;color:#15803d}
.badge-new{background:#f3f4f6;color:#4b5563}
.contact-badge-custom{background:#dbeafe;color:#1d4ed8}
.contact-badge-default{background:#f1f5f9;color:#64748b}
.status-active,.status-stop{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800;line-height:1}
.status-active{background:#dcfce7;color:#15803d}
.status-stop{background:#fee2e2;color:#b91c1c}
.rank-badge{min-width:32px;background:#e2e8f0;color:#334155}
.history-item{padding:16px;border:1px solid var(--border);border-radius:16px;background:#fff}
.history-item + .history-item{margin-top:12px}
.history-meta,.history-line{font-size:14px;color:var(--muted);margin-bottom:8px}
.history-body{font-size:15px;color:var(--text);line-height:1.7}

.pages-table th:nth-child(1),.pages-table td:nth-child(1){width:70px}
.pages-table th:nth-child(2),.pages-table td:nth-child(2){width:120px}
.pages-table th:nth-child(3),.pages-table td:nth-child(3){min-width:140px}
.pages-table th:nth-child(4),.pages-table td:nth-child(4){min-width:130px}
.pages-table th:nth-child(5),.pages-table td:nth-child(5){min-width:280px}
.pages-table th:nth-child(6),.pages-table td:nth-child(6){min-width:130px}
.pages-table th:nth-child(7),.pages-table td:nth-child(7){width:95px}
.pages-table th:nth-child(8),.pages-table td:nth-child(8){min-width:145px}
.pages-table th:nth-child(9),.pages-table td:nth-child(9){min-width:420px}
.stats-table th:nth-child(1),.stats-table td:nth-child(1){width:72px}
.stats-table th:nth-child(2),.stats-table td:nth-child(2){min-width:120px}
.stats-table th:nth-child(3),.stats-table td:nth-child(3){min-width:150px}
.stats-table th:nth-child(4),.stats-table td:nth-child(4){min-width:220px}
.stats-table th:nth-child(5),.stats-table td:nth-child(5),.stats-table th:nth-child(6),.stats-table td:nth-child(6),.stats-table th:nth-child(7),.stats-table td:nth-child(7),.stats-table th:nth-child(8),.stats-table td:nth-child(8){min-width:120px}
.stats-table th:nth-child(9),.stats-table td:nth-child(9){width:90px}
.stats-table th:nth-child(10),.stats-table td:nth-child(10),.stats-table th:nth-child(11),.stats-table td:nth-child(11),.stats-table th:nth-child(12),.stats-table td:nth-child(12){min-width:100px}
.rankings-table th:nth-child(1),.rankings-table td:nth-child(1){width:80px;text-align:center}
.rankings-table th:nth-child(2),.rankings-table td:nth-child(2),.rankings-table th:nth-child(3),.rankings-table td:nth-child(3),.rankings-table th:nth-child(4),.rankings-table td:nth-child(4){min-width:130px}
.rankings-table th:nth-child(n+5),.rankings-table td:nth-child(n+5){min-width:100px}
.admin-users-table th:nth-child(1),.admin-users-table td:nth-child(1){min-width:140px}
.admin-users-table th:nth-child(2),.admin-users-table td:nth-child(2){min-width:120px}
.admin-users-table th:nth-child(3),.admin-users-table td:nth-child(3){min-width:140px}
.admin-users-table th:nth-child(4),.admin-users-table td:nth-child(4){min-width:120px}
.admin-users-table th:nth-child(5),.admin-users-table td:nth-child(5){min-width:300px}
.leads-table th:nth-child(1),.leads-table td:nth-child(1){width:84px}
.leads-table th:nth-child(2),.leads-table td:nth-child(2),.leads-table th:nth-child(3),.leads-table td:nth-child(3),.leads-table th:nth-child(4),.leads-table td:nth-child(4),.leads-table th:nth-child(5),.leads-table td:nth-child(5),.leads-table th:nth-child(6),.leads-table td:nth-child(6){min-width:120px}
.leads-table th:nth-child(7),.leads-table td:nth-child(7){min-width:340px}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-box{width:100%;max-width:520px;padding:34px}
.login-box .title{margin-bottom:18px}

@media (max-width:1024px){
  body{font-size:15px}
  .landing-admin-title{font-size:22px}
  .summary-item strong,.item strong{font-size:22px}
}
@media (max-width:768px){
  body{font-size:15px;line-height:1.65}
  .title{font-size:25px}
  .landing-admin-title{font-size:22px}
  .search-inline > *, .search-grid > *{flex-basis:100%}
  .btn-group{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}
  .btn-group > a,.btn-group > button,.btn-group > form{width:100%}
  .btn-group > form > button{width:100%}
  .pages-table th:nth-child(9),.pages-table td:nth-child(9){min-width:300px}
}
@media (max-width:520px){
  .btn-group{grid-template-columns:1fr}
  .landing-admin-menu a,.landing-admin-utils a{flex-basis:100%}
  .summary-item,.item{flex-basis:100%}
}


/* 재통화 입력영역 확대 */
.recall-box{min-width:320px;margin-top:10px}
.recall-grid{display:grid;grid-template-columns:minmax(180px,1fr) minmax(140px,180px);gap:12px;margin-bottom:10px}
.recall-grid input[type="date"],
.recall-grid input[type="time"]{width:100%;height:48px;padding:0 16px;font-size:16px;font-weight:700;border-radius:12px}
.recall-box textarea{min-height:96px;font-size:15px;line-height:1.6}

/* 상담 목록 행 강조 */
.row-overdue td{background:#fff4f4 !important}
.row-today td{background:#fffaf0 !important}
.row-status-new td{background:#f8fafc}
.row-status-working td{background:#f8fbff}
.row-status-recall td{background:#fffdf7}
.row-status-done td{background:#f4fbf5}
.row-status-drop td{background:#fafafa}
.row-status-new:hover td,.row-status-working:hover td,.row-status-recall:hover td,.row-status-done:hover td,.row-status-drop:hover td{filter:brightness(.99)}

/* 구분선 */
.tablebox,.card,.topbox,.searchbox,.form-box,.help-box,.login-box{border-color:var(--border-soft)}
.admin-table tbody tr + tr td, table tbody tr + tr td{border-top:1px solid #f1f5f9}
.section-title{border-top:none}
.info-box,.history-item,.search-box,.empty,.empty-box{border-color:var(--border)}

@media (max-width:768px){
  .recall-grid{grid-template-columns:1fr}
}

/* 은은한 세로 구분선 */
table td + td,
table th + th{
  border-left:1px solid #e6ebf2;
}


/* CRM 끝판 UI 보강 */
.kpi-sub{display:block;margin-top:6px;font-size:12px;color:var(--muted);font-weight:700}
.status-legend{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 16px}
.status-legend .legend-item{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:#fff;font-size:13px;font-weight:700;color:var(--text-soft)}
.status-dot{width:10px;height:10px;border-radius:999px;display:inline-block}
.status-dot-new{background:#64748b}
.status-dot-working{background:#2563eb}
.status-dot-recall{background:#f59e0b}
.status-dot-done{background:#16a34a}
.status-dot-drop{background:#94a3b8}
.leads-table-wrap{overflow:auto;border-radius:16px}
.leads-table th,.leads-table td{white-space:nowrap}
.leads-table td.memo-cell,.leads-table td.manage-cell{white-space:normal}
.leads-table td.schedule-cell{white-space:normal;min-width:170px}
.leads-table .sticky-col{position:sticky;background:inherit;z-index:2}
.leads-table thead .sticky-col{z-index:4;background:#f1f4f9}
.leads-table .sticky-id{left:0;min-width:82px}
.leads-table .sticky-name{left:82px;min-width:120px}
.leads-table tbody tr:hover .sticky-col{background:#f7f9fc}
.quick-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:10px 0}
.quick-btn{height:36px;padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#fff;font-size:13px;font-weight:800;color:var(--text);cursor:pointer}
.quick-btn:hover{filter:brightness(.98)}
.quick-btn.new{background:#f8fafc;border-color:#cbd5e1;color:#475569}
.quick-btn.working{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.quick-btn.recall{background:#fff7ed;border-color:#fdba74;color:#c2410c}
.quick-btn.done{background:#f0fdf4;border-color:#86efac;color:#15803d}
.quick-btn.drop{background:#f8fafc;border-color:#d1d5db;color:#6b7280}
.quick-actions.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.meta-stack{display:flex;flex-direction:column;gap:4px}
.meta-sub{font-size:12px;color:var(--muted);font-weight:700}
.schedule-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;line-height:1.2;border:1px solid transparent}
.schedule-badge.overdue{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.schedule-badge.today{background:#fff7ed;color:#c2410c;border-color:#fdba74}
.schedule-badge.normal{background:#f8fafc;color:#475569;border-color:#cbd5e1}
.schedule-badge.empty{background:#f8fafc;color:#94a3b8;border-color:#e2e8f0}
.manage-panel{display:flex;flex-direction:column;gap:8px}
.manage-panel .btn-save{width:100%;height:40px}
.small-help{font-size:12px;color:var(--muted);font-weight:700}
.row-overdue td{box-shadow:inset 0 1px 0 #fecaca,inset 0 -1px 0 #fecaca}
.row-today td{box-shadow:inset 0 1px 0 #fed7aa,inset 0 -1px 0 #fed7aa}
@media (max-width:1200px){.leads-table .sticky-name{position:static}.leads-table .sticky-id{position:static}}
@media (max-width:768px){.quick-actions,.quick-actions.two{grid-template-columns:1fr}}


/* charts / reports */
.mini-chart-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin:16px 0 18px;
}
.mini-chart-card{
  background:#fff;
  border:1px solid #dce4ef;
  border-radius:16px;
  padding:16px;
}
.mini-chart-card h3{
  margin:0 0 12px;
  font-size:18px;
}
.mini-chart-row{
  margin-bottom:10px;
}
.mini-chart-head{
  display:flex;
  justify-content:space-between;
  gap:8px;
  margin-bottom:6px;
  font-size:14px;
}
.mini-chart-bar{
  height:10px;
  background:#eef3f9;
  border-radius:999px;
  overflow:hidden;
}
.mini-chart-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#3b82f6,#60a5fa);
}
.mini-chart-fill.green{ background:linear-gradient(90deg,#16a34a,#4ade80); }
.mini-chart-fill.orange{ background:linear-gradient(90deg,#ea580c,#fb923c); }
.report-box{
  margin:16px 0 18px;
  background:#fff;
  border:1px solid #dce4ef;
  border-radius:16px;
  padding:16px;
}
.report-box textarea{
  min-height:160px;
  resize:vertical;
  font-size:14px;
  line-height:1.7;
}
.report-tools{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
  align-items:center;
  flex-wrap:wrap;
}
.report-tools button{
  height:38px;
  border:none;
  border-radius:10px;
  background:#111827;
  color:#fff;
  padding:0 14px;
  font-weight:700;
  cursor:pointer;
}
@media (max-width: 900px){
  .mini-chart-grid{
    grid-template-columns:1fr;
  }
}


/* 일정 추가/수정 화면 정리 */
.schedule-editor-page{display:flex;flex-direction:column;gap:16px}
.schedule-editor-card{padding:22px}
.schedule-editor-form{margin:0}
.schedule-editor-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border-soft)}
.schedule-editor-title{font-size:24px;font-weight:900;color:var(--text);line-height:1.2}
.schedule-editor-desc{margin-top:6px;font-size:13px;line-height:1.65;color:var(--muted);max-width:760px}
.schedule-editor-date-badge{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:12px;font-weight:800;white-space:nowrap}
.schedule-editor-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);gap:16px;align-items:start}
.schedule-editor-main{display:flex;flex-direction:column;gap:2px}
.schedule-editor-side{display:flex;flex-direction:column;gap:12px}
.schedule-side-card{padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}
.schedule-side-title{font-size:14px;font-weight:900;color:var(--text);margin-bottom:8px}
.schedule-side-list{margin:0;padding-left:18px;color:var(--text-soft);font-size:13px;line-height:1.7}
.schedule-side-list li+li{margin-top:4px}
.schedule-time-grid{display:grid;grid-template-columns:220px 1fr 1fr;gap:12px}
.schedule-check-inline{display:flex;align-items:center;gap:8px;min-height:50px;padding:0 14px;border:1px solid var(--border);border-radius:13px;background:#f8fafc;color:var(--text-soft);font-weight:800}
.schedule-check-inline input[type="checkbox"]{width:18px;height:18px;margin:0}
.schedule-member-box{padding:14px;border:1px solid var(--border);border-radius:16px;background:#fff}
.schedule-member-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.schedule-member-item{display:flex;align-items:center;gap:10px;min-height:48px;padding:0 14px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;font-size:13px;font-weight:800;color:#334155}
.schedule-member-item input{width:18px;height:18px;margin:0;flex:0 0 18px}
.schedule-inline-help{margin-top:8px;font-size:12px;line-height:1.6;color:var(--muted)}
.schedule-editor-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:8px;padding-top:16px;border-top:1px solid var(--border-soft)}
.schedule-editor-actions .btn{min-width:120px}
@media (max-width:1100px){
  .schedule-editor-grid{grid-template-columns:1fr}
}
@media (max-width:900px){
  .schedule-time-grid{grid-template-columns:1fr}
  .schedule-member-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .schedule-editor-card{padding:16px}
  .schedule-editor-title{font-size:21px}
  .schedule-editor-actions{justify-content:stretch}
  .schedule-editor-actions .btn{width:100%}
}

/* 랜딩 추가·수정: 화면 고도화 */
.landing-editor-page{
  background:
    radial-gradient(900px 380px at 100% 0%, rgba(99,102,241,.08), transparent 55%),
    radial-gradient(800px 360px at 0% 20%, rgba(37,99,235,.07), transparent 50%),
    linear-gradient(180deg,#eef2f8 0%,#f4f7fc 100%);
}
.landing-editor-card{
  max-width:1180px;
  margin:0 auto;
  padding:26px 26px 24px;
  border-radius:22px;
  background:linear-gradient(165deg,#ffffff 0%,#fafbff 55%,#f5f8ff 100%);
  border:1px solid rgba(148,163,184,.2);
  box-shadow:0 2px 4px rgba(15,23,42,.03),0 16px 40px rgba(15,23,42,.08);
}
.landing-editor-policy-note{
  margin:0 0 16px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);
  color:#475569;
  font-size:13px;
  line-height:1.65;
}
.landing-editor-policy-note strong{color:#1e293b}
.landing-editor-shell{margin:0}
.landing-editor-nav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.landing-editor-nav a,
.landing-editor-nav span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:0.01em;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text-soft);
}
.landing-editor-nav .active{
  border-color:#bfdbfe;
  background:#eff6ff;
  color:#1d4ed8;
}
.landing-editor-subhelp{
  margin:0 0 16px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid #dbeafe;
  background:#f0f7ff;
  color:#1e3a8a;
  font-size:13px;
  line-height:1.65;
}
.landing-editor-panel{
  background:#fff;
  border:1px solid #e5edf7;
  border-radius:16px;
  padding:16px;
  box-shadow:0 8px 20px rgba(15,23,42,.04);
}
.landing-editor-panel .section-title{
  margin:2px 0 14px;
}
.landing-editor-panel .row{
  margin-bottom:12px;
}
.landing-editor-panel .row:last-child{
  margin-bottom:0;
}
.landing-editor-section-note{
  margin:-4px 0 12px;
  padding:10px 12px;
  border-radius:10px;
  background:#f8fafc;
  border:1px solid var(--border-soft);
  color:var(--muted);
  font-size:12px;
  line-height:1.6;
}
.landing-editor-panel .check-inline{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:42px;
  margin:0;
  padding:0 12px;
  border:1px solid var(--border-soft);
  border-radius:11px;
  background:#f8fafc;
  font-size:13px;
  font-weight:700;
  color:var(--text-soft);
}
.landing-editor-panel .check-inline input[type="checkbox"]{
  width:18px;
  height:18px;
  margin:0;
}
.landing-editor-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
  margin-top:6px;
  padding-top:14px;
  border-top:1px solid var(--border-soft);
}
.landing-editor-actions .btn{min-width:120px}
.landing-image-upload-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 12px;
}
.landing-image-upload-item{
  margin:0 !important;
}
.landing-image-upload-item input[type="file"]{
  height:42px;
  padding:8px 10px;
  border-radius:11px;
}

/* 랜딩 추가·수정: 단일 컬럼 정렬 */
.landing-editor-card .landing-editor-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  align-items:start;
}
.landing-editor-panel.landing-editor-sticky{
  position:static;
}
.landing-editor-panel.landing-form-fields-span{
  grid-column:1 / -1;
  margin:0;
  padding-top:14px;
  border-top:1px solid var(--border-soft);
}
.landing-editor-panel.landing-editor-actions-span{
  grid-column:1 / -1;
  margin:0;
  padding-top:8px;
}
.landing-editor-panel.landing-editor-actions-span .landing-editor-actions{
  margin-top:0;
}
.landing-editor-panel .section-title:not(:first-child){
  margin-top:20px;
  padding-top:14px;
  border-top:1px dashed #dbe4f2;
}
.landing-form-fields-card{
  background:var(--surface-soft);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:20px 22px 22px;
  margin-top:4px;
}
.landing-form-fields-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.landing-form-fields-title{
  margin:0 0 6px;
  font-size:17px;
  font-weight:900;
  color:var(--text);
  letter-spacing:-0.02em;
}
.landing-form-fields-lead{
  margin:0;
  max-width:52em;
  font-size:13px;
  line-height:1.65;
  color:var(--muted);
}
.landing-form-fields-add-btn{flex-shrink:0}
.landing-form-fields-tools{
  margin-bottom:12px;
}
.landing-form-fields-hint{
  font-size:12px;
  color:var(--muted);
  line-height:1.55;
}
.landing-form-fields-table-wrap{
  border-radius:var(--radius-md);
  border:1px solid var(--border-soft);
  background:#fff;
  overflow:auto;
}
.landing-field-table{
  width:100%;
  min-width:920px;
  border-collapse:collapse;
  font-size:13px;
}
.landing-field-table th{
  padding:10px 12px;
  text-align:left;
  font-size:11px;
  font-weight:800;
  color:var(--text-soft);
  text-transform:uppercase;
  letter-spacing:0.04em;
  background:#f8fafc;
  border-bottom:1px solid var(--border-soft);
  white-space:nowrap;
}
.landing-field-table td{
  padding:12px;
  vertical-align:top;
  border-bottom:1px solid #f1f5f9;
  background:#fff;
}
.landing-field-table tbody tr:last-child td{border-bottom:none}
.landing-field-table .col-sort{width:72px}
.landing-field-table .col-label{min-width:140px}
.landing-field-table .col-key{min-width:120px}
.landing-field-table .col-type{width:130px}
.landing-field-table .col-opt{min-width:200px}
.landing-field-table .col-check{width:52px;text-align:center}
.landing-field-table .col-act{width:88px}
.landing-field-table input[type="text"],
.landing-field-table input[type="number"],
.landing-field-table select,
.landing-field-table textarea{
  width:100%;
  box-sizing:border-box;
  margin:0;
}
.landing-field-table textarea{
  min-height:72px;
  resize:vertical;
  font-size:13px;
  line-height:1.5;
}
.landing-field-sort{
  max-width:64px;
  text-align:center;
}
.landing-field-key-hint{
  display:block;
  margin-top:4px;
  font-size:11px;
  color:var(--primary);
  font-weight:700;
}
.landing-field-table .compact-check input{width:18px;height:18px;margin:0}
.landing-field-table .field-remove-btn{
  min-height:36px;
  padding:0 10px;
  font-size:12px;
}
@media (max-width:1100px){
  .landing-image-upload-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .landing-editor-card .landing-editor-grid{
    grid-template-columns:1fr;
  }
  .landing-editor-panel.landing-editor-sticky{
    position:static;
  }
}
@media (max-width:640px){
  .landing-editor-card{
    padding:14px;
  }
  .landing-editor-panel{
    padding:14px;
  }
  .landing-image-upload-grid{
    grid-template-columns:1fr;
  }
  .landing-editor-actions .btn{
    width:100%;
  }
}

/* ---- Touch / small screens (관리자 공통) ---- */
@media (max-width:720px){
  input[type="text"],input[type="password"],input[type="email"],input[type="tel"],
  input[type="number"],input[type="date"],input[type="datetime-local"],input[type="search"],select,textarea{
    font-size:16px;
  }
  button,.btn,.btn-edit,.btn-back,.btn-delete,.btn-save,.btn-submit,.btn-reset,.nav,.tab-btn,
  .landing-admin-utils a,.landing-admin-menu a,.top-links a,.quick-links a,.btn-small{
    min-height:44px;
    padding:0 16px;
  }
  .pagination a,.pagination strong{min-width:44px;height:44px;}
}
@media (max-width:480px){
  .title{font-size:22px}
  .section-title{font-size:16px;padding-left:12px}
  .admin-table th,.admin-table td,table th,table td{padding:10px 12px;font-size:13px}
}

/* 랜딩 자유 HTML 블록 편집 */
textarea.wide-html{
  font-family:ui-monospace,SFMono-Regular,Consolas,"Liberation Mono",Menlo,monospace;
  font-size:13px;
  line-height:1.55;
}
.landing-html-examples{
  margin-top:12px;
  padding:14px 16px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:12px;
}
.landing-html-examples .examples-title{
  margin:0 0 10px;
  font-weight:800;
  font-size:14px;
  color:#334155;
}
.landing-html-examples details{margin-bottom:10px;}
.landing-html-examples summary{cursor:pointer;font-weight:700;color:#2563eb;}
.landing-html-examples .html-sample{
  display:block;
  margin:8px 0;
  padding:10px 12px;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:8px;
  overflow-x:auto;
  font-size:12px;
  line-height:1.45;
  white-space:pre-wrap;
}
.landing-html-examples .btn-copy-sample{margin-top:4px;}
