/* portal.css — 세이프스쿨 포털 공유 스타일 (거래처 로그인 + 직원·관리자 로그인) */
:root{
  --font-sans:'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,system-ui,'Segoe UI',Roboto,'Apple SD Gothic Neo','Noto Sans KR','Malgun Gothic','맑은 고딕',sans-serif;
  --font-mono:ui-monospace,'SF Mono',Menlo,Consolas,monospace;

  /* brand — green default (Tweaks overrides at runtime) */
  --primary:#1F7A4D;
  --primary-hover:#186340;
  --primary-press:#12502F;
  --primary-tint:#E7F3EC;
  --primary-deep:#16613B;
  --accent:#2FA86A;

  --ink-1:#15211B;
  --ink-2:#3A4640;
  --ink-3:#6C776F;
  --line:#E5E9E6;
  --line-soft:#EFF2F0;
  --bg:#FFFFFF;
  --bg-soft:#F6F8F6;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;height:100%;}
body{
  font-family:var(--font-sans);
  color:var(--ink-2);
  background:var(--bg);
  line-height:1.6;
  word-break:keep-all;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4{color:var(--ink-1);margin:0;line-height:1.2;letter-spacing:-0.02em;font-weight:700;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
input{font-family:inherit;}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;}
::selection{background:var(--primary-tint);}

/* ───────────── portal split ───────────── */
.portal{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,0.98fr);min-height:100vh;}

/* brand side */
.brand-side{position:relative;overflow:hidden;background:var(--primary);color:#fff;
  display:flex;flex-direction:column;padding:48px 56px 40px;}
.brand-side.is-staff{background:var(--primary-deep);}
.brand-side::before{content:"";position:absolute;right:-180px;bottom:-180px;width:520px;height:520px;border-radius:50%;
  background:rgba(255,255,255,.05);}
.brand-side::after{content:"";position:absolute;left:-120px;top:-140px;width:340px;height:340px;border-radius:50%;
  background:rgba(0,0,0,.06);}
.bs-logo{display:flex;align-items:center;gap:11px;position:relative;z-index:1;}
.bs-logo .name{font-size:21px;font-weight:800;color:#fff;letter-spacing:-0.02em;white-space:nowrap;}
.bs-logo .tagchip{margin-left:4px;font-size:11.5px;font-weight:700;letter-spacing:.02em;
  color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);
  padding:4px 9px;border-radius:999px;white-space:nowrap;}
.bs-head{margin-top:54px;position:relative;z-index:1;}
.bs-head h1{color:#fff;font-size:clamp(32px,3.6vw,50px);line-height:1.1;letter-spacing:-0.03em;}
.bs-head .sub{color:rgba(255,255,255,.82);font-size:17px;margin-top:18px;max-width:26em;line-height:1.6;}

.areas-label{position:relative;z-index:1;margin-top:48px;display:flex;align-items:center;gap:10px;white-space:nowrap;
  font-size:13px;font-weight:700;letter-spacing:.04em;color:rgba(255,255,255,.72);text-transform:uppercase;}
.areas-label::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.2);}
.area-grid{position:relative;z-index:1;margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.area-tile{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:15px 16px;color:#fff;
  transition:background .15s ease,border-color .15s ease,transform .15s ease;cursor:pointer;}
.area-tile:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);transform:translateY(-1px);}
.area-tile .at-ic{flex:0 0 auto;display:grid;place-items:center;width:36px;height:36px;border-radius:9px;
  background:rgba(255,255,255,.14);color:#fff;}
.area-tile .at-label{font-size:14.5px;font-weight:600;line-height:1.3;letter-spacing:-0.01em;}

/* staff feature list (직원 화면 좌측) */
.feat-list{position:relative;z-index:1;margin-top:18px;display:flex;flex-direction:column;gap:14px;}
.feat-row{display:flex;align-items:flex-start;gap:13px;color:#fff;}
.feat-row .fr-ic{flex:0 0 auto;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.14);color:#fff;margin-top:1px;}
.feat-row .t{font-size:15px;font-weight:700;}
.feat-row .d{font-size:13.5px;color:rgba(255,255,255,.74);line-height:1.45;}

.bs-contact{position:relative;z-index:1;margin-top:auto;padding-top:40px;display:flex;flex-wrap:wrap;gap:8px 22px;
  font-size:13.5px;color:rgba(255,255,255,.72);}
.bs-contact .c{display:flex;align-items:center;gap:7px;white-space:nowrap;}
.bs-contact .c svg{opacity:.85;}

/* login side */
.login-side{position:relative;display:flex;align-items:center;justify-content:center;
  padding:48px;background:var(--bg);}
.portal-badge{position:absolute;top:26px;right:30px;font-size:12.5px;font-weight:700;color:var(--primary);
  background:var(--primary-tint);padding:7px 13px;border-radius:999px;white-space:nowrap;}
.login-card{width:100%;max-width:392px;}
.login-card h2{font-size:27px;letter-spacing:-0.02em;}
.login-card .lc-sub{color:var(--ink-3);font-size:15px;margin-top:9px;margin-bottom:30px;}

/* role segment (직원/관리자) */
.seg{display:flex;gap:6px;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:5px;margin-bottom:24px;}
.seg button{flex:1;border:none;background:none;height:40px;border-radius:8px;font-size:13.5px;font-weight:600;
  color:var(--ink-3);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;
  transition:background .15s ease,color .15s ease,box-shadow .15s ease;white-space:nowrap;}
.seg button.on{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.09);}

.field{margin-bottom:17px;}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink-2);margin-bottom:8px;}
.input-wrap{position:relative;display:flex;align-items:center;}
.input-ic{position:absolute;left:15px;color:var(--ink-3);display:flex;pointer-events:none;}
.input{width:100%;height:50px;border:1px solid var(--line);border-radius:11px;padding:0 16px 0 44px;
  font-size:15px;color:var(--ink-1);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;}
