/* ============================================================
   haru SSO — NHN Design System(NDS) 적용 스타일
   장문 보고서용 NDS의 디자인 "언어"(컬러·잉크·타이포·라인·에디토리얼 톤)를
   인증 IdP 웹(로그인·가입·포털·관리 콘솔)에 맞춰 적용한다.
   보고서 전용 레이아웃(커버·사이드 TOC·PART 디바이더 등)은 적용하지 않는다.
   ============================================================ */

/* Pretendard Variable — 셀프 호스팅(same-origin, CSP 'self'). 전 weight 단일 파일. */
@font-face {
  font-family: "Pretendard Variable";
  font-weight: 45 920;
  font-style: normal;
  font-display: swap;
  src: url("/fonts/PretendardVariable-302ec55f5b4320354ec6b35a53dead87.woff2") format("woff2-variations");
}

:root {
  /* NHN 브랜드 */
  --nhn-black: #191919;
  --nhn-blue:  #0F80F6;
  --nhn-red:   #EB453D;
  --nhn-green: #01A058;
  --nhn-orange:#FF9000;

  /* 잉크(텍스트 위계) */
  --ink:   #191919;
  --ink-2: #2e2e2e;
  --ink-3: #545454;
  --ink-4: #767676;
  --ink-5: #a1a1a1;
  --ink-6: #c8c8c8;

  /* 표면 / 라인 */
  --surface:     #ffffff;
  --surface-1:   #f7f7f7;
  --surface-2:   #efefef;
  --line:        #191919;
  --line-soft:   #e3e3e3;
  --line-softer: #ededed;

  /* 시멘틱 */
  --accent:        var(--nhn-blue);
  --accent-strong: #0b6ed8;
  --danger:        var(--nhn-red);
  --success:       var(--nhn-green);

  /* 타이포 — Pretendard 단일(시스템 폰트 fallback) */
  --font-sans: "Pretendard Variable", -apple-system, BlinkMacSystemFont,
               "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;

  --radius:    12px;
  --radius-sm: 8px;
  --ease: cubic-bezier(0.32, 0.72, 0, 1);
  --dur:  240ms;
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.7;
  font-weight: 500;
  color: var(--ink-2);
  background: var(--surface-1);
  word-break: keep-all;          /* 한글 단어 단위 줄바꿈 */
  overflow-wrap: break-word;
  font-feature-settings: "tnum"; /* 숫자 등폭 */
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3 { margin: 0; color: var(--ink); font-weight: 700; letter-spacing: 0; line-height: 1.25; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- 폼 컨트롤 ---- */
label { display: block; font-size: 13px; color: var(--ink-3); font-weight: 600; }

input[type=text], input[type=email], input[type=password], input:not([type]), select, textarea {
  width: 100%;
  margin-top: 4px;
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 14px;
  color: var(--ink);
  background: var(--surface);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(15, 128, 246, 0.15);
}

/* ---- 버튼 ---- */
button, .btn {
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  padding: 9px 16px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
button:hover, .btn:hover { background: var(--accent-strong); }
button:active, .btn:active { transform: translateY(1px); }
button:focus-visible, .btn:focus-visible, a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
button.sub, .btn-sub { background: var(--surface); color: var(--ink-2); border-color: var(--line-soft); }
button.sub:hover, .btn-sub:hover { background: var(--surface-1); border-color: var(--ink-5); }
button.danger, .btn-danger { background: var(--surface); color: var(--danger); border-color: rgba(235, 69, 61, 0.45); }
button.danger:hover, .btn-danger:hover { background: rgba(235, 69, 61, 0.08); border-color: var(--danger); }
button.warn, .btn-warn { background: var(--surface); color: #b25e00; border-color: rgba(255, 144, 0, 0.5); }
button.warn:hover, .btn-warn:hover { background: rgba(255, 144, 0, 0.10); border-color: var(--nhn-orange); }

/* ---- 공통 보조 요소 ---- */
.msg    { font-size: 13px; color: var(--danger); min-height: 18px; }
.muted  { color: var(--ink-4); font-size: 13px; }
.svc-id { color: var(--ink-5); font-size: 11px; margin-top: 2px; word-break: break-all; font-feature-settings: "tnum"; }

.badge { display: inline-block; font-size: 12px; font-weight: 600; padding: 3px 9px; border-radius: 999px; }
.badge.pending  { background: rgba(255, 144, 0, 0.14); color: #8a5a00; }
.badge.rejected { background: rgba(235, 69, 61, 0.12); color: var(--danger); }
.badge.granted  { background: rgba(1, 160, 88, 0.12);  color: var(--success); }

/* ============================================================
   인증 화면(로그인·가입·접근거부·오류) — 중앙 카드
   ============================================================ */
body.auth { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }

.auth-card {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  box-shadow: 0 1px 2px rgba(25, 25, 25, 0.04), 0 10px 30px rgba(25, 25, 25, 0.06);
  padding: 40px 34px;
  width: 360px;
  max-width: 100%;
}
.auth-card.center { text-align: center; }
.auth-card h1 { font-size: 22px; margin-bottom: 6px; }
.auth-card .sub { color: var(--ink-4); font-size: 13px; line-height: 1.6; margin: 0 0 22px; }
.auth-card form label { margin-top: 14px; }
.auth-card form button { width: 100%; margin-top: 20px; padding: 11px; font-size: 15px; }
.auth-card .foot { margin-top: 18px; text-align: center; font-size: 13px; color: var(--ink-4); }

/* 로그인/가입 알림 박스 */
.alert { border-radius: var(--radius-sm); padding: 10px 12px; font-size: 13px; margin-bottom: 16px; }
.alert.error  { background: rgba(235, 69, 61, 0.10); color: var(--danger); }
.alert.notice { background: rgba(15, 128, 246, 0.08); color: var(--accent-strong); }

/* 접근거부 / 오류 화면 */
.auth-card .icon { font-size: 38px; }
.auth-card .code { font-size: 40px; font-weight: 700; color: var(--ink); letter-spacing: -0.02em; }
.auth-card p { color: var(--ink-3); font-size: 14px; line-height: 1.65; margin: 0; }
.auth-card .client { margin-top: 14px; font-size: 13px; color: var(--ink-4); }
.auth-card .client strong { color: var(--ink); }
.auth-card .home { margin-top: 20px; display: inline-block; font-size: 14px; }

/* 가입 — 서비스 토글 카드(복수 선택, 순수 CSS) */
.svc-note  { font-weight: 400; color: var(--ink-5); }
.svc-list  { margin-top: 8px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.svc-card {
  position: relative; display: block; margin: 0;
  padding: 10px 30px 10px 12px;
  border: 1.5px solid var(--line-soft); border-radius: var(--radius-sm);
  cursor: pointer; user-select: none;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.svc-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.svc-card .svc-name { display: block; font-size: 13px; font-weight: 600; color: var(--ink); }
.svc-card .svc-id   { display: block; }
.svc-card .svc-dot {
  position: absolute; top: 12px; right: 12px; width: 14px; height: 14px;
  border-radius: 50%; border: 1.5px solid var(--ink-6); box-sizing: border-box;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.svc-card:has(input:checked) { border-color: var(--accent); background: rgba(15, 128, 246, 0.06); }
.svc-card:has(input:checked) .svc-dot { border-color: var(--accent); background: var(--accent); box-shadow: inset 0 0 0 2px #fff; }
.svc-empty { font-size: 12px; color: var(--ink-4); margin: 8px 0 0; }

/* ============================================================
   관리 콘솔(사용자·클라이언트·접근권한)
   ============================================================ */
.topbar { background: var(--ink); color: #fff; padding: 14px 24px; display: flex; align-items: center; flex-wrap: wrap; }
.topbar strong { font-weight: 700; margin-right: 8px; }
.topbar a { color: rgba(255, 255, 255, 0.66); margin-left: 16px; font-size: 14px; }
.topbar a:last-child { margin-left: auto; } /* '← 포털로' 를 우측으로 */
.topbar a:hover { color: #fff; text-decoration: none; }

.wrap { padding: 28px 24px; max-width: 980px; margin: 0 auto; }
.wrap.wide { max-width: 1040px; }
.wrap > h1 { font-size: 21px; margin-bottom: 4px; }

.panel { background: var(--surface); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: 18px; margin: 16px 0; }
.panel h2 { font-size: 15px; margin: 0 0 12px; }
.row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

form.create { background: var(--surface); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: 16px; margin: 16px 0; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
form.create input, form.create select { width: auto; margin-top: 0; }

/* 테이블 — NDS thead(pale gray) + 행 구분선. 흰 .panel 안에 들어가 카드형으로 보인다 */
table { width: 100%; border-collapse: collapse; }
thead th { text-align: left; padding: 11px 14px; background: var(--surface-2); color: var(--ink);
           font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0; white-space: nowrap; }
tbody td { padding: 12px 14px; border-top: 1px solid var(--line-softer); color: var(--ink-2); font-size: 13.5px; vertical-align: top; }
th.num, td.num { text-align: right; font-feature-settings: "tnum"; }
table button { padding: 6px 12px; font-size: 13px; margin: 2px 0; }
.panel > table:first-child thead th:first-child { border-top-left-radius: 6px; }

/* ============================================================
   포털(서비스 런처)
   ============================================================ */
.brandbar { background: var(--surface); border-bottom: 1px solid var(--line-soft); padding: 14px 24px;
            display: flex; justify-content: space-between; align-items: center; }
.brandbar .brand { font-weight: 700; color: var(--ink); }
.brandbar .user { font-size: 13px; color: var(--ink-4); display: flex; align-items: center; gap: 10px; }
/* 헤더 우측 액션 — 아웃라인(고스트) 버튼. 관리 콘솔=살짝 강조, 로그아웃=약하게 */
.brandbar .user a,
.brandbar .user form.logout button {
    font: 600 13px/1.2 var(--font-sans);
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--line-soft);
    background: var(--surface);
    cursor: pointer;
    text-decoration: none;
    transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.brandbar .user a { color: var(--accent); border-color: rgba(15, 128, 246, 0.4); } /* 관리 콘솔 — accent 강조 */
.brandbar .user a:hover { background: rgba(15, 128, 246, 0.06); border-color: var(--accent); text-decoration: none; }
.brandbar .user form.logout { display: inline; margin: 0; }
.brandbar .user form.logout button { color: var(--ink-3); } /* 로그아웃 — 약하게 */
.brandbar .user form.logout button:hover { background: var(--surface-1); border-color: var(--ink-5); color: var(--ink); }

.portal { max-width: 880px; margin: 32px auto; padding: 0 24px; }
.portal h1 { font-size: 22px; margin: 0 0 18px; }
.portal h1.section { margin-top: 40px; }

.svc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.svc-icon { display: block; width: 36px; height: 36px; border-radius: 9px; object-fit: contain; margin-bottom: 12px; background: var(--surface-1); }
.svc-tile { display: block; background: var(--surface); border: 1px solid var(--line-soft); border-radius: var(--radius);
            padding: 22px; color: var(--ink);
            transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.svc-tile:hover { transform: translateY(-2px); border-color: var(--ink-6); box-shadow: 0 6px 20px rgba(25, 25, 25, 0.07); text-decoration: none; }
.svc-tile .name { font-size: 16px; font-weight: 600; }
.svc-tile .go { margin-top: 10px; font-size: 13px; color: var(--accent); }

.req-card { background: var(--surface); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: 22px; }
.req-card .name { font-size: 16px; font-weight: 600; color: var(--ink); }
.req-action { margin-top: 14px; }
.req-action form { display: inline; margin: 0; }
.req-action button { font-size: 13px; }

.empty { background: var(--surface); border: 1px dashed var(--line-soft); border-radius: var(--radius);
         padding: 36px; text-align: center; color: var(--ink-4); }
