:root {
  --o50:#FFF4EC;--o100:#FFE0C2;--o200:#FFBF80;
  --o400:#F07820;--o500:#D96010;--o600:#B84D08;--o800:#7A2F02;
  --bg:#f8f9fa;--white:#ffffff;--border:#e9ecef;
  --text:#212529;--muted:#6c757d;
  --green:#3B6D11;--green-bg:#EAF3DE;
  --red:#A32D2D;--red-bg:#FCEBEB;
  --purple:#534AB7;--purple-bg:#EEEDFE;
  --teal:#0F6E56;--teal-bg:#E1F5EE;
  --radius:8px;--radius-lg:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;color:var(--text);background:var(--bg);min-height:100vh}
a{color:inherit;text-decoration:none}
input,select,textarea,button{font-family:inherit;font-size:14px}
input,select{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);width:100%;transition:border-color .15s}
input:focus,select:focus{outline:none;border-color:var(--o400)}
textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);resize:vertical;min-height:56px;line-height:1.5}
textarea:focus{outline:none;border-color:var(--o400)}

/* ── Layout ── */
#app{min-height:100vh}
.topbar{background:var(--o400);color:#fff;height:52px;display:flex;align-items:center;padding:0 20px;gap:16px;position:sticky;top:0;z-index:100}
.topbar-logo{font-size:15px;font-weight:600;flex:1}
.topbar-logo span{font-size:11px;opacity:.8;margin-left:6px;font-weight:400}
.topbar-user{display:flex;align-items:center;gap:10px;font-size:13px}
.topbar-user button{background:rgba(255,255,255,.2);border:none;color:#fff;padding:5px 12px;border-radius:20px;cursor:pointer;font-size:12px}
.topbar-user button:hover{background:rgba(255,255,255,.35)}

.nav-tabs{display:flex;border-bottom:2px solid var(--o100);background:var(--white);padding:0 20px}
.ntb{background:none;border:none;padding:12px 16px;font-size:14px;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:color .15s;position:relative}
.ntb:hover{color:var(--o500)}
.ntb.active{color:var(--o500);border-bottom-color:var(--o400);font-weight:500}
.ntb .badge{background:var(--o400);color:#fff;font-size:10px;padding:1px 5px;border-radius:10px;margin-left:5px}

.main{padding:20px;max-width:900px;margin:0 auto}

/* ── Cards ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:14px}
.card-header{background:var(--o400);border-radius:var(--radius) var(--radius) 0 0;margin:-20px -20px 18px;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}
.card-header-t{font-size:14px;font-weight:600;color:#fff}
.card-header-s{font-size:11px;color:rgba(255,255,255,.8);margin-top:2px}

/* ── Flow Steps ── */
.flow{display:flex;align-items:center;margin-bottom:20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px}
.fstep{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:72px}
.fcirc{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid var(--border);background:var(--bg);color:var(--muted)}
.fcirc.done{background:var(--o400);color:#fff;border-color:var(--o400)}
.fcirc.cur{border-color:var(--o400);color:var(--o800)}
.fcirc.mid{background:var(--teal-bg);color:var(--teal);border-color:var(--teal)}
.fcirc.fin{background:var(--purple-bg);color:var(--purple);border-color:var(--purple)}
.flabel{font-size:10px;color:var(--muted);text-align:center;line-height:1.3;white-space:pre-line}
.farrow{flex:1;height:1px;background:var(--border);min-width:12px;margin-top:-16px}

/* ── Badges ── */
.bd{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500;white-space:nowrap}
.bd-draft{background:var(--o50);color:var(--o800)}
.bd-pending{background:var(--o100);color:var(--o800)}
.bd-approved{background:var(--green-bg);color:var(--green)}
.bd-rejected{background:var(--red-bg);color:var(--red)}
.bd-fb{background:var(--teal-bg);color:var(--teal)}
.bd-final{background:var(--purple-bg);color:var(--purple)}
.bd-locked{background:#2C2C2A;color:#D3D1C7}
.bd-master{background:var(--purple-bg);color:var(--purple)}
.bd-admin{background:var(--teal-bg);color:var(--teal)}
.bd-user{background:var(--o50);color:var(--o800)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:opacity .15s}
.btn:hover{opacity:.88}.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--o400);color:#fff}
.btn-ghost{background:none;border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--o50);opacity:1}
.btn-success{background:var(--green);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-teal{background:var(--teal);color:#fff}
.btn-purple{background:var(--purple);color:#fff}
.btn-sm{padding:4px 10px;font-size:12px}
.abar{display:flex;gap:8px;justify-content:flex-end;margin-top:14px;flex-wrap:wrap}

/* ── Alerts ── */
.alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:12px;border:1px solid;line-height:1.6}
.alert-orange{background:var(--o50);color:var(--o800);border-color:var(--o200)}
.alert-green{background:var(--green-bg);color:var(--green);border-color:#C0DD97}
.alert-red{background:var(--red-bg);color:var(--red);border-color:#F7C1C1}
.alert-teal{background:var(--teal-bg);color:var(--teal);border-color:#9FE1CB}
.alert-purple{background:var(--purple-bg);color:var(--purple);border-color:#AFA9EC}

/* ── Form rows ── */
.form-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.form-group{flex:1;min-width:130px}
.form-group label{display:block;font-size:12px;color:var(--o600);font-weight:500;margin-bottom:5px}
.field-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--o50)}
.field-row:last-child{border-bottom:none}

/* ── Category goals ── */
.cat-block{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden}
.cat-hd{padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.cat-title{font-size:13px;font-weight:600;padding:2px 8px;border-radius:12px}
.goal-row{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--o50)}
.goal-row:last-child{border-bottom:none}
.goal-num{width:22px;height:22px;border-radius:50%;background:var(--o100);font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;color:var(--o800);flex-shrink:0;margin-top:2px}
.goal-inputs{flex:1;display:flex;flex-direction:column;gap:5px}
.goal-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.goal-meta input[type=number]{width:54px;height:30px;font-size:12px}
.goal-meta input[type=text]{height:30px;font-size:12px;flex:1;min-width:100px}
.goal-name{height:32px;font-size:13px;font-weight:500}

/* ── Stars ── */
.stars{display:flex;gap:2px;align-items:center}
.star{font-size:18px;cursor:pointer;color:#ddd;transition:color .1s,transform .1s;line-height:1}
.star.on{color:var(--o400)}
.star:hover{transform:scale(1.2)}
.star-lbl{font-size:12px;font-weight:500;color:var(--o800);min-width:40px}

/* ── Tables ── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;padding:8px 12px;background:var(--o50);color:var(--o800);font-weight:500;border-bottom:1px solid var(--o100)}
.tbl td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--o50)}

/* ── User list rows ── */
.user-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.user-row:last-child{border-bottom:none}
.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}

/* ── Period picker ── */
.period-pick{display:flex;gap:8px;margin-bottom:12px}
.popt{flex:1;padding:10px 8px;border-radius:var(--radius);border:1.5px solid var(--border);cursor:pointer;text-align:center;transition:all .15s}
.popt:hover{border-color:var(--o200)}
.popt.sel{background:var(--o400);border-color:var(--o400)}
.popt .pt{font-size:14px;font-weight:600;color:var(--o800)}
.popt.sel .pt{color:#fff}
.popt .ps{font-size:11px;color:var(--muted);margin-top:2px}
.popt.sel .ps{color:rgba(255,255,255,.8)}
.sub-periods{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.spopt{padding:5px 12px;border-radius:20px;border:1px solid var(--border);font-size:12px;cursor:pointer;transition:all .14s;color:var(--muted)}
.spopt:hover{border-color:var(--o200)}
.spopt.sel{background:var(--o100);border-color:var(--o400);color:var(--o800);font-weight:500}

/* ── Weight indicator ── */
.wt-ok{background:var(--o400);color:#fff;font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}
.wt-warn{background:var(--o100);color:var(--o800);font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}
.wt-err{background:var(--red-bg);color:var(--red);font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}

/* ── Grade ── */
.grade{display:inline-block;padding:3px 12px;border-radius:20px;font-size:13px;font-weight:600}
.grade-S{background:var(--teal-bg);color:var(--teal)}
.grade-A{background:var(--green-bg);color:var(--green)}
.grade-B{background:var(--o100);color:var(--o800)}
.grade-C{background:#FAEEDA;color:#633806}
.grade-D{background:var(--red-bg);color:var(--red)}

/* ── Bar chart ── */
.bar-row{margin-bottom:8px}
.bar-label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:3px}
.bar-track{background:var(--bg);border-radius:6px;height:16px;overflow:hidden;border:1px solid var(--border)}
.bar-fill{height:100%;background:var(--o400);border-radius:6px;transition:width .4s}

/* ── Login ── */
.login-wrap{max-width:420px;margin:60px auto;background:var(--white);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.login-header{background:var(--o400);padding:28px;text-align:center}
.login-logo{width:52px;height:52px;background:rgba(255,255,255,.2);border-radius:12px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}
.login-title{font-size:17px;font-weight:700;color:#fff}
.login-sub{font-size:12px;color:rgba(255,255,255,.8);margin-top:4px}
.login-body{padding:28px}
.login-hint{background:var(--o50);border-radius:var(--radius);padding:12px;margin-top:16px;font-size:12px;color:var(--o800);line-height:1.8}

/* ── Org tree ── */
.org-node{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:6px;background:var(--white)}
.org-children{margin-left:28px;border-left:2px solid var(--o200);padding-left:12px;margin-top:6px}

/* ── Feedback entry ── */
.fb-entry{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:8px}

/* 등급 선택 카드 호버 */
.fin-grade-card:hover {
  border-color: var(--o300) !important;
  background: var(--o50) !important;
}
.fb-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:12px;color:var(--muted)}

/* ── 관리자 탭 (언더라인 방식) ── */
.adm-tabs-wrap {
  margin-bottom: 16px;
}
.adm-tabs-wrap .adm-tabs {
  border-bottom: none;
}
.adm-tabs-wrap .adm-tabs:last-child {
  border-bottom: 1.5px solid var(--border);
}
.adm-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1.5px solid var(--border);
  overflow-x: visible;
  overflow-y: visible;
  white-space: nowrap;
  flex-wrap: nowrap;
  padding: 4px 0 0 0;
  margin-bottom: 0;
  min-height: 40px;
}
.adm-tabs::-webkit-scrollbar { display: none; }
.adm-tab {
  padding: 10px 14px;
  font-size: 12px;
  color: var(--muted);
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -1.5px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: color .15s, border-color .15s;
  line-height: 1.4;
}
.adm-tab:hover { color: var(--o500); }
.adm-tab.active {
  color: var(--o500);
  border-bottom: 2.5px solid var(--o500);
  font-weight: 500;
  background: none;
}
.adm-tab .cnt {
  background: var(--o100);
  color: var(--o600);
  border-radius: 10px;
  padding: 0 5px;
  font-size: 11px;
  margin-left: 4px;
}

/* ── Subtabs (언더라인 방식) ── */
.stabs {
  display: flex;
  gap: 0;
  border-bottom: 1.5px solid var(--border);
  overflow-x: auto;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 0;
  margin-bottom: 16px;
}
.stabs::-webkit-scrollbar { display: none; }
.stb {
  padding: 10px 14px;
  font-size: 12px;
  color: var(--muted);
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -1.5px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: color .15s, border-color .15s;
}
.stb:hover { color: var(--o500); }
.stb.active {
  color: var(--o500);
  border-bottom: 2.5px solid var(--o500);
  font-weight: 500;
  background: none;
}
.stb .cnt {
  background: var(--o100);
  color: var(--o600);
  border-radius: 10px;
  padding: 0 5px;
  font-size: 11px;
  margin-left: 4px;
}
.sp{display:none}.sp.active{display:block}

/* ── Spinner ── */
.spinner{text-align:center;padding:40px;color:var(--muted);font-size:13px}

/* ── AI 요약 (PROMPT 58C) ── */
.ai-section{margin-bottom:12px}
.dept-item{padding:4px 0;border-bottom:1px dashed var(--o100)}
.dept-detail-table{width:100%;border-collapse:collapse;font-size:12px}
.dept-detail-table th{padding:6px 8px;background:var(--o50);color:var(--muted);text-align:left;font-weight:500;border-bottom:2px solid var(--o200)}
.dept-detail-table td{padding:5px 8px;border-bottom:1px solid var(--o100)}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--o200);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--o400)}

@media(max-width:600px){
  .main{padding:12px}
  .form-row{flex-direction:column}
  .form-group{min-width:0}
  .topbar-logo span{display:none}
}

/* ── 반응형 레이아웃 ─────────────────────────── */

/* 태블릿 (768px 이하) */
@media (max-width: 768px) {
  .topbar {
    padding: 0 12px;
    height: 52px;
  }
  .topbar-user .user-info {
    display: none;
  }
  .nav-tabs {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 8px;
  }
  .nav-tabs::-webkit-scrollbar { display: none; }
  .ntb {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .card {
    padding: 14px;
    margin-bottom: 10px;
  }
  .btn {
    white-space: nowrap;
  }
  .btn-sm {
    min-width: fit-content;
    white-space: nowrap;
  }
  .abar {
    flex-wrap: wrap;
    gap: 8px;
  }
  .flow-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* PC/모바일 가시성 유틸 */
.pc-only     { display: block; }
.mobile-only { display: none;  }

/* nav 드롭다운 — topbar 내부에서 수평 중앙 정렬 */
.nav-tabs-wrap {
  display: flex !important;
  align-items: center;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: transparent;
}

/* ── PC 드롭다운 메뉴 ─────────────────────── */
.nav-tab {
  background: none;
  border: none;
  color: white;
  font-size: 14px;
  padding: 6px 12px;
  cursor: pointer;
  opacity: .85;
  border-radius: 6px;
}
.nav-tab:hover { opacity: 1; }

.nav-dropdown {
  position: relative;
  z-index: 9999;
}
.nav-dd-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: white !important;
  background-color: #ffffff !important;
  color: #333333 !important;
  border-radius: 8px;
  min-width: 150px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  z-index: 9999 !important;
  overflow: hidden;
  border: 1px solid var(--o100);
  transform-origin: top center;
}
.nav-dd-menu.open {
  display: block;
  animation: ddSlideDown 0.15s ease-out forwards;
}
@keyframes ddSlideDown {
  from { opacity: 0; transform: scaleY(0.85) translateY(-6px); }
  to   { opacity: 1; transform: scaleY(1)    translateY(0);    }
}
.dd-item {
  padding: 10px 16px;
  font-size: 13px;
  color: #333333 !important;
  cursor: pointer;
  border-bottom: 1px solid var(--o50);
  transition: background .1s;
  white-space: nowrap;
  display: block !important;
  background-color: #ffffff !important;
}
.dd-item:last-child { border-bottom: none; }
.dd-item:hover {
  background-color: var(--o50) !important;
  color: var(--o500) !important;
}
.dd-section-label {
  padding: 6px 16px;
  font-size: 11px;
  color: var(--muted);
  background: var(--o50);
  border-bottom: 1px solid var(--o100);
  font-weight: 500;
}

/* 모바일 (480px 이하) */
@media (max-width: 480px) {
  .pc-only     { display: none !important; }
  .mobile-only { display: flex !important; }
  .hamburger-btn {
    display: flex !important;
  }
  .topbar-logo {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: calc(100vw - 140px);
  }
  .nav-tabs-wrap {
    display: none !important;
  }
  .nav-tabs-wrap.mobile-open {
    display: flex !important;
    position: fixed;
    top: 52px;
    left: 0;
    right: 0;
    background: var(--white);
    flex-direction: column;
    z-index: 200;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    padding: 8px 0;
    max-height: calc(100vh - 52px);
    overflow-y: auto;
  }
  .nav-tabs-wrap.mobile-open .ntb {
    padding: 12px 20px;
    border-bottom: 1px solid var(--o50);
    border-radius: 0;
    font-size: 14px;
    text-align: left;
    width: 100%;
  }
  .nav-tabs-wrap.mobile-open .ntb.active {
    background: var(--o50);
    color: var(--o500);
  }
  .topbar {
    padding: 0 12px;
  }
  .topbar-logo {
    font-size: 14px;
  }
  .topbar-user {
    gap: 6px;
  }
  #main-area {
    padding: 12px;
  }
  .card {
    padding: 12px;
    border-radius: 8px;
  }
  .card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .btn-group {
    flex-wrap: wrap;
    gap: 6px;
  }
  .btn {
    white-space: nowrap;
    min-width: fit-content;
  }
  input, select, textarea {
    font-size: 16px !important;
  }
  .eval-card-actions {
    flex-direction: column;
    width: 100%;
  }
  .eval-card-actions .btn {
    width: 100%;
    text-align: center;
  }
  .resp-table thead {
    display: none;
  }
  .resp-table tr {
    display: block;
    margin-bottom: 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px;
  }
  .resp-table td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
    border: none;
    font-size: 13px;
  }
  .resp-table td::before {
    content: attr(data-label);
    font-weight: 600;
    color: var(--muted);
    font-size: 11px;
    min-width: 80px;
  }
  .flow-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }
  .flow-step-label {
    font-size: 10px;
  }
  .stabs {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0;
  }
  .stabs::-webkit-scrollbar { display: none; }
  .stb {
    white-space: nowrap;
    flex-shrink: 0;
    font-size: 12px;
    padding: 5px 10px;
  }
  .srow {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .okr-kr-row {
    flex-wrap: wrap;
    gap: 6px;
  }
  .flow { padding: 10px 6px; }
  .fstep { min-width: 0; flex: 1 1 0; gap: 3px; }
  .farrow { flex: 0 0 6px; min-width: 0; }
}

/* ── 전직원 평가 현황 컨트롤 ── */
.admin-status-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 10px 14px;
  background: var(--o50);
  border: 1px solid var(--o100);
  border-radius: 8px;
}

/* ── 전직원 평가 현황 컨트롤 ── */
.admin-status-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 10px 14px;
  background: var(--o50);
  border: 1px solid var(--o100);
  border-radius: 8px;
}
.admin-status-controls select {
  min-width: 200px;
  flex-shrink: 0;
}
.admin-status-controls .checkbox-inline {
  white-space: nowrap;
  flex-shrink: 0;
}
.admin-status-controls .checkbox-inline span {
  white-space: nowrap;
}

/* ── 평가 기간 관리 컨트롤 ── */
.period-mgr-controls {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--o50);
  border: 1px solid var(--o100);
  border-radius: 8px;
}
.period-mgr-controls label {
  white-space: nowrap;
  flex-shrink: 0;
  flex-grow: 0;
}
.period-mgr-controls select {
  width: 120px;
  min-width: 120px;
  flex-shrink: 0;
  flex-grow: 0;
}
.period-mgr-controls span {
  white-space: nowrap;
  flex-shrink: 0;
  flex-grow: 0;
}
.period-mgr-controls .btn,
.period-mgr-controls button {
  white-space: nowrap;
  flex-shrink: 0;
  flex-grow: 0;
}
.period-mgr-controls small {
  white-space: nowrap;
  flex-shrink: 0;
  flex-grow: 0;
}
@media (max-width: 768px) {
  .period-mgr-controls {
    flex-wrap: wrap;
  }
  .period-mgr-controls small {
    flex-basis: 100%;
    white-space: normal;
  }
}
@media (max-width: 480px) {
  .period-mgr-controls small {
    display: none;
  }
}

/* ── 평가 기간 접기/펼치기 카드 ── */
.period-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--white);
  overflow: hidden;
}
.period-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  cursor: pointer;
  user-select: none;
}
.period-card-header:hover {
  background: var(--o50);
}
.toggle-icon {
  font-size: 11px;
  color: var(--muted);
  width: 14px;
  flex-shrink: 0;
}
.period-card-body {
  padding: 14px 16px;
  border-top: 1px solid var(--border);
}