.input::placeholder{color:#A6ADA8;}
.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}
.input.err{border-color:#D64545;box-shadow:0 0 0 3px #fbe6e6;}
.eye-btn{position:absolute;right:8px;background:none;border:none;color:var(--ink-3);padding:8px;
  display:flex;border-radius:8px;transition:color .15s ease,background .15s ease;}
.eye-btn:hover{color:var(--ink-1);background:var(--bg-soft);}
.field-msg{font-size:12.5px;color:#D64545;margin-top:7px;min-height:0;}

.row-between{display:flex;align-items:center;justify-content:space-between;margin:4px 0 22px;}
.check{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--ink-2);cursor:pointer;user-select:none;white-space:nowrap;}
.check input{position:absolute;opacity:0;width:0;height:0;}
.check .box{width:18px;height:18px;border:1.6px solid var(--line);border-radius:5px;display:grid;place-items:center;
  color:#fff;transition:background .15s ease,border-color .15s ease;}
.check input:checked + .box{background:var(--primary);border-color:var(--primary);}
.check .box svg{opacity:0;transition:opacity .12s ease;}
.check input:checked + .box svg{opacity:1;}
.link{font-size:14px;font-weight:600;color:var(--primary);white-space:nowrap;}
.link:hover{text-decoration:underline;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:11px;white-space:nowrap;
  font-weight:700;font-size:15.5px;line-height:1;padding:0 20px;height:50px;
  transition:background .15s ease,color .15s ease,box-shadow .15s ease,transform .12s ease;}
.btn-primary{width:100%;background:var(--primary);color:#fff;box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 24%,transparent);}
.btn-primary:hover{background:var(--primary-hover);}
.btn-primary:active{background:var(--primary-press);transform:translateY(1px);}
.btn-primary:disabled{opacity:.65;cursor:default;box-shadow:none;}
.btn-ghost{width:100%;background:#fff;color:var(--ink-1);border:1px solid var(--line);}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-tint);}

.divider{display:flex;align-items:center;gap:14px;color:var(--ink-3);font-size:12.5px;margin:22px 0;white-space:nowrap;}
.divider::before,.divider::after{content:"";height:1px;background:var(--line);flex:1;}
.help{text-align:center;font-size:13.5px;color:var(--ink-3);margin-top:22px;line-height:1.7;}
.help a{color:var(--primary);font-weight:600;}

/* ── discreet cross-login link (거래처↔임직원) ── */
.alt-login{margin-top:26px;padding-top:18px;border-top:1px solid var(--line);text-align:center;}
.alt-login a{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink-3);
  padding:8px 14px;border-radius:9px;transition:color .15s ease,background .15s ease;white-space:nowrap;}
.alt-login a:hover{color:var(--primary);background:var(--bg-soft);}
.alt-login a svg{opacity:.85;}
.alt-login a .arr{margin-left:1px;transition:transform .15s ease;}
.alt-login a:hover .arr{transform:translateX(3px);}
.note-line{font-size:12px;color:var(--ink-3);text-align:center;margin-top:12px;line-height:1.6;}
.note-line a{color:var(--ink-2);font-weight:600;text-decoration:underline;text-underline-offset:2px;}

/* notice toast */
.notice{display:flex;align-items:center;gap:10px;background:var(--primary-tint);color:var(--primary-deep);
  border:1px solid color-mix(in srgb,var(--primary) 24%,transparent);border-radius:11px;
  padding:12px 14px;font-size:13.5px;font-weight:600;margin-bottom:20px;}
.notice svg{flex:0 0 auto;}

/* spinner */
.spin{width:17px;height:17px;border:2.2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ───────────── centered variant ───────────── */
.portal.centered{display:block;background:var(--bg-soft);}
.portal.centered .brand-side,.portal.centered .login-side{all:unset;}
.centered-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px 24px;text-align:center;}
.centered-wrap .cw-logo{display:flex;align-items:center;gap:11px;color:var(--primary);margin-bottom:20px;}
.centered-wrap .cw-logo .name{font-size:20px;font-weight:800;color:var(--ink-1);}
.centered-wrap h1{font-size:clamp(26px,3vw,34px);letter-spacing:-0.02em;}
.centered-wrap .cw-sub{color:var(--ink-3);font-size:16px;margin-top:12px;}
.cw-card{width:100%;max-width:404px;background:#fff;border:1px solid var(--line);border-radius:18px;
  box-shadow:0 12px 40px rgba(21,33,27,.08);padding:36px 34px;margin-top:34px;text-align:left;}
.cw-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:30px;max-width:560px;}
.cw-chip{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink-2);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 15px;}
.cw-chip svg{color:var(--primary);}
.cw-contact{margin-top:30px;font-size:13px;color:var(--ink-3);display:flex;flex-wrap:wrap;gap:6px 20px;justify-content:center;}

/* responsive */
@media(max-width:920px){
  .portal{grid-template-columns:1fr;min-height:0;}
  .brand-side{padding:30px 24px 26px;}
  .brand-side::before{width:300px;height:300px;right:-130px;bottom:-150px;}
  .brand-side::after{display:none;}
  .bs-logo .name{font-size:19px;}
  .bs-head{margin-top:22px;}
  .bs-head h1{font-size:30px;}
  .bs-head .sub{font-size:15px;margin-top:12px;}
  .areas-label{margin-top:28px;}
  .area-grid{margin-top:14px;gap:9px;}
  .area-tile{padding:13px 14px;}
  .feat-list{margin-top:20px;gap:12px;}
  .bs-contact{padding-top:26px;font-size:13px;gap:6px 18px;}
  .login-side{padding:36px 24px 48px;align-items:flex-start;}
  .portal-badge{display:none;}
  .login-card{margin:0 auto;max-width:420px;}
}
@media(max-width:380px){
  .area-grid{grid-template-columns:1fr;}
  .bs-head h1{font-size:27px;}
}
/* centered variant on mobile */
@media(max-width:560px){
  .cw-card{padding:30px 22px;}
  .centered-wrap{padding:40px 18px;}
}

/* ═══════════ 우리 학교 찾기 (Find School) ═══════════ */
.wrap2{max-width:1120px;margin:0 auto;padding:0 28px;}
.finder-page{background:var(--bg-soft);min-height:100vh;}

.finder-top{position:sticky;top:0;z-index:30;background:var(--primary);color:#fff;}
.finder-top .wrap2{display:flex;align-items:center;justify-content:space-between;height:64px;}
.ft-left{display:flex;align-items:center;gap:14px;min-width:0;}
.ft-brand{display:flex;align-items:center;gap:10px;color:#fff;}
.ft-brand .name{font-weight:800;font-size:18px;color:#fff;letter-spacing:-0.02em;white-space:nowrap;}
.ft-sep{width:1px;height:20px;background:rgba(255,255,255,.3);}
.ft-title{font-size:14.5px;font-weight:600;color:rgba(255,255,255,.92);white-space:nowrap;}
.ft-logout{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:#fff;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:8px 14px;border-radius:9px;
  transition:background .15s ease;white-space:nowrap;}
.ft-logout:hover{background:rgba(255,255,255,.24);}

.finder-body{padding:38px 0 72px;}
.finder-head h1{font-size:clamp(26px,3vw,32px);letter-spacing:-0.02em;}
.finder-head .sub{color:var(--ink-3);font-size:16px;margin-top:9px;}

.finder-tools{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:26px;}
.search-box{position:relative;display:flex;align-items:center;flex:1;min-width:240px;max-width:400px;}
.search-box .input-ic{position:absolute;left:15px;color:var(--ink-3);display:flex;pointer-events:none;}
.search-box input{width:100%;height:48px;border:1px solid var(--line);border-radius:11px;padding:0 16px 0 44px;
  font-size:15px;color:var(--ink-1);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;}
.search-box input::placeholder{color:#A6ADA8;}
.search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}

.region-chips{display:flex;gap:8px;flex-wrap:wrap;}
.rchip{font-size:13.5px;font-weight:600;color:var(--ink-2);background:#fff;border:1px solid var(--line);
  padding:9px 15px;border-radius:999px;cursor:pointer;transition:all .15s ease;white-space:nowrap;}
.rchip:hover{border-color:var(--primary);color:var(--primary);}
.rchip.on{background:var(--primary);border-color:var(--primary);color:#fff;}

.legend{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--ink-3);margin:22px 0 4px;}
.legend .lg{display:flex;align-items:center;gap:8px;white-space:nowrap;}
.legend .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto;}
.legend .dot.mine{background:var(--primary);}
.legend .dot.lock{background:#fff;border:1.5px solid var(--border-strong,#C9CFCB);}

.finder-notice{display:flex;align-items:center;gap:10px;background:var(--primary-tint);color:var(--primary-deep);
  border:1px solid color-mix(in srgb,var(--primary) 24%,transparent);border-radius:12px;
  padding:14px 16px;font-size:14.5px;font-weight:700;margin:22px 0 0;}

.region-section{margin-top:34px;}
.region-title{display:flex;align-items:center;gap:11px;font-size:15px;font-weight:700;color:var(--ink-1);margin-bottom:14px;}
.region-title .rt-badge{font-size:12px;font-weight:700;color:var(--primary);background:var(--primary-tint);
  padding:3px 9px;border-radius:999px;font-variant-numeric:tabular-nums;}
.region-title::after{content:"";flex:1;height:1px;background:var(--line);}

.school-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:12px;}
.school-item{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease;}
.school-item .no{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:var(--bg-soft);color:var(--ink-3);
  font-size:13px;font-weight:700;display:grid;place-items:center;font-variant-numeric:tabular-nums;}
.school-item .smeta{min-width:0;}
.school-item .sname{font-size:15px;font-weight:600;color:var(--ink-1);line-height:1.3;}
.school-item .sregion{font-size:12.5px;color:var(--ink-3);margin-top:2px;}
.school-item .tail{margin-left:auto;flex:0 0 auto;display:flex;align-items:center;color:#B7BDB9;}

.school-item.is-mine{border-color:var(--primary);background:var(--primary-tint);cursor:pointer;}
.school-item.is-mine .no{background:var(--primary);color:#fff;}
.school-item.is-mine .tail{color:var(--primary);}
.school-item.is-mine:hover{transform:translateY(-2px);box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 18%,transparent);}
.school-item.is-mine:hover .tail .arr{transform:translateX(3px);}
.school-item.is-mine .tail .arr{transition:transform .15s ease;}
.mine-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;color:#fff;background:var(--primary);
  padding:3px 8px;border-radius:999px;margin-right:7px;vertical-align:middle;white-space:nowrap;}

.school-item.is-locked{opacity:.62;cursor:not-allowed;}
.school-item.is-locked:active{transform:none;}

.finder-empty{text-align:center;color:var(--ink-3);font-size:15px;padding:56px 0;}

/* toast */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(8px);background:var(--ink-1);color:#fff;
  padding:13px 18px;border-radius:11px;font-size:14px;font-weight:600;box-shadow:0 12px 34px rgba(0,0,0,.28);
  z-index:60;display:flex;align-items:center;gap:9px;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast svg{color:#FFC46B;}

@media(max-width:640px){
  .wrap2{padding:0 18px;}
  .ft-title{display:none;}
  .ft-sep{display:none;}
  .school-grid{grid-template-columns:1fr;}
}

/* ── 학교명 검색 (API 조회) ── */
.search-row{display:flex;gap:10px;margin-top:24px;max-width:640px;}
.search-row .search-box{flex:1;max-width:none;min-width:0;}
.btn-search{flex:0 0 auto;width:auto;height:48px;padding:0 26px;background:var(--primary);color:#fff;border:none;
  border-radius:11px;font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 22%,transparent);transition:background .15s ease,transform .12s ease;white-space:nowrap;}
.btn-search:hover{background:var(--primary-hover);}
.btn-search:active{background:var(--primary-press);transform:translateY(1px);}

.results-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:32px;}
.results-head .rh-title{font-size:16px;font-weight:700;color:var(--ink-1);}
.results-head .rh-title b{color:var(--primary);}
.results-head .rh-title .cnt{color:var(--ink-3);font-weight:600;margin-left:7px;}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink-3);
  cursor:pointer;background:none;border:none;padding:6px 4px;transition:color .15s ease;}
