/* ============================================================
   KARA Campus AI Agent — 공통 컴포넌트 (카드 · 버튼 · 폼 · 테이블 · 유틸)
   ============================================================ */

/* ---------- 카드 / 그리드 ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border-bottom:1px solid var(--line-2)}
.card-h h3{font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-h .ch-sub{font-size:12px;color:var(--ink-3);font-weight:500}
.card-b{padding:18px}
.grid{display:grid;gap:18px}
.row{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- 버튼 ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;border-radius:9px;padding:9px 15px;font-size:13.5px;font-weight:600;transition:.15s;border:1px solid transparent;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-700)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{filter:brightness(.95)}
.btn-ghost{background:var(--surface);color:var(--ink-2);border-color:var(--line)}
.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn-soft{background:var(--primary-50);color:var(--primary-700)}
.btn-soft:hover{background:var(--primary-100)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-lg{padding:12px 22px;font-size:14.5px}
.btn[disabled]{opacity:.5;pointer-events:none}

/* ---------- 태그 / 칩 ---------- */
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
.tag.blue{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-100)}
.tag.teal{background:var(--accent-50);color:#0a7a8a;border-color:#bfe9ee}
.tag.green{background:var(--ok-50);color:#0f7a44;border-color:#c2ebd3}
.tag.amber{background:var(--warn-50);color:#9a5e0c;border-color:#f1dcb3}
.tag.red{background:var(--danger-50);color:#b3322a;border-color:#f4cdc9}
.tag.gray{background:#eef1f5;color:#5b6b7e}

.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:6px 12px;border-radius:20px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);transition:.15s;cursor:pointer}
.chip:hover{border-color:var(--primary);color:var(--primary)}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ---------- 폼 ---------- */
label.field{display:block;margin-bottom:14px}
label.field>span{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
label.field>span em{color:var(--danger);font-style:normal;margin-left:2px}
.input,select.input,textarea.input{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;background:var(--surface);color:var(--ink);outline:none;transition:.15s}
.input:disabled,select.input:disabled,textarea.input:disabled{background:var(--surface-2);color:var(--ink-3);cursor:not-allowed;opacity:.7}
.input:focus,select.input:focus,textarea.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}
textarea.input{resize:vertical;min-height:74px;line-height:1.6}
.hint{font-size:11.5px;color:var(--ink-3);margin-top:5px}

/* ---------- 테이블 ---------- */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:11px 14px;font-size:13px;border-bottom:1px solid var(--line-2);vertical-align:top}
th{font-size:11.5px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em;background:var(--surface-2)}
tbody tr:hover{background:var(--surface-2)}
.t-num{color:var(--ink-3);font-variant-numeric:tabular-nums}

/* ---------- 세그먼트 ---------- */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.seg button{padding:6px 14px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--ink-2)}
.seg button.on{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}

/* ---------- 기타 유틸 ---------- */
.muted{color:var(--ink-2)} .muted2{color:var(--ink-3)}
.sec-title{font-size:12px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;margin:4px 0 10px}
.divider{height:1px;background:var(--line-2);margin:16px 0}
.kv{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--line-2);font-size:13px}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--ink-3)} .kv .v{font-weight:600;text-align:right}
.list-reset{list-style:none}
.feat-list li{display:flex;gap:9px;font-size:13px;padding:6px 0;color:var(--ink-2)}
.feat-list li::before{content:"›";color:var(--accent);font-weight:800;flex:0 0 auto}
.callout{display:flex;gap:12px;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--r);padding:14px 16px;font-size:13px;color:var(--primary-800);line-height:1.6}
.callout .c-ic{font-size:18px}

/* ---------- 툴팁 ---------- */
.tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--surface-2);color:var(--ink-3);border:1px solid var(--line);font-size:10.5px;font-weight:700;cursor:help;vertical-align:middle}
.tip::after{content:attr(data-tip);position:absolute;bottom:150%;left:50%;transform:translateX(-50%);width:250px;background:#16202E;color:#fff;padding:9px 11px;border-radius:9px;font-size:11.5px;font-weight:500;line-height:1.55;white-space:normal;text-align:left;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s;z-index:60;box-shadow:var(--shadow-lg)}
.tip::before{content:"";position:absolute;bottom:150%;left:50%;transform:translate(-50%,90%);border:6px solid transparent;border-top-color:#16202E;opacity:0;visibility:hidden;transition:opacity .15s;z-index:60}
.tip:hover::after,.tip:hover::before{opacity:1;visibility:visible}

/* ---------- 문항 재생성 로딩 오버레이 ---------- */
.regen-ov{position:absolute;inset:0;background:rgba(255,255,255,.78);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border-radius:inherit;z-index:5;font-size:12.5px;font-weight:600;color:var(--primary)}
