:root{
  color-scheme: light dark;
  --fg:#1a1d22; --muted:#5b6470; --bg:#f4f6f9; --card:#ffffff; --border:#d7dce3;
  --subtle:#f7f9fc; --soft:#eef1f6; --soft-h:#e3e8f0;
  --primary:#2f6bff; --primary-d:#2253e8; --on-primary:#ffffff; --danger:#b23a48;
  --ok-bg:#e3f6e9; --ok-fg:#1b7a3d;
  --wait-bg:#fdeede; --wait-fg:#a86413;
  --info-bg:#e6eefc; --info-fg:#2253e8;
  --no-bg:#fde8ea; --no-fg:#b23a48; --no-bd:#f3c2c8;
  --alert-bg:#fde8ea; --alert-fg:#b23a48; --alert-bd:#f3c2c8;
  --warn-bg:#fff7e6; --warn-bd:#f3d9b0; --warn-fg:#8a5a12;
}
@media (prefers-color-scheme: dark){
  :root{
    --fg:#e7e9ee; --muted:#9aa3b2; --bg:#14161b; --card:#1d2026; --border:#333a45;
    --subtle:#23262e; --soft:#2a2e37; --soft-h:#333a45;
    --primary:#5b8cff; --primary-d:#74a0ff; --on-primary:#ffffff; --danger:#f08a96;
    --ok-bg:#16331f; --ok-fg:#5fd089;
    --wait-bg:#352a17; --wait-fg:#e3b15f;
    --info-bg:#1b2a48; --info-fg:#8fb4ff;
    --no-bg:#3a1f24; --no-fg:#f08a96; --no-bd:#5a2f36;
    --alert-bg:#3a1f24; --alert-fg:#f08a96; --alert-bd:#5a2f36;
    --warn-bg:#352a17; --warn-bd:#5a4a2a; --warn-fg:#e3b15f;
  }
}
/* Pretendard 가변폰트 — 로컬 번들(인터넷 없어도 동일 글꼴) */
@font-face{
  font-family:'Pretendard';
  font-weight:45 920; font-style:normal; font-display:swap;
  src:url('/static/vendor/PretendardVariable.woff2') format('woff2-variations');
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:'Pretendard',system-ui,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  font-size:17px; line-height:1.6; color:var(--fg); background:var(--bg);
}
h1{font-size:26px; margin:0 0 8px}
a.link{color:var(--primary); text-decoration:none}
a.link:hover{text-decoration:underline}
.muted{color:var(--muted)}
.container{max-width:2000px; margin:0 auto; padding:38px 40px 44px}
.card{background:var(--card); border:1px solid var(--border); border-radius:14px; padding:28px}

/* ===== 앱 셸: 좌측 사이드바 ===== */
.layout{display:flex; min-height:100vh}
.sidebar{flex:0 0 230px; width:230px; background:var(--card); border-right:1px solid var(--border); display:flex; flex-direction:column; position:sticky; top:0; height:100vh}
.side-brand{display:block; padding:20px 22px; font-weight:700; font-size:18px; color:var(--fg); text-decoration:none; border-bottom:1px solid var(--border)}
a.side-brand:hover{color:var(--primary)}
.side-nav{flex:1; padding:14px 12px; display:flex; flex-direction:column; gap:3px; overflow-y:auto}
.side-nav a{display:block; padding:12px 14px; border-radius:10px; color:var(--fg); text-decoration:none; font-size:16px; font-weight:500}
.side-nav a:hover{background:var(--soft)}
.side-nav a.active{background:var(--info-bg); color:var(--info-fg); font-weight:700}
.side-foot{padding:16px 18px; border-top:1px solid var(--border); font-size:14px}
.tabs{display:inline-flex; gap:4px; background:var(--soft); padding:5px; border-radius:14px; margin:0 0 24px; flex-wrap:wrap; max-width:100%}
.tab{padding:9px 18px; border-radius:10px; color:var(--muted); text-decoration:none; font-weight:600; font-size:14px; white-space:nowrap; transition:background .15s, color .15s}
.tab:hover{color:var(--fg)}
.tab.active{background:var(--card); color:var(--primary); box-shadow:0 1px 3px rgba(0,0,0,.10)}
.side-user{color:var(--muted); margin-bottom:8px; line-height:1.4}
.side-logout{color:var(--primary); text-decoration:none; font-weight:600}
.side-logout:hover{text-decoration:underline}
.side-link{display:inline-block; color:var(--muted); text-decoration:none; font-size:13px; margin-right:12px}
.side-link:hover{color:var(--fg)}
.content-area{flex:1; min-width:0}
.mobilebar{display:none}
.nav-overlay{display:none}
@media (max-width:820px){
  .sidebar{position:fixed; top:0; left:0; z-index:50; transform:translateX(-100%); transition:transform .22s ease; box-shadow:2px 0 16px rgba(0,0,0,.18)}
  #navtoggle:checked ~ .layout .sidebar{transform:none}
  #navtoggle:checked ~ .layout .nav-overlay{display:block; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:40}
  .mobilebar{display:flex; align-items:center; gap:14px; padding:13px 16px; background:var(--card); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:20}
  .hamburger{font-size:24px; cursor:pointer; line-height:1; user-select:none}
  .mb-title{font-weight:700}
}