.back-link:hover{color:var(--primary);}
.back-link .arr{transition:transform .15s ease;}
.back-link:hover .arr{transform:translateX(-3px);}

.results-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;margin-top:16px;}

.spill{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;
  margin-right:7px;vertical-align:middle;white-space:nowrap;}
.spill.mine{color:#fff;background:var(--primary);}
.spill.reg{color:var(--primary);background:var(--primary-tint);}
.spill.unreg{color:var(--ink-3);background:var(--bg-soft);border:1px solid var(--line);}

.school-item.is-unreg{cursor:pointer;}
.school-item.is-unreg .no{background:var(--bg-soft);color:var(--ink-3);}
.reg-cta{font-size:12.5px;font-weight:700;color:var(--primary);white-space:nowrap;}

@media(max-width:640px){
  .search-row{flex-wrap:wrap;}
  .btn-search{width:100%;}
  .results-list{grid-template-columns:1fr;}
}

/* ═══════════ 학교 전용 페이지 (마이페이지) ═══════════ */
.school-page{background:var(--bg-soft);min-height:100vh;}
.ft-schoolchip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#fff;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);padding:4px 10px;border-radius:999px;white-space:nowrap;}

.sp-body{padding:30px 0 76px;}
.sp-hero{margin-bottom:8px;}
.sp-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.sp-title{font-size:clamp(24px,2.6vw,30px);font-weight:800;letter-spacing:-0.02em;color:var(--ink-1);}
.sp-status{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--primary);
  background:var(--primary-tint);padding:5px 11px;border-radius:999px;white-space:nowrap;}
.sp-sub{color:var(--ink-3);font-size:14.5px;margin-top:7px;}

.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:20px;}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;}
.stat-card .lbl{font-size:12.5px;color:var(--ink-3);font-weight:600;display:flex;align-items:center;gap:7px;}
.stat-card .lbl svg{color:var(--primary);}
.stat-card .val{font-size:18px;font-weight:800;color:var(--ink-1);margin-top:9px;letter-spacing:-0.01em;}
.stat-card .val.ok{color:var(--primary);}

