/* ===== RESET & BASE ===== */
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif; font-size: 14px; color: #1a1a1a; background: #fff; }

/* ===== PAGE LAYOUT ===== */
#page-wrap { max-width: 1000px; margin: 0 auto; padding: 1.5rem 1rem 3rem; }
h2.page-title { font-size: 1.4rem;  font-weight: 700; margin-bottom: 0.8rem; color: #1a1a1a; }
.lead { font-size: 1rem;  color: #444; line-height: 1.7; margin-bottom: 1.2rem; }

/* ===== ADMIN BAR ===== */
#admin-bar-guest { text-align: right; margin-bottom: 0.8rem; }
#admin-bar-guest a { font-size: 1rem;  color: #888; cursor: pointer; text-decoration: underline; }
#admin-bar-loggedin { display: none; background: #f0f4f8; border: 1px solid #c8d8e8; border-radius: 6px; padding: 8px 14px; margin-bottom: 1rem; align-items: center; gap: 12px; flex-wrap: wrap; }
#admin-bar-loggedin.show { display: flex; }
#admin-bar-loggedin span { font-size: 1rem;  font-weight: 600; color: #185FA5; margin-right: auto; }
#admin-bar-loggedin a { font-size: 1rem;  color: #185FA5; cursor: pointer; text-decoration: underline; }
#admin-bar-loggedin a.btn-add { background: #185FA5; color: #fff; text-decoration: none; padding: 5px 14px; border-radius: 5px; font-size: 1rem;  }
#admin-bar-loggedin a.btn-add:hover { background: #0C447C; }

/* ===== FILTER (admin only) ===== */
#filter-bar { display: none; margin-bottom: 1rem; gap: 8px; flex-wrap: wrap; align-items: center; }
#filter-bar.show { display: flex; }
#filter-bar select,
#filter-bar input { font-size: 1rem;  padding: 5px 9px; border: 1px solid #ccc; border-radius: 5px; background: #fff; color: #1a1a1a; }
#filter-bar input { width: 210px; }

/* ===== TABLE ===== */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 1rem;  }
thead th { text-align: left; padding: 9px 10px; border-bottom: 2px solid #ccc; font-weight: 700; color: #333; white-space: nowrap; background: #f8f8f6; }
tbody tr { border-bottom: 1px solid #e8e8e4; }
tbody tr:hover { background: #fafaf8; }
tbody td { padding: 9px 10px; vertical-align: top; line-height: 1.6; }
td.name-cell a { color: #185FA5; text-decoration: none; }
td.name-cell a:hover { text-decoration: underline; }
td.target-cell { color: #444; font-size: 1rem;  max-width: 280px; }
td.handle-cell { width: 3%; color: #bbb; cursor: grab; text-align: center; font-size: 15px; user-select: none; }
td.handle-cell:hover { color: #888; }
tbody tr.dragging { opacity: 0.4; }
tbody tr.drag-over { outline: 2px solid #185FA5; outline-offset: -2px; }
.edit-btn, .del-btn { font-size: 11px; padding: 3px 9px; border-radius: 4px; cursor: pointer; border: 1px solid; background: #fff; margin-right: 3px; }
.edit-btn { color: #185FA5; border-color: #aac8e8; }
.edit-btn:hover { background: #eef4fb; }
.del-btn { color: #A32D2D; border-color: #e8aaaa; }
.del-btn:hover { background: #fdf0f0; }

/* ===== MODALS ===== */
.modal-bg { display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, 0.45); z-index: 200; align-items: center; justify-content: center; }
.modal-bg.open { display: flex; }
.modal-box { background: #fff; border-radius: 10px; padding: 1.6rem 1.8rem; width: 540px; max-width: 95vw; max-height: 90vh; overflow-y: auto; box-shadow: 0 8px 40px rgba(0, 0, 0, 0.2); }
.modal-box h3 { font-size: 15px; font-weight: 700; margin-bottom: 1.2rem; color: #185FA5; border-bottom: 1px solid #e0e0e0; padding-bottom: 0.7rem; }
.form-row { margin-bottom: 12px; }
.form-row label { display: block; font-size: 1rem;  color: #666; margin-bottom: 4px; font-weight: 600; }
.form-row input,
.form-row textarea,
.form-row select { width: 100%; padding: 7px 10px; border: 1px solid #ccc; border-radius: 6px; font-size: 1rem;  font-family: inherit; color: #1a1a1a; background: #fff; transition: border-color 0.15s; }
.form-row input:focus,
.form-row textarea:focus,
.form-row select:focus { outline: none; border-color: #185FA5; box-shadow: 0 0 0 3px rgba(24, 95, 165, 0.1); }
.form-row textarea { resize: vertical; min-height: 65px; }
.form-error { font-size: 1rem;  color: #A32D2D; margin-top: 5px; display: none; }
.form-error.show { display: block; }
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 1.2rem; padding-top: 1rem; border-top: 1px solid #eee; }
.modal-actions button { padding: 7px 18px; border-radius: 6px; font-size: 1rem;  cursor: pointer; border: 1px solid #ccc; background: #fff; color: #333; font-family: inherit; }
.modal-actions .btn-ok { background: #185FA5; color: #fff; border-color: #185FA5; }
.modal-actions .btn-ok:hover { background: #0C447C; }
.modal-actions button:not(.btn-ok):hover { background: #f0f0ee; }