/* 로그인 */
.auth{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px}
.auth-card{width:100%; max-width:400px}
.brand{font-size:24px; margin:0 0 4px}
.sub{color:var(--muted); margin:0 0 22px}
form label{display:block; margin:0 0 16px; font-weight:500}
input{
  display:block; width:100%; margin-top:7px; padding:14px 14px; font-size:17px;
  border:1px solid var(--border); border-radius:10px; background:var(--card); color:var(--fg);
}
input:focus{outline:2px solid var(--primary); outline-offset:1px; border-color:var(--primary)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; width:auto;
  min-height:46px; padding:11px 22px; font-size:16px; font-weight:600;
  border:0; border-radius:10px; cursor:pointer;
}
a.btn{text-decoration:none}
.btn-block{width:100%}
.btn-primary{background:var(--primary); color:var(--on-primary)}
.btn-primary:hover{background:var(--primary-d)}
.alert{
  background:var(--alert-bg); color:var(--alert-fg); border:1px solid var(--alert-bd);
  padding:12px 14px; border-radius:10px; margin-bottom:18px; font-size:15px;
}
.alert-ok{background:var(--ok-bg); color:var(--ok-fg); border-color:var(--ok-fg)}
/* 작업 완료 1회용 알림(플래시) — 모든 페이지 상단 */
.container.flash-wrap{padding-top:22px; padding-bottom:0}
.flash-msg{margin:0; font-weight:600; box-shadow:0 2px 10px rgba(0,0,0,.08)}

/* 대시보드 */
.topbar{
  display:flex; justify-content:space-between; align-items:center;
  background:var(--card); border-bottom:1px solid var(--border); padding:14px 20px;
}
.brand-sm{font-weight:600; color:var(--fg); text-decoration:none}
a.brand-sm:hover{color:var(--primary)}
.user-box{color:var(--muted); font-size:15px; display:flex; gap:14px; align-items:center}
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:16px; margin-top:22px}
.stat{background:var(--card); border:1px solid var(--border); border-radius:14px; padding:24px; text-align:center}
.stat .num{font-size:36px; font-weight:700; color:var(--primary); line-height:1.1}
.stat .lbl{color:var(--muted); margin-top:8px}

@media (max-width:480px){
  body{font-size:16px}
  .container{padding:18px 14px}
  .card{padding:22px}
}