.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;margin-top:22px;}
.section-h{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.section-h .sh-l{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.section-h h2{font-size:18px;font-weight:700;color:var(--ink-1);white-space:nowrap;}
.section-h .sh-ic{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--primary-tint);color:var(--primary);}
.section-h .sh-cnt{font-size:13px;color:var(--ink-3);font-weight:600;white-space:nowrap;}

/* board toolbar */
.board-tools{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.area-filter{display:flex;gap:8px;flex-wrap:wrap;}
.afchip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-2);
  background:#fff;border:1px solid var(--line);padding:8px 13px;border-radius:999px;cursor:pointer;transition:all .15s ease;white-space:nowrap;}
.afchip:hover{border-color:var(--ink-3);}
.afchip.on{background:var(--ink-1);border-color:var(--ink-1);color:#fff;}
.afchip .adot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.view-toggle{display:flex;gap:4px;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:4px;flex:0 0 auto;}
.view-toggle button{display:flex;align-items:center;gap:7px;height:36px;padding:0 14px;border:none;background:none;
  border-radius:7px;font-size:13.5px;font-weight:600;color:var(--ink-3);cursor:pointer;transition:all .15s ease;white-space:nowrap;}
.view-toggle button.on{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.1);}

/* kanban */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;}
.kcol{flex:1 1 0;min-width:262px;background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:12px;
  padding:12px;display:flex;flex-direction:column;gap:10px;}
