:root {
	--navy:#051f3f;
	--navy-2:#08315d;
	--orange:#ff7a00;
	--green:#16a34a;
	--red:#ef4444;
	--line:#d9e2ec;
	--muted:#64748b;
	--bg:#f5f8fb;
	--white:#fff;
	--text:#122033;
	--shadow:0 14px 34px rgba(5,31,63,.11);
	--radius:8px;
}
* { box-sizing:border-box; }
html { min-height:100%; background:var(--bg); color:var(--text); font-family:Arial,'Apple SD Gothic Neo','Noto Sans KR',sans-serif; }
body { margin:0; min-height:100%; letter-spacing:0; }
a { color:inherit; text-decoration:none; }
button,input,select,textarea { font:inherit; letter-spacing:0; }
button { cursor:pointer; }
#pageloading { position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center; background:rgba(5,31,63,.26); }
#pageloading span { padding:12px 18px; border-radius:var(--radius); background:var(--white); color:var(--navy); font-weight:800; box-shadow:var(--shadow); }
.alert-layer { position:fixed; left:50%; bottom:86px; z-index:110; display:none; width:calc(100% - 36px); max-width:420px; transform:translateX(-50%); padding:14px 16px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:var(--shadow); }
.alert-layer.is-active { display:flex; flex-direction:column; gap:4px; }
.alert-layer strong { color:var(--navy); }
.app-shell { width:100%; min-height:100vh; padding-bottom:78px; background:linear-gradient(180deg,#eef4fb 0%,#f8fafc 34%,#fff 100%); }
.mobile-header { position:sticky; top:0; z-index:20; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; border-bottom:1px solid rgba(217,226,236,.9); background:rgba(255,255,255,.94); backdrop-filter:blur(12px); }
.brand { display:flex; align-items:center; gap:9px; min-width:0; color:var(--navy); font-weight:900; }
.brand img { width:38px; height:38px; border-radius:var(--radius); object-fit:cover; background:var(--navy); }
.brand span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.status-pill { display:inline-flex; align-items:center; gap:7px; min-height:32px; padding:0 11px; border:1px solid #cfe7d7; border-radius:999px; background:#effaf2; color:#166534; font-size:13px; font-weight:800; white-space:nowrap; }
.dot { width:8px; height:8px; border-radius:50%; background:var(--green); }
.mobile-main { width:100%; max-width:720px; margin:0 auto; padding:18px 14px 28px; }
.hero-panel { display:flex; align-items:flex-end; justify-content:space-between; gap:14px; min-height:210px; padding:24px 20px; border-radius:var(--radius); background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 62%,#0a4a7a 100%); color:var(--white); box-shadow:var(--shadow); }
.hero-panel p { margin:0 0 12px; color:#c6d8ed; font-weight:800; }
.hero-panel h1 { margin:0; font-size:32px; line-height:1.18; letter-spacing:0; }
.hero-panel span { display:block; margin-top:14px; color:#dce8f5; font-size:14px; }
.status-button { flex:0 0 auto; min-height:42px; padding:0 16px; border:0; border-radius:var(--radius); background:var(--orange); color:var(--white); font-weight:900; }
.summary-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-top:12px; }
.summary-grid div { min-height:78px; padding:13px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:0 8px 18px rgba(5,31,63,.05); }
.summary-grid span { display:block; color:var(--muted); font-size:12px; font-weight:800; }
.summary-grid strong { display:block; margin-top:8px; color:var(--navy); font-size:22px; }
.quick-actions { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:14px 0; }
.primary-button,.line-button,.small-button { display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:0 14px; border-radius:var(--radius); font-weight:900; text-align:center; }
.primary-button { border:0; background:var(--orange); color:var(--white); }
.line-button { border:1px solid var(--navy); background:var(--white); color:var(--navy); }
.small-button { min-height:34px; padding:0 12px; border:1px solid var(--line); background:var(--white); color:var(--navy); font-size:13px; }
.section-block { display:flex; flex-direction:column; gap:10px; margin-top:20px; }
.section-title { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.section-title h2 { margin:0; color:var(--navy); font-size:18px; }
.section-title a { color:var(--orange); font-size:13px; font-weight:900; }
.job-card { padding:16px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:0 8px 20px rgba(5,31,63,.06); }
.job-card-top { display:flex; align-items:center; justify-content:space-between; color:var(--muted); font-size:12px; }
.badge { display:inline-flex; min-height:24px; align-items:center; padding:0 8px; border-radius:999px; background:#fff2e6; color:#c45100; font-weight:900; }
.job-route { display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:8px; margin-top:12px; color:var(--navy); }
.job-route strong { min-width:0; font-size:15px; line-height:1.35; }
.job-route span { color:var(--orange); font-weight:900; }
.job-meta { display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.job-meta span { padding:5px 8px; border-radius:999px; background:#edf3f9; color:#36516f; font-size:12px; font-weight:800; }
.job-card-bottom { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:14px; }
.job-card-bottom b { display:block; color:var(--navy); font-size:18px; }
.job-card-bottom small { display:block; margin-top:4px; color:var(--muted); }
.notice-row { display:grid; gap:4px; padding:14px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); }
.notice-row strong { color:var(--navy); }
.notice-row span { color:#344760; font-size:14px; }
.notice-row small { color:var(--muted); }
.notice-row.large { min-height:92px; }
.page-title { margin:4px 0 16px; }
.page-title h1 { margin:0; color:var(--navy); font-size:26px; }
.page-title p { margin:8px 0 0; color:var(--muted); line-height:1.5; }
.filter-bar,.tab-box,.admin-tabs { display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; }
.filter-bar button,.tab-box button,.admin-tabs button { min-height:36px; padding:0 12px; border:1px solid var(--line); border-radius:999px; background:var(--white); color:var(--navy); font-weight:800; white-space:nowrap; }
.map-placeholder { position:relative; height:180px; overflow:hidden; border:1px solid var(--line); border-radius:var(--radius); background:#d9e7f2; }
.map-placeholder div { position:absolute; inset:18px; background:linear-gradient(90deg,transparent 48%,rgba(255,255,255,.6) 50%,transparent 52%),linear-gradient(0deg,transparent 48%,rgba(255,255,255,.6) 50%,transparent 52%); background-size:52px 52px; }
.map-placeholder span { position:absolute; left:16px; bottom:14px; padding:7px 10px; border-radius:var(--radius); background:var(--white); color:var(--navy); font-weight:900; }
.detail-card,.form-card,.profile-card { margin-top:12px; padding:16px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:0 8px 20px rgba(5,31,63,.05); }
.detail-route { display:grid; grid-template-columns:1fr auto 1fr; gap:8px; color:var(--navy); font-weight:900; }
.info-list { display:grid; gap:10px; margin:16px 0 0; }
.info-list div { display:grid; grid-template-columns:92px 1fr; gap:10px; }
.info-list dt { color:var(--muted); font-weight:800; }
.info-list dd { margin:0; color:var(--text); }
.trust-row { display:flex; flex-wrap:wrap; gap:8px; }
.trust-row span { padding:7px 10px; border-radius:999px; background:#effaf2; color:#166534; font-weight:900; font-size:13px; }
.sticky-actions { position:sticky; bottom:78px; z-index:12; margin-top:14px; }
.sticky-actions .primary-button { width:100%; }
.form-stack { display:grid; gap:12px; }
.form-card h2 { margin:0 0 14px; color:var(--navy); font-size:17px; }
.form-card label,.admin-panel label { display:grid; gap:7px; margin-top:10px; color:#344760; font-weight:800; }
.form-card input,.form-card select,.form-card textarea,.admin-panel input,.admin-panel select,.admin-panel textarea { width:100%; min-height:44px; padding:10px 12px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); color:var(--text); }
.form-card textarea,.admin-panel textarea { resize:vertical; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.policy-note { margin:0; padding:12px; border-left:4px solid var(--orange); border-radius:var(--radius); background:#fff8ef; color:#6b4b25; line-height:1.5; }
.profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.profile-card { margin-top:0; }
.profile-card span { display:block; color:var(--muted); font-weight:800; }
.profile-card strong { display:block; margin-top:8px; color:var(--navy); font-size:20px; }
.profile-card small { display:block; margin-top:6px; color:#48627f; }
.bottom-nav { position:fixed; left:50%; bottom:0; z-index:30; display:grid; grid-template-columns:repeat(5,1fr); width:100%; max-width:720px; transform:translateX(-50%); border-top:1px solid var(--line); background:var(--white); box-shadow:0 -10px 24px rgba(5,31,63,.08); }
.bottom-nav a { display:flex; align-items:center; justify-content:center; min-height:64px; color:#35516e; font-size:12px; font-weight:900; }
.bottom-nav .nav-primary { margin:-14px 4px 10px; min-height:58px; border-radius:var(--radius); background:var(--orange); color:var(--white); box-shadow:0 8px 18px rgba(255,122,0,.28); }
.admin-shell { display:grid; grid-template-columns:220px 1fr; min-height:100vh; background:#f7fafc; }
.admin-sidebar { position:sticky; top:0; height:100vh; padding:18px 14px; background:linear-gradient(180deg,var(--navy) 0%,#021226 100%); color:var(--white); }
.admin-brand { display:flex; align-items:center; gap:10px; margin-bottom:24px; font-weight:900; }
.admin-brand img { width:42px; height:42px; border-radius:var(--radius); object-fit:cover; }
.admin-sidebar nav { display:grid; gap:5px; }
.admin-sidebar nav a { padding:11px 12px; border-radius:var(--radius); color:#d8e5f2; font-weight:800; }
.admin-sidebar nav a:hover { background:rgba(255,255,255,.1); color:var(--white); }
.admin-content { min-width:0; padding:24px; }
.admin-header { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:18px; }
.admin-header p { margin:0 0 6px; color:var(--muted); font-weight:800; }
.admin-header h1 { margin:0; color:var(--navy); font-size:28px; }
.metric-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:14px; }
.metric-card { min-height:110px; padding:18px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:0 8px 20px rgba(5,31,63,.05); }
.metric-card span { color:var(--muted); font-weight:800; }
.metric-card strong { display:block; margin-top:14px; color:var(--navy); font-size:28px; }
.admin-grid { display:grid; grid-template-columns:1.35fr .9fr; gap:14px; margin-bottom:14px; }
.admin-panel { padding:18px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); box-shadow:0 8px 20px rgba(5,31,63,.05); }
.admin-panel.narrow { max-width:680px; }
.panel-title { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; }
.panel-title h2 { margin:0; color:var(--navy); font-size:18px; }
.panel-title a,.panel-title button,.search-line button { min-height:34px; padding:0 12px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); color:var(--navy); font-weight:900; }
.chart-bars { display:flex; align-items:end; gap:12px; height:210px; padding:18px; border-radius:var(--radius); background:linear-gradient(180deg,#f8fbff,#eef5fb); }
.chart-bars span { flex:1; min-width:18px; border-radius:6px 6px 0 0; background:linear-gradient(180deg,#6fb2ff,#0a4a7a); }
.todo-list { display:grid; gap:10px; margin:0; padding:0; list-style:none; }
.todo-list li { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px; border-radius:var(--radius); background:#f4f8fc; }
.todo-list span { color:#344760; font-weight:800; }
.todo-list strong { color:var(--orange); }
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; min-width:620px; }
th,td { padding:13px 12px; border-bottom:1px solid var(--line); text-align:left; white-space:nowrap; }
th { color:var(--muted); font-size:13px; }
td { color:#263b52; }
.table-status { display:inline-flex; min-height:24px; align-items:center; padding:0 8px; border-radius:999px; background:#effaf2; color:#166534; font-size:12px; font-weight:900; }
.search-line { display:grid; grid-template-columns:1fr auto; gap:8px; margin-bottom:12px; }
.search-line input { min-height:38px; padding:8px 10px; border:1px solid var(--line); border-radius:var(--radius); }
@media (max-width:900px) {
	.admin-shell { grid-template-columns:1fr; }
	.admin-sidebar { position:relative; height:auto; }
	.admin-sidebar nav { grid-template-columns:repeat(3,1fr); }
	.admin-content { padding:18px 14px; }
	.metric-grid { grid-template-columns:repeat(2,1fr); }
	.admin-grid { grid-template-columns:1fr; }
}
@media (max-width:520px) {
	.mobile-main { padding-left:12px; padding-right:12px; }
	.hero-panel { min-height:190px; padding:20px 16px; flex-direction:column; align-items:flex-start; }
	.hero-panel h1 { font-size:28px; }
	.summary-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
	.summary-grid div { padding:11px 9px; }
	.summary-grid strong { font-size:19px; }
	.form-grid,.profile-grid { grid-template-columns:1fr; }
	.admin-sidebar nav { grid-template-columns:repeat(2,1fr); }
}

