/* 예약의 민족 — 관리자 화면 공용 스타일 (대시보드/홈과 동일한 "고요한 럭셔리" 톤) */
:root{
  --bg:#fbfbfc; --surface:#ffffff; --ink:#16181d; --ink-soft:#3b3f47;
  --muted:#8a9099; --faint:#b9bec6; --line:#ececf0; --line-2:#f3f3f6; --field:#f6f6f8;
  --accent:#3a5bd9; --accent-soft:#eef1fc;
  --korean:#3a5bd9; --chinese:#c08a2d; --haejang:#2f9e6b;
  --ok:#2f9e6b; --warn:#b9821f; --warn-soft:#fbf3e2; --warn-line:#ecd9ad; --danger:#c4453f;
  --r-lg:20px; --r-md:14px; --r-sm:10px;
  --shadow:0 1px 2px rgba(20,24,29,.04), 0 8px 28px -16px rgba(20,24,29,.18);
  --ease:cubic-bezier(.22,.61,.36,1);
  /* 기존 인라인 코드 호환용 별칭 */
  --border:var(--line); --border-strong:#dcdee4; --surface-2:var(--field);
  --text-2:var(--ink-soft); --succ:var(--ok);
  --font-mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
@media (prefers-color-scheme:dark){
  :root{
    --bg:#0c0d10; --surface:#15171c; --ink:#f4f5f7; --ink-soft:#d3d6dc;
    --muted:#878d97; --faint:#5a606b; --line:#23262d; --line-2:#1c1f25; --field:#1b1d23;
    --accent:#7e96ff; --accent-soft:#1b2340; --korean:#7e96ff; --chinese:#e0b15c; --haejang:#5dc795;
    --ok:#5dc795; --warn:#e0b15c; --warn-soft:#2a2415; --warn-line:#4a3f1d; --danger:#ef6f6a;
    --shadow:0 1px 2px rgba(0,0,0,.4), 0 14px 40px -22px rgba(0,0,0,.8);
    --border-strong:#33373f;
  }
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,system-ui,'Segoe UI',Roboto,'Apple SD Gothic Neo',sans-serif;
  background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  letter-spacing:-.011em;line-height:1.45;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom)}
.num{font-variant-numeric:tabular-nums;letter-spacing:-.02em}

.wrap,.wrap-wide{max-width:760px;margin:0 auto;padding:20px 24px 60px}
.wrap-wide{max-width:880px}
@media (max-width:560px){.wrap,.wrap-wide{padding:16px 16px 48px}}

/* 상단바 */
.topbar{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid var(--line)}
.topbar-in{max-width:880px;margin:0 auto;padding:13px 24px;display:flex;align-items:center;gap:13px}
@media (max-width:560px){.topbar-in{padding:11px 16px}}
.brand{display:flex;align-items:center;gap:11px;min-width:0;text-decoration:none;color:inherit}
.mark{width:30px;height:30px;border-radius:9px;flex:0 0 auto;
  background:linear-gradient(150deg,var(--accent),color-mix(in srgb,var(--accent) 55%,#111));
  display:grid;place-items:center;color:#fff;font-size:15px;
  box-shadow:0 2px 8px -2px color-mix(in srgb,var(--accent) 60%,transparent)}
.brand-txt{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.brand-txt b{font-size:14.5px;font-weight:650;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-txt span{font-size:11.5px;color:var(--muted);font-weight:450;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-link{margin-left:auto;flex:0 0 auto;display:inline-flex;align-items:center;gap:5px;height:36px;padding:0 13px;
  border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink-soft);
  font-size:12.5px;font-weight:600;text-decoration:none;letter-spacing:-.01em;transition:border-color .15s var(--ease),color .15s var(--ease)}
.top-link:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--line));color:var(--accent)}

/* 페이지 머리글 */
.head{padding:24px 0 6px}
.head h1{font-size:clamp(22px,4vw,29px);font-weight:740;letter-spacing:-.035em;line-height:1.1}
.head p{margin-top:6px;font-size:13.5px;color:var(--muted);font-weight:450}

/* 히어로(사진 페이지) */
.hero{padding:30px 0 14px;text-align:center}
.hero-brand{display:inline-block;font-size:12px;font-weight:650;color:var(--accent);letter-spacing:.02em;
  background:var(--accent-soft);padding:5px 12px;border-radius:999px}
.hero-title{margin-top:14px;font-size:clamp(24px,5.4vw,32px);font-weight:760;letter-spacing:-.035em;line-height:1.12}
.hero-sub{margin-top:8px;font-size:14px;color:var(--muted);font-weight:450}

/* 카드 */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);
  padding:20px 22px;margin-top:16px}