.kcol-h{display:flex;align-items:center;gap:9px;padding:3px 5px 7px;}
.kcol-h .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.kcol-h .kt{font-size:13.5px;font-weight:700;color:var(--ink-2);white-space:nowrap;}
.kcol-h .cnt{margin-left:auto;font-size:12px;color:var(--ink-3);background:#fff;border:1px solid var(--line);border-radius:999px;padding:2px 9px;font-variant-numeric:tabular-nums;}
.kcol-empty{font-size:13px;color:var(--ink-4,#9aa39d);text-align:center;padding:18px 0;}
.kcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px 14px;cursor:pointer;
  transition:box-shadow .15s ease,transform .15s ease,border-color .15s ease;}
.kcard:hover{box-shadow:0 7px 18px rgba(19,32,46,.09);transform:translateY(-2px);border-color:var(--border-strong,#cfd5d0);}
.kcard .ktitle{font-size:14.5px;font-weight:700;color:var(--ink-1);line-height:1.36;}
.kcard .kmeta{display:flex;align-items:center;gap:8px;margin-top:11px;flex-wrap:wrap;}
.area-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;}
.area-chip .adot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;}
.kdate{font-size:12px;color:var(--ink-3);display:inline-flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums;}
.kbar{height:6px;background:#EAEEEB;border-radius:999px;margin-top:11px;overflow:hidden;}
.kbar>i{display:block;height:100%;background:var(--primary);border-radius:999px;}
.kfoot{display:flex;align-items:center;justify-content:space-between;margin-top:11px;}
.avatar{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-3);font-weight:600;}
.avatar .ava{width:24px;height:24px;border-radius:50%;background:var(--primary-tint);color:var(--primary);
  font-size:10.5px;font-weight:800;display:grid;place-items:center;}
.sbadge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;white-space:nowrap;}
.sbadge.review{color:#8A6D00;background:#FFF3CD;}
.sbadge.progress{color:var(--primary);background:var(--primary-tint);}
.sbadge.done{color:var(--ink-3);background:#EEF1EE;border:1px solid var(--line);}

/* list view */
.ptable-wrap{overflow-x:auto;}
.ptable{width:100%;border-collapse:collapse;min-width:680px;}
.ptable th{text-align:left;font-size:12.5px;color:var(--ink-3);font-weight:700;padding:0 12px 11px;border-bottom:1px solid var(--line);}
.ptable td{padding:14px 12px;border-bottom:1px solid var(--line-soft);font-size:14px;color:var(--ink-2);vertical-align:middle;}
.ptable tr:last-child td{border-bottom:none;}
.ptable tbody tr{cursor:pointer;transition:background .12s ease;}
.ptable tbody tr:hover td{background:var(--bg-soft);}
.ptable .pname{font-weight:600;color:var(--ink-1);}
.ptable .pprog{display:flex;align-items:center;gap:9px;min-width:120px;}
.ptable .pprog .bar{flex:1;height:6px;background:#EAEEEB;border-radius:999px;overflow:hidden;}
.ptable .pprog .bar>i{display:block;height:100%;background:var(--primary);}
.ptable .pprog .pct{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;width:34px;text-align:right;}

/* Q&A */
.qna-list{display:flex;flex-direction:column;}
.qna-row{display:flex;align-items:center;gap:14px;padding:14px 4px;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:background .12s ease;border-radius:8px;}
.qna-row:last-child{border-bottom:none;}
.qna-row:hover{background:var(--bg-soft);}
.qna-ic{flex:0 0 auto;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--bg-soft);color:var(--ink-3);}
.qna-main{flex:1;min-width:0;}
.qna-title{font-size:14.5px;font-weight:600;color:var(--ink-1);line-height:1.35;}
.qna-meta{font-size:12.5px;color:var(--ink-3);margin-top:4px;display:flex;gap:12px;flex-wrap:wrap;}
.qna-meta span{white-space:nowrap;}
.qbadge{font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;white-space:nowrap;flex:0 0 auto;}
.qbadge.done{color:var(--primary);background:var(--primary-tint);}
.qbadge.wait{color:#8A6D00;background:#FFF3CD;}

/* school info + 2col */
.sp-2col{display:grid;grid-template-columns:1.1fr 0.9fr;gap:20px;align-items:start;}
.sp-2col .panel{margin-top:0;}
.info-grid{display:grid;grid-template-columns:1fr;}
.info-row{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid var(--line-soft);}
.info-row:last-child{border-bottom:none;}
.info-row .k{color:var(--ink-3);font-size:13.5px;flex:0 0 auto;white-space:nowrap;}
.info-row .v{color:var(--ink-1);font-size:14px;font-weight:600;text-align:right;}
.btn-mini{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:9px;
  background:var(--primary);color:#fff;border:none;font-size:13.5px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease;}
.btn-mini:hover{background:var(--primary-hover);}
.btn-mini.ghost{background:#fff;color:var(--ink-2);border:1px solid var(--line);}
.btn-mini.ghost:hover{border-color:var(--primary);color:var(--primary);}

@media(max-width:1000px){
  .stat-cards{grid-template-columns:repeat(2,1fr);}
  .sp-2col{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .stat-cards{grid-template-columns:1fr;}
  .board-tools{align-items:stretch;}
}

/* 직원(담당 매니저) 화면 — role chip / 편집 / 활동 로그 */
.ft-schoolchip.staff{background:rgba(255,255,255,.22);}
.sp-rolebar{display:flex;align-items:center;gap:9px;background:#FFF8E6;border:1px solid #F2E2B0;color:#7A5E00;
  border-radius:11px;padding:11px 15px;font-size:13.5px;font-weight:600;margin-top:16px;}
.sp-rolebar svg{color:#C9961A;flex:0 0 auto;}

.info-input{width:60%;max-width:260px;height:40px;border:1px solid var(--line);border-radius:9px;padding:0 12px;
  font-size:14px;color:var(--ink-1);background:#fff;text-align:right;transition:border-color .15s ease,box-shadow .15s ease;}
.info-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}
.info-row.is-editable .v{color:var(--primary);}
.edit-actions{display:flex;gap:8px;}

.log-list{display:flex;flex-direction:column;}
.log-row{display:flex;gap:13px;padding:13px 4px;border-bottom:1px solid var(--line-soft);}
.log-row:last-child{border-bottom:none;}
.log-row.fresh{background:var(--primary-tint);border-radius:8px;border-bottom-color:transparent;}
.log-dot{margin-top:6px;width:8px;height:8px;border-radius:50%;background:var(--primary);flex:0 0 auto;}
.log-main{flex:1;min-width:0;}
.log-action{font-size:14px;color:var(--ink-1);font-weight:600;line-height:1.4;}
.log-meta{font-size:12.5px;color:var(--ink-3);margin-top:4px;display:flex;gap:14px;flex-wrap:wrap;}
.log-meta span{white-space:nowrap;}
.log-meta span{white-space:nowrap;}
.log-actor{font-weight:600;}
.log-note{font-size:12.5px;color:var(--ink-3);margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);line-height:1.6;}

/* ─────────── 프로젝트 관리 상세 ─────────── */
.pd-top{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:6px;}
.pd-back{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink-3);
  background:none;border:none;cursor:pointer;padding:6px 4px;transition:color .15s ease;white-space:nowrap;}
.pd-back:hover{color:var(--primary);}
.pd-back .arr{transition:transform .15s ease;}
.pd-back:hover .arr{transform:translateX(-3px);}
.pd-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:6px 0 4px;}
.pd-head > div:first-child{flex:1;min-width:240px;}
.pd-title{font-size:clamp(22px,2.6vw,28px);font-weight:800;letter-spacing:-0.02em;color:var(--ink-1);}
.pd-titlemeta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px;}
.pd-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.stage-select{height:40px;border:1px solid var(--line);border-radius:9px;padding:0 12px;font-size:13.5px;font-weight:600;
  color:var(--ink-1);background:#fff;font-family:inherit;cursor:pointer;}
.stage-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}

.pd-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--line-soft);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:18px 0 22px;}
.pd-ov{background:#fff;padding:14px 16px;}
.pd-ov .k{font-size:12px;color:var(--ink-3);font-weight:600;}
.pd-ov .v{font-size:15px;color:var(--ink-1);font-weight:700;margin-top:6px;font-variant-numeric:tabular-nums;}

.pd-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:20px;align-items:start;}
.pd-grid .panel{margin-top:0;margin-bottom:20px;}
.pd-grid .col-side .panel:last-child{margin-bottom:0;}
@media(max-width:980px){.pd-grid{grid-template-columns:1fr;}}

/* 과업 명세 체크리스트 (구독형 연간관리) */
.scope-cat{margin-bottom:18px;}
.scope-cat:last-child{margin-bottom:0;}
.scope-cat-h{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:700;color:var(--ink-1);margin-bottom:10px;}
.scope-cat-h .rt-badge{font-size:11.5px;font-weight:700;color:var(--primary);background:var(--primary-tint);padding:2px 8px;border-radius:999px;font-variant-numeric:tabular-nums;}
.scope-item{display:flex;align-items:flex-start;gap:11px;padding:9px 4px;border-radius:8px;cursor:pointer;transition:background .12s ease;}
.scope-item:hover{background:var(--bg-soft);}
.scope-item .chk{width:20px;height:20px;border-radius:6px;border:1.6px solid var(--line);flex:0 0 auto;margin-top:1px;
  display:grid;place-items:center;color:#fff;transition:all .15s ease;}
.scope-item.done .chk{background:var(--primary);border-color:var(--primary);}
.scope-item .chk svg{opacity:0;transition:opacity .12s ease;}
.scope-item.done .chk svg{opacity:1;}
.scope-item .st{font-size:14px;color:var(--ink-2);line-height:1.5;}
.scope-item.done .st{color:var(--ink-3);text-decoration:line-through;text-decoration-color:var(--line-strong,#c9cfca);}
.scope-readonly .scope-item{cursor:default;}
.scope-readonly .scope-item:hover{background:transparent;}

/* 정산 요약 (유지보수·용역) */
.settle-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px;}
@media(max-width:680px){.settle-cards{grid-template-columns:repeat(2,1fr);}}
.settle-card{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:11px;padding:13px 15px;}
.settle-card .k{font-size:12px;color:var(--ink-3);font-weight:600;}
.settle-card .v{font-size:18px;color:var(--ink-1);font-weight:800;margin-top:7px;font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
.settle-card .v.neg{color:var(--c-danger,#C0392B);}
.settle-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--ink-3);margin-bottom:6px;}
.settle-meta span{white-space:nowrap;}
.settle-meta b{color:var(--ink-1);font-variant-numeric:tabular-nums;}

.wktable-wrap{overflow-x:auto;}
.wktable{width:100%;border-collapse:collapse;min-width:520px;}
.wktable th{text-align:left;font-size:12px;color:var(--ink-3);font-weight:700;padding:0 10px 10px;border-bottom:1px solid var(--line);white-space:nowrap;}
.wktable td{padding:11px 10px;border-bottom:1px solid var(--line-soft);font-size:13.5px;color:var(--ink-2);}
.wktable tr:last-child td{border-bottom:none;}
.wktable td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;}
.wktable .wk-no{color:var(--ink-3);font-variant-numeric:tabular-nums;}

/* 일정 타임라인 */
.sched-list{display:flex;flex-direction:column;}
.sched-row{display:flex;gap:13px;padding:12px 4px;border-bottom:1px solid var(--line-soft);}
.sched-row:last-child{border-bottom:none;}
.sched-date{flex:0 0 auto;width:88px;font-size:12.5px;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums;}
.sched-main .t{font-size:14px;font-weight:600;color:var(--ink-1);}
.sched-main .w{font-size:12.5px;color:var(--ink-3);margin-top:3px;}

/* 파견인력 */
.pstaff{display:flex;flex-direction:column;gap:10px;}
.pstaff-row{display:flex;align-items:center;gap:12px;padding:11px 12px;background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:11px;}
.pstaff-row .ava{width:36px;height:36px;border-radius:50%;background:var(--primary-tint);color:var(--primary);display:grid;place-items:center;font-size:12px;font-weight:800;flex:0 0 auto;}
.pstaff-row .pn{font-size:14px;font-weight:700;color:var(--ink-1);}
.pstaff-row .pr{font-size:12.5px;color:var(--ink-3);margin-top:2px;}

/* 소통(코멘트) */
.cmt-list{display:flex;flex-direction:column;gap:14px;margin-bottom:16px;}
.cmt{display:flex;flex-direction:column;gap:5px;max-width:88%;}
.cmt.staff{align-self:flex-start;}
.cmt.school{align-self:flex-end;align-items:flex-end;}
.cmt .bubble{padding:11px 14px;border-radius:13px;font-size:13.5px;line-height:1.5;}
.cmt.staff .bubble{background:var(--bg-soft);color:var(--ink-1);border-top-left-radius:4px;}
.cmt.school .bubble{background:var(--primary);color:#fff;border-top-right-radius:4px;}
.cmt .meta{font-size:11.5px;color:var(--ink-3);}
.cmt-form{display:flex;gap:8px;border-top:1px solid var(--line);padding-top:14px;}
.cmt-form input{flex:1;height:44px;border:1px solid var(--line);border-radius:10px;padding:0 14px;font-size:14px;color:var(--ink-1);font-family:inherit;}
.cmt-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}
.cmt-send{flex:0 0 auto;width:46px;border-radius:10px;background:var(--primary);color:#fff;border:none;display:grid;place-items:center;cursor:pointer;transition:background .15s ease;}
.cmt-send:hover{background:var(--primary-hover);}

/* ═══════════ 관리자 대시보드 ═══════════ */
.admin{display:flex;min-height:100vh;background:var(--bg-soft);}
.admin-side{width:250px;flex:0 0 250px;background:var(--primary-deep);color:rgba(255,255,255,.85);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:18px 14px;}
.as-brand{display:flex;align-items:center;gap:10px;padding:8px 10px 6px;color:#fff;}
.as-brand .name{font-weight:800;font-size:18px;color:#fff;letter-spacing:-0.02em;white-space:nowrap;}
.as-rolechip{margin:8px 10px 16px;font-size:11.5px;font-weight:700;color:#fff;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);padding:5px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;width:fit-content;white-space:nowrap;}
.as-nav{display:flex;flex-direction:column;gap:4px;}
.as-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:9px;color:rgba(255,255,255,.82);
  font-size:14.5px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease;border:none;background:none;text-align:left;width:100%;white-space:nowrap;}
.as-item:hover{background:rgba(255,255,255,.1);color:#fff;}
.as-item.on{background:rgba(255,255,255,.18);color:#fff;}
.as-item .bn{margin-left:auto;font-size:11px;font-weight:700;background:rgba(255,255,255,.22);padding:2px 8px;border-radius:999px;}
.as-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.14);padding-top:14px;}
.as-user{display:flex;align-items:center;gap:11px;padding:4px 8px 10px;}
.as-user .ava{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800;flex:0 0 auto;}
.as-user .u-name{font-size:13.5px;font-weight:700;color:#fff;}
.as-user .u-role{font-size:12px;color:rgba(255,255,255,.6);}
.as-logout{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border-radius:9px;border:none;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.85);font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s ease;}
.as-logout:hover{background:rgba(255,255,255,.16);color:#fff;}

.admin-main{flex:1;min-width:0;display:flex;flex-direction:column;}
.admin-top{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.admin-top h1{font-size:20px;font-weight:800;letter-spacing:-0.02em;white-space:nowrap;}
.admin-top .at-actions{display:flex;gap:10px;align-items:center;}
.admin-content{padding:26px 28px 64px;}

/* KPI */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:16px;}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between;}
.kpi .k-ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--primary-tint);color:var(--primary);}
.kpi .k-trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--primary);background:var(--primary-tint);padding:3px 8px;border-radius:999px;white-space:nowrap;}
.kpi .k-trend.flat{color:var(--ink-3);background:var(--bg-soft);}
.kpi .k-val{font-size:30px;font-weight:800;color:var(--ink-1);margin-top:14px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;}
.kpi .k-lbl{font-size:13.5px;color:var(--ink-3);font-weight:600;margin-top:3px;}

.ov-2col{display:grid;grid-template-columns:1.25fr 1fr;gap:18px;margin-top:18px;}
.ov-2col .panel{margin-top:0;}

.barlist{display:flex;flex-direction:column;gap:14px;}
.barrow{display:flex;align-items:center;gap:12px;}
.barrow .bl-label{width:118px;flex:0 0 auto;font-size:13px;font-weight:600;color:var(--ink-2);display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.barrow .bl-label .adot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.barrow .bl-track{flex:1;height:10px;background:var(--bg-soft);border-radius:999px;overflow:hidden;}
.barrow .bl-track>i{display:block;height:100%;border-radius:999px;}
.barrow .bl-n{width:54px;text-align:right;font-size:13px;font-weight:700;color:var(--ink-1);font-variant-numeric:tabular-nums;}

/* admin tables */
.atoolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.atoolbar .left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.atable-wrap{overflow-x:auto;}
.atable{width:100%;border-collapse:collapse;min-width:720px;}
.atable th{text-align:left;font-size:12.5px;color:var(--ink-3);font-weight:700;padding:0 12px 12px;border-bottom:1px solid var(--line);white-space:nowrap;}
.atable td{padding:14px 12px;border-bottom:1px solid var(--line-soft);font-size:14px;color:var(--ink-2);vertical-align:middle;}
.atable tr:last-child td{border-bottom:none;}
.atable tbody tr.clickable{cursor:pointer;transition:background .12s ease;}
.atable tbody tr.clickable:hover td{background:var(--bg-soft);}
.atable .a-name{font-weight:700;color:var(--ink-1);}
.atable .a-sub{font-size:12px;color:var(--ink-3);margin-top:3px;font-variant-numeric:tabular-nums;}
.mini-stat{display:inline-flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums;}
.mini-stat .pill{font-size:12px;font-weight:700;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line-soft);padding:3px 9px;border-radius:999px;}

.abadge{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;}
.abadge.ok{color:var(--primary);background:var(--primary-tint);}
.abadge.wait{color:#8A6D00;background:#FFF3CD;}
.abadge.off{color:#8B5350;background:#F8E3E1;}
.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink-3);
  display:inline-grid;place-items:center;cursor:pointer;transition:all .15s ease;}
.icon-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-tint);}

.lbadge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;}
.lbadge.login{color:#0A4F97;background:#E4EDF9;}
.lbadge.qna{color:#6D4CD6;background:#EEEAFB;}
.lbadge.project{color:var(--primary);background:var(--primary-tint);}
.lbadge.account{color:#B45309;background:#FBEBD6;}
.lbadge.info{color:#0E7490;background:#DEF1F5;}
.lbadge.employee{color:#9A3412;background:#FBE7D8;}

.emp-role{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;}
.emp-role.manager{color:#0A4F97;background:#E4EDF9;}
.emp-role.dispatch{color:#6D4CD6;background:#EEEAFB;}

/* 배치 모달 — 인력 정보 카드 */
.assign-info{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:11px;padding:6px 14px;}
.ai-row{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft);}
.ai-row:last-child{border-bottom:none;}
.ai-ic{flex:0 0 auto;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);color:var(--primary);}
.ai-k{font-size:12px;color:var(--ink-3);font-weight:600;}
.ai-v{font-size:14px;color:var(--ink-1);font-weight:600;margin-top:3px;}

/* 사진 아바타 (Odoo hr.employee 사진) */
.photo-ava{border-radius:50%;background:var(--primary-tint);color:var(--primary);display:grid;place-items:center;flex:0 0 auto;overflow:hidden;}
.photo-ava img{width:100%;height:100%;object-fit:cover;display:block;}
.ph-edit{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;background:var(--primary);
  color:#fff;display:grid;place-items:center;border:2px solid #fff;}

/* 스마트 배치 (최적 인력 찾기) */
.sa-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.sa-form .fg-full{grid-column:1 / -1;}
.sa-hint{font-size:12.5px;color:var(--ink-3);margin:12px 0 4px;display:flex;align-items:center;gap:7px;}
.sa-results{display:flex;flex-direction:column;gap:10px;margin-top:6px;}
.sa-card{display:flex;align-items:center;gap:13px;border:1px solid var(--line);border-radius:12px;padding:12px 14px;transition:border-color .15s ease,background .15s ease;}
.sa-card.best{border-color:var(--primary);background:var(--primary-tint);}
.sa-card.conflict{opacity:.62;}
.sa-card .pa{width:46px;height:46px;font-size:13px;font-weight:800;}
.sa-card .sc-main{flex:1;min-width:0;}
.sa-card .sc-name{font-size:14.5px;font-weight:700;color:var(--ink-1);display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.sa-card .sc-skill{font-size:12.5px;color:var(--ink-3);margin-top:2px;}
.sa-card .sc-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.sc-tag{font-size:11px;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line-soft);padding:3px 8px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;}
.sc-tag.ok{color:var(--primary);background:#fff;border-color:color-mix(in srgb,var(--primary) 30%,transparent);}
.rec-badge{font-size:10.5px;font-weight:800;color:#fff;background:var(--primary);padding:2px 8px;border-radius:999px;white-space:nowrap;}
.conf-badge{font-size:11px;font-weight:700;color:#8B5350;background:#F8E3E1;padding:4px 9px;border-radius:999px;white-space:nowrap;flex:0 0 auto;}
.sa-btn{flex:0 0 auto;height:36px;padding:0 15px;border-radius:9px;background:var(--primary);color:#fff;border:none;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease;}
.sa-btn:hover{background:var(--primary-hover);}
.sa-empty{text-align:center;color:var(--ink-3);font-size:13.5px;padding:22px 0;}

/* ═══════════ 파견인력 모바일 포털 ═══════════ */
.field-page{background:var(--bg-soft);min-height:100vh;}
.field-top{position:sticky;top:0;z-index:30;background:var(--primary);color:#fff;}
.ft-wrap{max-width:520px;margin:0 auto;padding:0 18px;display:flex;align-items:center;justify-content:space-between;height:58px;}
.ft-brand{display:flex;align-items:center;gap:9px;color:#fff;}
.ft-brand .name{font-weight:800;font-size:16px;white-space:nowrap;}
.ft-brand .sub{font-size:11.5px;font-weight:700;color:rgba(255,255,255,.8);background:rgba(255,255,255,.16);padding:3px 8px;border-radius:999px;white-space:nowrap;}
.ft-out{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#fff;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:7px 11px;border-radius:9px;}
.field-body{max-width:520px;margin:0 auto;padding:18px 18px 56px;}
.fcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:16px;}
.fcard h3{font-size:15px;font-weight:700;color:var(--ink-1);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.fcard h3 .sh-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--primary-tint);color:var(--primary);}

/* 프로필 */
.fprofile{display:flex;align-items:center;gap:14px;}
.fprofile .pava{width:54px;height:54px;border-radius:50%;background:var(--primary-tint);color:var(--primary);display:grid;place-items:center;font-size:18px;font-weight:800;flex:0 0 auto;}
.fprofile .pn{font-size:18px;font-weight:800;color:var(--ink-1);letter-spacing:-0.02em;}
.fprofile .ps{font-size:13px;color:var(--ink-3);margin-top:2px;}
.fmeta{display:flex;flex-direction:column;gap:10px;margin-top:16px;}
.fmeta .m{display:flex;align-items:flex-start;gap:11px;font-size:13.5px;}
.fmeta .m svg{color:var(--primary);flex:0 0 auto;margin-top:2px;}
.fmeta .m .mk{color:var(--ink-3);width:64px;flex:0 0 auto;}
.fmeta .m .mv{color:var(--ink-1);font-weight:600;}
.fskills{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px;}
.fskill{font-size:12px;font-weight:700;color:var(--primary);background:var(--primary-tint);padding:5px 11px;border-radius:999px;white-space:nowrap;}

/* 요약 칩 */
.fsum{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.fsum .s{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:11px;padding:13px 10px;text-align:center;}
.fsum .s .v{font-size:22px;font-weight:800;color:var(--primary);font-variant-numeric:tabular-nums;}
.fsum .s .k{font-size:12px;color:var(--ink-3);margin-top:3px;font-weight:600;}

/* 캘린더 */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-title{font-size:15px;font-weight:800;color:var(--ink-1);font-variant-numeric:tabular-nums;}
.cal-nav{display:flex;gap:6px;}
.cal-nav button{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;transition:all .15s ease;}
.cal-nav button:hover{border-color:var(--primary);color:var(--primary);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-dow{text-align:center;font-size:11.5px;font-weight:700;color:var(--ink-3);padding:4px 0 8px;}
.cal-dow.sun{color:#D64545;}
.cal-day{position:relative;aspect-ratio:1/1;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:13.5px;font-weight:600;color:var(--ink-2);cursor:pointer;border:1px solid transparent;transition:background .12s ease,border-color .12s ease;}
.cal-day:hover{background:var(--bg-soft);}
.cal-day.other{color:var(--ink-4,#b9c0bb);cursor:default;}
.cal-day.other:hover{background:transparent;}
.cal-day.today{border-color:var(--primary);}
.cal-day.sel{background:var(--primary);color:#fff;}
.cal-day .cdot{position:absolute;bottom:6px;width:5px;height:5px;border-radius:50%;background:var(--accent);}
.cal-day.sel .cdot{background:#fff;}
.cal-day.sun{color:#D64545;}
.cal-day.sel.sun{color:#fff;}

/* 업무 카드 */
.ftask-list{display:flex;flex-direction:column;gap:11px;}
.ftask{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;}
.ft-row{display:flex;gap:13px;}
.ftask .fdate{flex:0 0 auto;width:48px;text-align:center;}
.ftask .fdate .d{font-size:19px;font-weight:800;color:var(--primary);line-height:1;font-variant-numeric:tabular-nums;}
.ftask .fdate .m{font-size:11px;color:var(--ink-3);margin-top:3px;}
.ftask .fmain{flex:1;min-width:0;}
.ftask .fschool{font-size:14.5px;font-weight:700;color:var(--ink-1);}
.ftask .fwork{font-size:13px;color:var(--ink-2);margin-top:3px;}
.ftask .ftime{font-size:12.5px;color:var(--ink-3);margin-top:7px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.ftask .ftime svg{color:var(--ink-3);}
.freport{margin-top:13px;padding-top:13px;border-top:1px dashed var(--line);}
.freport .rl{font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:9px;display:flex;align-items:center;gap:7px;}
.freport .rl svg{color:var(--primary);}
.freport-act{display:flex;gap:8px;margin-top:11px;}
.report-btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 13px;border-radius:9px;border:1px solid var(--line);
  background:#fff;color:var(--ink-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;}
.report-btn:hover{border-color:var(--primary);color:var(--primary);}
.report-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.report-btn.primary:hover{background:var(--primary-hover);}
.fdone-tag{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--primary);margin-top:9px;}

/* 작업 사진 보고 (파견인력 업로드 → 프로젝트 공유) */
.report-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:13px;}
.rg-item .rg-cap{margin-top:8px;}
.rg-item .rg-cap b{display:block;font-size:13px;font-weight:700;color:var(--ink-1);}
.rg-item .rg-cap span{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;}
.fstatus{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;align-self:flex-start;}
.fstatus.planned{color:var(--primary);background:var(--primary-tint);}
.fstatus.done{color:var(--ink-3);background:#EEF1EE;border:1px solid var(--line);}
.fempty{text-align:center;color:var(--ink-3);font-size:14px;padding:26px 0;}

/* ═══════════ 전체 배치 캘린더 (담당 매니저) ═══════════ */
.sch-page{background:var(--bg-soft);min-height:100vh;}
.sch-body{max-width:1180px;margin:0 auto;padding:26px 24px 60px;}
.sch-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.sch-head h1{font-size:clamp(22px,2.6vw,28px);font-weight:800;letter-spacing:-0.02em;}
.sch-sum{display:flex;gap:10px;flex-wrap:wrap;}
.sch-sum .s{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:13px;color:var(--ink-3);font-weight:600;}
.sch-sum .s b{color:var(--ink-1);font-size:15px;font-variant-numeric:tabular-nums;margin-right:4px;}
.wk-nav{display:flex;align-items:center;gap:10px;}
.wk-nav .wk-title{font-size:14.5px;font-weight:700;color:var(--ink-1);font-variant-numeric:tabular-nums;white-space:nowrap;}
.wk-nav button{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;transition:all .15s ease;}
.wk-nav button:hover{border-color:var(--primary);color:var(--primary);}

.rcal-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--line-soft);}
.rcal{display:grid;grid-template-columns:130px repeat(7,minmax(124px,1fr));gap:1px;min-width:840px;}
.rc-corner{background:var(--bg-soft);position:sticky;left:0;z-index:2;}
.rc-head{background:var(--bg-soft);text-align:center;padding:10px 6px;}
.rc-head .dow{font-size:11.5px;font-weight:700;color:var(--ink-3);}
.rc-head .dnum{font-size:15px;font-weight:800;color:var(--ink-1);margin-top:2px;font-variant-numeric:tabular-nums;}
.rc-head.sun .dow,.rc-head.sun .dnum{color:#D64545;}
.rc-head.today{background:var(--primary-tint);}
.rc-head.today .dnum{color:var(--primary);}
.rc-name{background:#fff;font-weight:700;font-size:13px;color:var(--ink-1);display:flex;align-items:center;gap:9px;padding:10px;position:sticky;left:0;z-index:1;}
.rc-name .ps{display:block;font-size:11px;color:var(--ink-3);font-weight:500;margin-top:1px;}
.rc-cell{background:#fff;padding:7px;min-height:62px;}
.rc-cell.today{background:color-mix(in srgb,var(--primary-tint) 45%,#fff);}
.rc-chip{font-size:11px;font-weight:700;border-radius:7px;padding:5px 7px;margin-bottom:5px;line-height:1.3;cursor:pointer;border:1px solid transparent;}
.rc-chip:last-child{margin-bottom:0;}
.rc-chip .cw{font-weight:500;opacity:.85;display:block;font-size:10.5px;margin-top:1px;}
@media(max-width:760px){.sch-body{padding:18px 14px 48px;}}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(19,32,30,.46);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;}
.modal{background:#fff;border-radius:16px;width:100%;max-width:580px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 70px rgba(0,0,0,.32);overflow:hidden;}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line);}
.modal-h h3{font-size:18px;font-weight:800;white-space:nowrap;}
.modal-body{padding:22px 24px;overflow:auto;}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--line);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.fg-full{grid-column:1 / -1;}
.fld label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:7px;}
.fld input,.fld select{width:100%;height:44px;border:1px solid var(--line);border-radius:9px;padding:0 12px;font-size:14px;color:var(--ink-1);background:#fff;font-family:inherit;}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}
.btn-admin{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 18px;border-radius:10px;
  background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease;}
.btn-admin:hover{background:var(--primary-hover);}
.btn-admin.ghost{background:#fff;color:var(--ink-2);border:1px solid var(--line);}
.btn-admin.ghost:hover{border-color:var(--primary);color:var(--primary);}

@media(max-width:900px){
  .admin{flex-direction:column;}
  .admin-side{width:100%;flex:none;height:auto;position:static;padding:14px 16px;}
  .as-rolechip{display:none;}
  .as-nav{flex-direction:row;overflow-x:auto;gap:6px;padding-bottom:4px;}
  .as-item .bn{margin-left:8px;}
  .as-foot{display:none;}
  .kpi-row{grid-template-columns:repeat(2,1fr);}
  .ov-2col{grid-template-columns:1fr;}
  .admin-content{padding:20px 16px 48px;}
  .admin-top{padding:0 16px;}
}
@media(max-width:520px){
  .kpi-row{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
}
