/* app.css (정렬/커스텀셀렉트 포함 최종본) */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg-component);
  font-family:"Pretendard Variable",Pretendard,system-ui,sans-serif;
  font-weight:400;
  color:var(--text-main);
}

/* ✅ 모달 오픈 시 바디 스크롤 잠금(신규 추가: 다른 기능 영향 없음) */
body.is-modal-open{overflow:hidden}

/* layout */
.page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:0 16px}
.wrap{width:100%}

/* button */
.btn{
  width:100%;
  padding:12px 16px;
  border-radius:8px;
  border:0;
  cursor:pointer;
  font-size:18px;
  line-height:22px;
  font-weight:700;
}
.btn--primary{background:var(--brand-main);color:var(--text-contrast)}
.btn--outline{background:transparent;color:var(--text-main);border:1px solid var(--border-default)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* checkbox */
.remember{display:inline-flex;align-items:center}
.remember__input{position:absolute;opacity:0}
.remember__label{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.remember__box{
  width:20px;height:20px;border-radius:4px;
  background:var(--bg-component);
  border:2px solid var(--border-default);
  display:inline-flex;align-items:center;justify-content:center;
}
.remember__text{font-size:15px;line-height:18px;font-weight:700;color:var(--text-main)}
.remember__input:checked + .remember__label .remember__box{background:var(--brand-main);border-color:var(--brand-main)}
.remember__input:checked + .remember__label .remember__box::after{
  content:"";width:10px;height:10px;background:var(--text-contrast);
  clip-path:polygon(14% 52%,0 66%,40% 100%,100% 30%,86% 16%,40% 70%);
}

/* login */
.login-header{display:flex;flex-direction:column;align-items:center;padding-top:24px;padding-bottom:40px}
.login-logo{height:40px;width:auto}
.login-subtitle{margin-top:8px;font-size:18px;line-height:22px;font-weight:800;color:var(--brand-main)}
.input-group{padding:4px 0}
.input-box + .input-box{margin-top:4px}
.input-box{display:flex;align-items:center;width:100%;background:var(--bg-component);padding:12px 4px;border-bottom:1px solid var(--border-default)}
.input-box__icon{width:24px;height:24px}
.input-box__field{flex:1;margin-left:12px;border:0;outline:none;background:transparent;font-size:16px}
.input-box__field::placeholder{color:var(--text-sub)}
.login-meta{display:flex;justify-content:space-between;margin:4px 0 20px}
.login-meta__error{font-size:13px;color:var(--contrast-main);visibility:hidden;margin:0}
.login-meta__error.is-visible{visibility:visible}

/* header */
.app-header{
  position:fixed;top:0;width:100%;height:60px;padding:16px;
  display:flex;justify-content:center;align-items:center;
  background:var(--bg-component);
  border-bottom:1px solid var(--border-default);
  z-index:1000;
}
.app-header__logo{height:28px}
.app-header__menu{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border:0;background:transparent;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;border-radius:10px;
}
.app-header__menu:active{opacity:.75}
.hamburger__icon{width:18px;height:12px;position:relative;display:block}
.hamburger__icon span{position:absolute;left:0;right:0;height:2px;background:var(--text-main);border-radius:2px}
.hamburger__icon span:nth-child(1){top:0}
.hamburger__icon span:nth-child(2){top:5px}
.hamburger__icon span:nth-child(3){top:10px}

/* pages common */
.work-page,.history-page,.admin-page{padding-top:60px;min-height:100vh;background:var(--bg-default)}
.sheet + .sheet{margin-top:40px}
.sheet{width:100%;background:var(--bg-component);border-top:1px solid var(--border-default);border-bottom:1px solid var(--border-default)}
.sheet__inner{padding:16px}
.sheet--user{margin-top:40px}

/* user panel */
.user-panel__top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.user-panel__title{margin:0;font-size:18px;font-weight:800;flex:1;min-width:0}
.user-panel__name{color:var(--brand-main)}
.user-panel__desc{margin:8px 0 12px;font-size:13px;color:var(--text-sub);font-weight:700}
.user-meta{padding-left:12px;border-left:2px solid var(--brand-main)}
.user-meta__row{display:flex;gap:4px;font-size:14px;color:var(--text-sub);font-weight:700}
.user-meta__row + .user-meta__row{margin-top:8px}

/* badges */
.status-badge{
  border:1px solid var(--border-default);
  background:var(--bg-component);
  color:var(--text-sub);
  border-radius:999px;
  padding:8px 12px;
  font-size:13px;line-height:15px;font-weight:800;
  cursor:default;white-space:nowrap;
}
.status-badge--none{background:var(--border-default);color:var(--text-sub)}
.status-badge--work{background:var(--brand-sub);color:var(--brand-main);border-color:var(--brand-sub)}
.status-badge--error{background:var(--contrast-bg);color:var(--contrast-main);border-color:var(--contrast-bg);cursor:pointer}
.is-hidden{display:none !important}

/* segmented */
.seg-wrap{border-bottom:1px solid var(--border-default)}
.seg-inner{position:relative;display:grid;grid-template-columns:1fr 1fr;height:56px;padding:0 16px}
.seg__btn{border:0;background:none;font-size:18px;font-weight:800;color:var(--text-disabled);cursor:pointer}
.seg__btn.is-active{color:var(--text-main)}
.seg__underline{
  position:absolute;left:16px;bottom:0;width:calc((100% - 32px)/2);
  height:2px;background:var(--brand-main);transition:transform .15s ease;
}

/* office/remote */
.office-desc,.remote-desc{margin:0 0 12px;font-size:14px;font-weight:800;color:var(--text-sub)}
.code-box{display:flex;align-items:center;background:var(--brand-bg);border-radius:8px;padding:16px 12px}
.code-input{flex:1;border:0;outline:none;background:transparent;font-size:16px}
.code-input::placeholder{color:var(--text-sub)}
.code-hint{margin-left:12px;font-size:13px;font-weight:800;color:var(--contrast-main);visibility:hidden}
.code-hint.is-visible{visibility:visible}
.office-btn,.remote-btn{margin-top:8px}
.remote-consent{margin:6px 0 8px}

/* modal */
.modal{position:fixed;inset:0;z-index:2000;display:none}
.modal.is-open{display:block}
.modal__dim{position:absolute;inset:0;background:var(--overlay-dim)}
.modal__panel{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:calc(100vw - 32px);max-width:420px;
  background:var(--bg-component);border:1px solid var(--border-default);
  border-radius:12px;padding:16px;
}

/* ✅ 수정: 모달 패널 높이 고정 + 내부 스크롤 */
.modal__panel--report{
  padding:16px;
  max-height:calc(100vh - 32px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.modal__msg{margin:0 0 16px;text-align:center}
.modal__headline{margin:0;font-size:16px;line-height:18px;font-weight:800;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.modal__sub{margin:6px 0 0;font-size:12px;line-height:14px;font-weight:700;color:var(--text-sub)}
.modal__actions{display:flex;gap:8px}
.modal__actions .btn{font-size:15px;line-height:18px;font-weight:800}

/* ✅ 처리중 모달(신규) */
.modal__panel--progress{
  max-width:360px;
  padding:18px 16px;
}
.modal__msg--progress{
  margin:0;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.spinner{
  width:28px;height:28px;border-radius:999px;
  border:3px solid var(--border-default);
  border-top-color:var(--brand-main);
  animation:spin .85s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ✅ 카메라 모달(신규) */
.modal__panel--camera{
  max-width:520px;
  max-height:calc(100vh - 32px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.camera-modal__body{
  flex:1;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.camera-box{
  width:100%;
  flex:1;
  min-height:280px;
  border-radius:14px;
  border:1px solid var(--border-default);
  background:#000;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.camera-box video{
  width:100%;
  height:100%;
  object-fit:cover;
}
.camera-hint{
  font-size:12px;
  line-height:14px;
  font-weight:900;
  color:var(--text-sub);
  text-align:center;
}

/* drawer */
.drawer-backdrop{position:fixed;inset:0;background:var(--overlay-dim);opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:999}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;left:0;width:280px;max-width:78vw;height:100vh;
  background:var(--bg-component);
  transform:translateX(-100%);transition:transform .18s ease;
  z-index:1000;box-shadow:var(--shadow-drawer);padding:16px;
}
.drawer.is-open{transform:translateX(0)}
.drawer__close{position:absolute;top:10px;right:10px;width:40px;height:40px;border:0;background:transparent;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.drawer__close:active{opacity:.75}
.drawer__close-icon{width:18px;height:18px;position:relative;display:block}
.drawer__close-icon::before,.drawer__close-icon::after{
  content:"";position:absolute;left:50%;top:50%;
  width:18px;height:2px;background:var(--text-main);transform-origin:center;
}
.drawer__close-icon::before{transform:translate(-50%,-50%) rotate(45deg)}
.drawer__close-icon::after{transform:translate(-50%,-50%) rotate(-45deg)}
.drawer__title{font-size:20px;font-weight:900;margin:8px 0 14px;padding-right:48px;letter-spacing:-.2px}
.drawer__nav{display:flex;flex-direction:column;gap:10px}
.drawer__link{
  display:block;padding:14px 14px;border-radius:14px;text-decoration:none;
  color:var(--text-main);background:var(--bg-soft);
  font-size:15px;font-weight:900;line-height:1.2;
}
.drawer__link:active{opacity:.85}
.drawer__link.is-active{background:var(--brand-main);color:var(--text-contrast)}
body.is-drawer-open{overflow:hidden}

/* sections */
.report-section{margin-top:16px;padding:0 0 16px}
.section-title{padding:12px 16px 10px;font-size:15px;font-weight:900;color:var(--text-main)}
.section-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 16px 10px
}
.section-title-row .section-title{padding:0}

/* dashboard */
.dash-grid{padding:0 16px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dash-card{background:var(--bg-component);border:1px solid var(--border-default);border-radius:14px;padding:14px}
.dash-card__label{font-size:12px;font-weight:800;color:var(--text-sub)}
.dash-card__value{margin-top:10px;font-size:24px;font-weight:900;color:var(--text-main);letter-spacing:-.2px;display:flex;align-items:baseline;gap:6px}
.dash-card__unit{font-size:14px;font-weight:800;color:var(--text-sub)}
.pay-tile{
  margin:12px 16px 0;width:calc(100% - 32px);
  border:1px solid var(--border-default);background:var(--bg-component);
  border-radius:14px;padding:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer
}
.pay-tile:active{opacity:.85}
.pay-tile__title{font-size:15px;font-weight:900;color:var(--text-main)}
.pay-tile__sub{margin-top:6px;font-size:12px;font-weight:800;color:var(--text-sub)}
.pay-tile__money{font-size:16px;font-weight:900;color:var(--brand-main);letter-spacing:-.2px}

/* week */
.week-calendar{padding:0 16px;display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.week-day{background:var(--bg-component);border:1px solid var(--border-default);border-radius:12px;padding:10px 0;text-align:center}
.week-day__w{font-size:11px;font-weight:900;color:var(--text-sub)}
.week-day__d{margin-top:6px;font-size:14px;font-weight:900;color:var(--text-main)}
.week-day.is-on{border-color:var(--brand-main);background:var(--brand-bg)}
.week-day.is-on .week-day__d{color:var(--brand-main)}
.week-day.is-off{opacity:.85}
.week-day.is-today{box-shadow:0 0 0 2px var(--brand-main) inset}
.week-legend{padding:10px 16px 0;display:flex;align-items:center;gap:8px}
.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}
.legend-dot--on{background:var(--brand-main)}
.legend-dot--off{background:var(--border-default)}
.legend-text{font-size:11px;font-weight:900;color:var(--text-sub);margin-right:10px}

/* month select & summary */
.month-select{min-width:160px;display:flex;align-items:center}
.month-summary{
  margin:0 16px;background:var(--bg-component);border:1px solid var(--border-default);
  border-radius:14px;padding:14px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px
}
.month-summary__label{font-size:11px;font-weight:900;color:var(--text-sub)}
.month-summary__value{margin-top:8px;font-size:13px;font-weight:900;color:var(--text-main)}

/* filters */
.filters{margin:12px 16px 0;display:flex;align-items:center;gap:8px}
.chip{
  height:36px;padding:0 12px;border-radius:999px;
  border:1px solid var(--border-default);background:var(--bg-component);
  color:var(--text-main);font-size:12px;font-weight:900;cursor:pointer
}
.chip:active{opacity:.85}
.chip.is-active{border-color:var(--brand-main);background:var(--brand-main);color:var(--text-contrast)}
.filters__right{margin-left:auto;display:inline-flex;align-items:center}
.filters__meta{font-size:11px;font-weight:900;color:var(--text-sub)}

/* list + pagination */
.day-list{margin:12px 16px 0;display:flex;flex-direction:column;gap:10px}
.day-row{
  width:100%;border:1px solid var(--border-default);background:var(--bg-component);
  border-radius:14px;padding:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer
}
.day-row:active{opacity:.85}
.day-row__date{font-size:13px;font-weight:900;color:var(--text-main)}
.day-row__time{font-size:13px;font-weight:900;color:var(--brand-main)}
.day-list__hint{padding:10px 16px 0;font-size:11px;font-weight:800;color:var(--text-sub)}
.empty{border:1px dashed var(--border-default);background:transparent;border-radius:14px;padding:18px;text-align:center;font-size:12px;font-weight:900;color:var(--text-sub)}
.pagination{margin:12px 16px 0;display:flex;justify-content:center}
.page-bar{display:inline-flex;gap:6px;padding:8px;border-radius:14px;border:1px solid var(--border-default);background:var(--bg-component)}
.page-btn{
  width:34px;height:34px;border-radius:10px;border:1px solid var(--border-default);
  background:var(--bg-soft);color:var(--text-main);font-size:12px;font-weight:900;cursor:pointer
}
.page-btn:active{opacity:.85}
.page-btn.is-active{border-color:var(--brand-main);background:var(--brand-main);color:var(--text-contrast)}

/* report modals */
.report-modal__top{position:relative;padding-right:44px;margin-bottom:12px}
.report-modal__title{font-size:16px;font-weight:900;color:var(--text-main);text-align:left}
.report-modal__x{position:absolute;top:-6px;right:-6px;width:40px;height:40px;border:0;background:transparent;cursor:pointer;border-radius:10px}
.report-modal__x:active{opacity:.75}
.report-modal__x::before,.report-modal__x::after{
  content:"";position:absolute;left:50%;top:50%;
  width:18px;height:2px;background:var(--text-main);transform-origin:center
}
.report-modal__x::before{transform:translate(-50%,-50%) rotate(45deg)}
.report-modal__x::after{transform:translate(-50%,-50%) rotate(-45deg)}

/* ✅ 수정: 모달 내부 콘텐츠만 스크롤 */
.report-modal__body{
  padding:4px 0 10px;
  flex:1;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}

.calc-box{border:1px solid var(--border-default);background:var(--bg-component);border-radius:14px;padding:12px}
.calc-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 6px;border-bottom:1px solid var(--border-default)}
.calc-row:last-child{border-bottom:0}
.calc-row--sub .calc-label,.calc-row--sub .calc-value{color:var(--text-sub);font-weight:900}
.calc-row--total{background:var(--brand-bg);border-radius:12px;border-bottom:0;margin-top:8px}
.calc-label{font-size:12px;font-weight:900;color:var(--text-main)}
.calc-value{font-size:12px;font-weight:900;color:var(--text-main)}
.calc-strong{font-weight:900;color:var(--brand-main)}

/* day detail */
.session-list{display:flex;flex-direction:column;gap:10px}
.session-card{border:1px solid var(--border-default);background:var(--bg-component);border-radius:14px;padding:12px}
.session-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.session-card__title{font-size:13px;font-weight:900;color:var(--text-main)}
.session-card__title.is-hidden{display:none}
.session-card__badges{display:inline-flex;align-items:center;gap:6px}
.session-badge{
  display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;
  font-size:11px;font-weight:900;border:1px solid var(--border-default);background:var(--bg-soft);color:var(--text-main)
}
.session-badge--office{background:var(--brand-bg);border-color:var(--brand-sub);color:var(--brand-main)}
.session-badge--remote{background:var(--bg-soft);border-color:var(--border-default);color:var(--text-main)}
.session-badge--next{background:var(--bg-danger-soft);border-color:var(--contrast-bg);color:var(--contrast-main)}
.session-rows{display:grid;grid-template-columns:1fr;gap:8px}
.session-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 10px;border-radius:12px;border:1px solid var(--border-default);background:var(--bg-component)
}
.session-row__label{font-size:11px;font-weight:900;color:var(--text-sub)}
.session-row__value{font-size:12px;font-weight:900;color:var(--text-main)}
.session-row--total{background:var(--brand-bg);border-color:var(--brand-sub)}
.session-row--total .session-row__value{color:var(--brand-main)}
.day-total{margin-top:12px;padding:14px;border-radius:14px;border:1px solid var(--border-default);background:var(--bg-component);display:flex;align-items:center;justify-content:space-between;gap:10px}
.day-total[aria-hidden="true"]{display:none}
.day-total__label{font-size:12px;font-weight:900;color:var(--text-sub)}
.day-total__value{font-size:13px;font-weight:900;color:var(--brand-main)}

/* admin */
.admin-controls{
  padding:0 16px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  align-items:stretch;
}

/* ✅ 정렬 핵심: label + select를 동일한 규칙으로 쌓기 */
.control{
  border:1px solid var(--border-default);
  background:var(--bg-component);
  border-radius:14px;
  padding:12px;

  display:flex;
  flex-direction:column;
  gap:8px; /* 기존 margin-top 대신 gap으로 통일 */
}
.control__label{font-size:11px;font-weight:900;color:var(--text-sub);margin:0}

/* 기존 select 스타일(백업용). 커스텀셀렉트 적용 시 select는 숨김이라 영향 최소화 */
.control__field{
  margin-top:0;
  width:100%;
  height:40px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid var(--border-default);
  background:var(--bg-component);
  color:var(--text-main);
  font-size:13px;
  font-weight:900;
  outline:none
}

.admin-actions{padding:10px 16px 0}
.admin-alerts{
  margin:12px 16px 0;padding:12px;border-radius:14px;
  border:1px solid var(--contrast-bg);background:var(--bg-danger-soft);
  color:var(--contrast-main);font-size:12px;font-weight:900
}
.admin-alerts[aria-hidden="true"]{display:none}

/* =========================
   UnderPhase Custom Select
   (정렬/드롭다운 포함)
   ========================= */
.u-select{position:relative;width:100%}

/* select는 값 저장용으로 숨김 */
.u-select__native{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
}

/* 트리거(선택 영역) */
.u-select__trigger{
  width:100%;
  height:40px;              /* ✅ month/employee 동일 높이 */
  padding:0 44px 0 12px;
  border-radius:12px;
  border:1px solid var(--border-default);
  background:var(--bg-component);
  color:var(--text-main);

  display:flex;
  align-items:center;       /* ✅ 세로 중앙 정렬 */
  justify-content:space-between;
  gap:10px;

  font-family:inherit;
  font-size:13px;
  font-weight:900;
  line-height:1;            /* ✅ 텍스트 기준선 흔들림 방지 */
  cursor:pointer;
}
.u-select__trigger:active{opacity:.9}
.u-select.is-open .u-select__trigger{border-color:var(--brand-main)}
.u-select__label{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* chevron */
.u-select__chev{
  width:10px;height:10px;
  flex:0 0 auto;
  border-right:2px solid var(--text-main);
  border-bottom:2px solid var(--text-main);
  transform:rotate(45deg);
  transition:transform .15s ease;
  opacity:.9;
}
.u-select.is-open .u-select__chev{transform:rotate(-135deg)}

/* options */
.u-select__list{
  position:absolute;
  top:calc(100% + 6px);
  left:0;right:0;

  background:var(--bg-component);
  border:1px solid var(--border-default);
  border-radius:14px;
  box-shadow:var(--shadow-drawer);
  z-index:3000;

  max-height:280px;
  overflow:auto;

  display:none;
}
.u-select.is-open .u-select__list{display:block}

.u-select__option{
  width:100%;
  border:0;
  background:transparent;
  text-align:left;

  padding:12px 12px;
  font-family:inherit;
  font-size:13px;
  font-weight:900;
  color:var(--text-main);
  cursor:pointer;
}
.u-select__option:hover{background:var(--bg-soft);color:var(--brand-main)}
.u-select__option.is-selected{background:var(--brand-bg);color:var(--brand-main)}
.u-select__option + .u-select__option{border-top:1px solid var(--border-default)}

/* history 상단 '월 선택' 우측 정렬 안정화 */
.month-select{min-width:160px}
.month-select > .u-select{width:100%}

.control__field{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;

  padding-right:44px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--text-main) 50%),
    linear-gradient(135deg, var(--text-main) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%;
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}

/* ✅ 화살표를 '진짜 오른쪽'에 고정 */
.u-select__trigger{
  position: relative;
  justify-content: flex-start; /* space-between 쓰면 padding 안쪽에서 멈춤 */
}

/* 기존 flex 흐름에서 빼서 오른쪽으로 고정 */
.u-select__chev{
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

/* 열렸을 때 회전 */
.u-select.is-open .u-select__chev{
  transform: translateY(-50%) rotate(-135deg);
}

/* 라벨이 화살표랑 겹치지 않게 오른쪽 여유 */
.u-select__label{
  padding-right: 32px;
}