@media (max-width:560px){.card{padding:17px 18px}}
.card h3{font-size:15.5px;font-weight:650;letter-spacing:-.02em;margin-bottom:14px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.muted{color:var(--muted)}
.mini{font-size:12.5px;color:var(--muted);font-weight:450}

/* 행/입력 */
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>div{flex:1;min-width:0}
.label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:-.01em}
input[type=text],input[type=date],input[type=number],input[type=password],select,textarea{
  width:100%;height:46px;padding:0 14px;font:inherit;font-size:15px;color:var(--ink);color-scheme:light dark;
  background:var(--field);border:1px solid var(--line);border-radius:var(--r-md);
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease);-webkit-appearance:none;appearance:none}
textarea{height:auto;padding:12px 14px;line-height:1.5;resize:vertical}
select{cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 19px,calc(100% - 13px) 19px;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px}
input[type=file]{height:auto;padding:11px 14px;font-size:13.5px;color:var(--ink-soft);cursor:pointer}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent)}
input::placeholder,textarea::placeholder{color:var(--faint)}

/* 세그먼트 토글 */
.seg{display:inline-flex;background:var(--field);border:1px solid var(--line);border-radius:var(--r-md);padding:3px;gap:3px}
.seg button{border:0;background:transparent;color:var(--muted);font:inherit;font-size:14px;font-weight:600;
  padding:11px 18px;border-radius:10px;cursor:pointer;transition:all .15s var(--ease)}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px rgba(20,24,29,.1)}

/* 메뉴 칩 */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;min-height:42px;padding:9px 15px;font-size:14px;font-weight:550;cursor:pointer;
  background:var(--field);color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;
  transition:all .14s var(--ease);user-select:none}
.chip:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--line))}
.chip.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}

/* 키보드 포커스 가시성 (마우스 클릭 시엔 보이지 않음) */
.btn:focus-visible,.seg button:focus-visible,.chip:focus-visible,.top-link:focus-visible,.brand:focus-visible{
  outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}

/* 버튼 */
.btn{display:flex;align-items:center;justify-content:center;width:100%;height:48px;padding:0 18px;
  font:inherit;font-size:15px;font-weight:650;letter-spacing:-.01em;cursor:pointer;
  background:var(--field);color:var(--ink);border:1px solid var(--line);border-radius:var(--r-md);
  transition:transform .12s var(--ease),border-color .15s var(--ease),filter .15s var(--ease)}
.btn:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}
.btn:active{transform:scale(.99)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{border-color:var(--accent);filter:brightness(1.06)}
.btn-ok{background:var(--ok);border-color:var(--ok);color:#fff}
.btn-ok:hover{border-color:var(--ok);filter:brightness(1.05)}

/* 안내 배너 */
.banner{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);
  font-size:13.5px;line-height:1.55;margin-top:16px}
.banner.accent{background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);color:var(--ink-soft)}
.banner b{color:var(--ink);font-weight:650}

/* 사진 미리보기 */
.photo-preview{border-radius:var(--r-md);overflow:hidden;background:var(--field);border:1px solid var(--line)}
.photo-preview img{display:block;width:100%;height:auto}
.photo-preview.empty{display:grid;place-items:center;text-align:center;min-height:160px;padding:24px;
  color:var(--muted);font-size:13.5px;border-style:dashed}

/* 표 */
table{width:100%;border-collapse:collapse;font-size:13px}
table th{font-weight:600;color:var(--ink-soft)}
table tbody tr{border-top:1px solid var(--line)}

/* 토스트 */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(12px);z-index:60;
  background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:999px;font-size:13.5px;font-weight:600;
  box-shadow:0 12px 32px -12px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:all .25s var(--ease);max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