/* ===== 공통 폼·표 (온보딩·관리자) ===== */
.row-between{display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}
.sec-title{font-size:18px; margin:40px 0 12px; padding-top:24px; border-top:1px solid var(--border)}
.sec-title:first-of-type{border-top:0; padding-top:0; margin-top:14px}
.form-card{margin-top:16px}
/* 짧은 입력칸은 넓은 본문에서도 늘어지지 않게 폭 제한 */
.form-grid{display:grid; grid-template-columns:repeat(2,minmax(0,460px)); gap:0 18px}
.meta-grid{display:grid; grid-template-columns:minmax(0,1fr) 190px minmax(0,1fr); gap:0 16px; max-width:720px}
@media (max-width:560px){ .meta-grid{grid-template-columns:1fr} }
/* 드래그&드롭 업로드 */
input[hidden]{display:none}
.dropzone{border:2px dashed var(--border); border-radius:12px; padding:22px 16px; text-align:center; cursor:pointer; background:var(--subtle); margin-top:7px; transition:border-color .15s, background .15s}
.dropzone:hover{border-color:var(--primary)}
.dz-over{border-color:var(--primary); background:var(--info-bg)}
.dz-msg{color:var(--muted)}
.dz-link{color:var(--primary); text-decoration:underline}
.dz-files{margin-top:8px; word-break:break-all}
select,textarea{
  display:block; width:100%; margin-top:7px; padding:13px 12px; font-size:17px;
  border:1px solid var(--border); border-radius:10px; background:var(--card); color:var(--fg);
}
select:focus,textarea:focus{outline:2px solid var(--primary); outline-offset:1px; border-color:var(--primary)}
input[type=file]{padding:10px; background:var(--subtle); cursor:pointer; font-size:15px}
.consent-box{
  background:var(--subtle); border:1px solid var(--border); border-radius:10px;
  padding:16px 18px; font-size:15px; line-height:1.7; max-height:230px; overflow:auto;
}
.consent-box p{margin:0 0 8px}
.check-row{display:flex !important; align-items:center; gap:10px; margin:14px 0 6px !important; font-weight:600}
.check-row input{width:22px; height:22px; margin:0; flex:0 0 auto}
.btn-secondary{background:var(--soft); color:var(--fg)}
.btn-secondary:hover{background:var(--soft-h)}
.btn-inline{width:auto; min-height:44px; padding:10px 18px; font-size:16px}
/* 접이식 보조 설정 */
.settings-fold{margin-top:40px; border-top:1px solid var(--border); padding-top:10px}
.settings-fold > summary{cursor:pointer; font-size:18px; font-weight:700; padding:12px 0; list-style:none}
.settings-fold > summary::-webkit-details-marker{display:none}
.settings-fold > summary::before{content:'▸  '; color:var(--muted)}
.settings-fold[open] > summary::before{content:'▾  '}
.small{font-size:14px}
.center{text-align:center}
.quick{margin-top:18px}
/* 표 */
.table-wrap{margin-top:18px; padding:0; overflow:auto}
.tbl{width:100%; border-collapse:collapse; font-size:16px}
.tbl th,.tbl td{padding:14px 16px; text-align:left; border-bottom:1px solid var(--border); white-space:nowrap}
.tbl th{background:var(--subtle); color:var(--muted); font-weight:600; font-size:14px}
.tbl tr:last-child td{border-bottom:0}
.badge{display:inline-block; padding:4px 11px; border-radius:999px; font-size:13px; font-weight:600}
.badge-ok{background:var(--ok-bg); color:var(--ok-fg)}
.badge-wait{background:var(--wait-bg); color:var(--wait-fg)}
@media (max-width:640px){ .form-grid{grid-template-columns:1fr} }

/* ===== 보고서 루프 ===== */
.badge-info{background:var(--info-bg); color:var(--info-fg)}
.badge-no{background:var(--no-bg); color:var(--no-fg)}
.alert-warn{background:var(--warn-bg); color:var(--warn-fg); border:1px solid var(--warn-bd)}
.assign-card{margin-top:16px}
.company-name{font-size:19px; font-weight:700}
.tbl.mini{margin-top:14px; font-size:15px}
.tbl.mini th,.tbl.mini td{padding:10px 12px}
.btn-row{display:flex; gap:12px; margin-top:8px; flex-wrap:wrap}
.btn-row .btn{width:auto; min-width:130px; margin-top:0}
/* 폼 작업 버튼 고정 바 — 스크롤해도 상단 우측에 항상 보이게(저장·제출 놓치지 않게) */
.form-actions{position:sticky; top:0; z-index:25; display:flex; justify-content:flex-end; align-items:center; gap:10px; flex-wrap:wrap; margin:0 0 20px; padding:12px 0; background:var(--card); border-bottom:1px solid var(--border)}
.form-actions .fa-hint{margin-right:auto; color:var(--muted); font-size:14px; font-weight:600}
.form-actions .btn{width:auto; min-width:118px; margin-top:0}
@media(max-width:980px){ .form-actions{top:48px} .form-actions .fa-hint{display:none} }
.char-count{margin:-8px 0 14px; text-align:right; font-weight:600}
.tab b{margin-left:4px}
.kv{display:flex; gap:12px; padding:8px 0; border-bottom:1px dashed var(--border)}
.kv span{width:110px; color:var(--muted); flex:0 0 auto}
.report-text{white-space:pre-wrap; line-height:1.8; background:var(--subtle); border:1px solid var(--border); border-radius:10px; padding:14px 16px; margin:0}
.thumbs{display:flex; gap:10px; flex-wrap:wrap}
.thumbs img{width:120px; height:120px; object-fit:cover; border:1px solid var(--border); border-radius:10px; display:block}
.pending-banner{display:block; margin:16px 0; padding:16px 18px; background:var(--warn-bg); border:1px solid var(--warn-bd); border-radius:12px; color:var(--warn-fg); font-weight:600; text-decoration:none}
.reject-form{margin-top:12px}
textarea{font-family:inherit; line-height:1.7; resize:vertical}
.inline-form{margin:0}
.inline-form select{margin-top:0; padding:8px 10px; font-size:15px; min-width:120px}
.checkbox-list{display:flex; flex-wrap:wrap; gap:10px 18px; margin:4px 0 6px}
.chk{display:flex !important; align-items:center; gap:7px; margin:0 !important; font-weight:400}
.chk input{width:20px; height:20px; margin:0; flex:0 0 auto}
.field-label{font-weight:500; margin:10px 0 4px}