/* ── 공통 체크박스 인라인 ── */
.checkbox-inline {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}
.checkbox-inline input[type="checkbox"] {
  flex-shrink: 0;
}

/* ── 평가 정책 탭 ── */
.policy-tab {
  width: 100%;
}
.policy-group {
  margin-bottom: 28px;
}
.policy-group-header {
  font-size: 15px;
  font-weight: 700;
  color: #333;
  padding: 10px 0;
  margin-bottom: 0;
}
.policy-group-header::after {
  content: '';
  display: block;
  height: 1px;
  margin-top: 10px;
  background: linear-gradient(to right, transparent, rgba(217,119,6,0.3), transparent);
}
/* 통일 grid 레이아웃: 제목 좌측 1fr, 옵션 우측 auto */
.policy-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 16px;
  row-gap: 6px;
  padding: 16px 20px;
  border-bottom: 1px solid #e5e5e5;
  transition: background 0.15s;
}
.policy-item:hover {
  background: #fafafa;
}
.policy-item:last-child {
  border-bottom: none;
}
.policy-item .policy-title {
  font-size: 14px;
  font-weight: 600;
  color: #222;
  display: flex;
  align-items: center;
}
.policy-item .policy-options {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  flex-shrink: 0;
  justify-content: flex-end;
}
.policy-item .policy-description {
  grid-column: 1 / -1;
  font-size: 12px;
  color: #666;
}
.policy-emoji {
  font-size: 16px;
  margin-right: 8px;
  display: inline-block;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
}
.policy-sub-item {
  margin-top: 10px;
  margin-left: 32px;
  padding: 10px 14px;
  border-left: 3px solid #e5e5e5;
  background: #fafafa;
  border-radius: 4px;
  grid-column: 1 / -1;
}
.policy-sub-item .policy-item {
  padding: 0;
  border-bottom: none;
}
.policy-sub-item .policy-item:hover {
  background: transparent;
}
.btn-policy-option {
  padding: 5px 11px;
  border: 1px solid #ddd;
  background: white;
  color: #555;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all 0.15s;
}
.btn-policy-option:hover:not(:disabled) {
  background: #f5f5f5;
  border-color: #bbb;
}
.btn-policy-option.btn-primary,
.btn-policy-option.active {
  background: #d97706;
  color: white;
  border-color: #d97706;
  font-weight: 500;
}
.btn-policy-option.btn-ghost {
  background: white;
  color: #555;
  border-color: #ddd;
  font-weight: normal;
}
@media (max-width: 768px) {
  .policy-item {
    grid-template-columns: 1fr;
    row-gap: 8px;
  }
  .policy-item .policy-options {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

/* ── 미바인딩 알림 배너 ── */
.missing-policy-banner {
  position: sticky;
  top: 0;
  z-index: 100;
  background: linear-gradient(to right, #fef3c7, #fde68a);
  border-bottom: 2px solid #f59e0b;
  padding: 10px 16px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}
.missing-policy-banner .banner-content {
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 960px;
  margin: 0 auto;
  flex-wrap: wrap;
}
.missing-policy-banner .banner-icon {
  font-size: 18px;
  flex-shrink: 0;
}
.missing-policy-banner .banner-text {
  flex: 1;
  font-size: 13px;
  color: #92400e;
}

/* ── 모달 ── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.modal-content {
  background: white;
  border-radius: 8px;
  max-width: 600px;
  max-height: 90vh;
  width: 90%;
  display: flex;
  flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
}
.modal-header {
  padding: 16px;
  border-bottom: 1px solid var(--o100);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
}
.modal-body {
  padding: 16px;
  overflow-y: auto;
  flex: 1;
}
.modal-footer {
  padding: 12px 16px;
  border-top: 1px solid var(--o100);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.modal-close {
  background: none;
  border: none;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  color: var(--muted);
  padding: 0 4px;
}
.modal-close:hover { color: var(--o700); }

@media (max-width: 480px) {
  .missing-policy-banner .banner-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .missing-policy-banner .banner-text {
    font-size: 12px;
  }
  .modal-content {
    width: 95%;
    max-height: 95vh;
  }
  .modal-body table {
    overflow-x: auto;
    display: block;
  }
}

/* ── 보고·피드백 통합 UI (64B) ── */
.rf-hidden { display: none !important; }
.goal-report-card { margin-bottom: 16px; }
.round-list { margin-top: 8px; }
.round-block { border: 1px solid var(--o100); border-radius: 6px; margin-bottom: 10px; padding: 10px; background: white; }
.round-header { font-size: 12px; color: var(--muted); margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px dashed var(--o100); }
.round-header strong { color: var(--o500); font-size: 13px; }
.round-items { display: flex; flex-direction: column; gap: 6px; }
.item-block { padding: 8px 10px; border-radius: 4px; }
.report-block { background: #fef9e7; border-left: 3px solid #f59e0b; }
.feedback-block { background: #f0f9ff; border-left: 3px solid #3b82f6; }
.item-header { font-size: 11px; color: var(--muted); margin-bottom: 4px; }
.item-content { font-size: 13px; white-space: pre-wrap; word-break: break-word; line-height: 1.6; }
.bd-legacy { background: #f3f4f6; color: #6b7280; padding: 1px 5px; border-radius: 3px; font-size: 10px; margin-left: 6px; }
.summary-card { margin-bottom: 16px; border-top: 3px solid var(--o300); }
.more-controls { text-align: center; padding-top: 10px; border-top: 1px dashed var(--o100); margin-top: 4px; }
@media (max-width: 480px) {
  .item-header { font-size: 10px; }
  .item-content { font-size: 12px; }
}