/* ===== 대시보드 ===== */
.todo-row{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin:18px 0}
.todo{display:block; background:var(--card); border:1px solid var(--border); border-radius:14px; padding:18px; text-decoration:none; color:var(--fg)}
.todo-n{font-size:30px; font-weight:700; line-height:1}
.todo-l{color:var(--muted); margin-top:6px; font-size:15px}
.todo-on{border-color:var(--primary); box-shadow:inset 0 0 0 1px var(--primary)}
.todo-on .todo-n{color:var(--primary)}
.todo-warn{background:var(--warn-bg); border-color:var(--warn-bd)}
.todo-warn .todo-n{color:var(--warn-fg)}
.dash-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:16px}
.card-title{font-size:17px; margin:0 0 14px}
.prog-line{margin-bottom:14px}
.prog-head{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; font-size:15px; gap:10px}
.bar{height:10px; background:var(--soft); border-radius:999px; overflow:hidden}
.bar-fill{height:100%; background:var(--primary); border-radius:999px}
.recent-item{display:flex; align-items:center; gap:10px; padding:11px 0; border-bottom:1px solid var(--border); text-decoration:none; color:var(--fg)}
.recent-item:last-child{border-bottom:0}
.recent-co{font-weight:600}
.card-overdue{border-color:var(--no-bd)}
.card-urgent{border-color:var(--warn-bd)}
@media (max-width:680px){ .dash-grid{grid-template-columns:1fr} }

/* ===== 유형별 보고서 양식 ===== */
.req{color:var(--danger); font-weight:700}
.score-field input{max-width:130px}
.score-line{margin:6px 0 12px}
.score-head{display:flex; justify-content:space-between; font-size:15px; margin-bottom:5px; gap:10px}

/* 진단 — 지표 한 줄 + SWOT 2x2 */
.indicator-row{display:grid; grid-template-columns:108px 76px 1fr; gap:10px; align-items:start; margin:0 0 12px}
.ind-label{font-weight:600; padding-top:13px}
.indicator-row input.ind-score, .indicator-row textarea.ind-desc{margin-top:0}
.ind-score{text-align:center}
.indicator-row.view{grid-template-columns:108px 70px 1fr; align-items:start}
.indicator-row.view .ind-label{padding-top:14px}
.ind-score-v{font-weight:700; padding-top:14px; white-space:nowrap}
.swot-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:4px 0 6px}
.swot-cell{margin:0 !important}
.swot-cell textarea{margin-top:6px; min-height:160px}
.swot-h{font-weight:600; margin-bottom:6px}
.swot-cell .report-text{min-height:130px}
@media (max-width:560px){
  .indicator-row, .indicator-row.view{grid-template-columns:1fr}
  .ind-label, .indicator-row.view .ind-label, .ind-score-v{padding-top:0}
  .ind-score{max-width:120px}
  .swot-grid{grid-template-columns:1fr}
}
