/* ============================================================
   Fish On 乗合船管理画面 CSS v2
   ============================================================ */

:root {
  --ca-primary:  #0077b6;
  --ca-dark:     #023e6e;
  --ca-teal:     #0096a0;
  --ca-orange:   #f4a020;
  --ca-red:      #e53935;
  --ca-green:    #2e7d32;
  --ca-gray:     #3d5670;
  --ca-light:    #f0f7fc;
  --ca-white:    #ffffff;
  --ca-border:   #c5dff0;
  --ca-text:     #1a2e42;
  --ca-header-h: 52px;
  --ca-radius:   10px;
  --ca-shadow:   0 2px 12px rgba(0,119,182,.1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; font-family: 'Noto Sans JP', sans-serif; font-size: 14px; color: var(--ca-text); background: #e8f2f9; -webkit-tap-highlight-color: transparent; overflow-x: hidden; width: 100%; max-width: 100vw; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, select, textarea { font-family: inherit; font-size: 16px; } /* iOS自動ズーム防止のため16px必須 */

/* ============================================================
   ヘッダー
   ============================================================ */
.ca-header {
  position: sticky; top: 0; z-index: 100;
  height: var(--ca-header-h);
  background: var(--ca-dark);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.ca-header__title { color: #fff; font-size: 16px; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.ca-header__title i { color: var(--ca-orange); }
.ca-header__user { color: rgba(255,255,255,.75); font-size: 13px; }

/* ============================================================
   アラートバナー
   ============================================================ */
.ca-alert-banner {
  background: #fff3cd; border-bottom: 2px solid #f59e0b;
  padding: 10px 16px;
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 700; color: #92400e;
}
.ca-alert-banner i { font-size: 16px; color: #f59e0b; }
.ca-alert-banner span { flex: 1; }
.ca-alert-btn {
  background: #f59e0b; color: #fff; border: none;
  padding: 5px 14px; border-radius: 20px; font-size: 12px; font-weight: 700;
  cursor: pointer;
}

/* ============================================================
   4グリッド
   ============================================================ */
.ca-grid-4 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 12px;
  max-width: 100%;
  overflow: hidden;
}

/* 予約登録（横幅最大・6カラム横詰めコンパクト） */
.ca-grid-register {
  padding: 6px 10px;
  max-width: 100%;
}
.ca-grid-register .ca-panel { width: 100%; }
.ca-grid-register .ca-panel__header { padding: 6px 10px; }
.ca-grid-register .ca-panel__body { padding: 8px 10px; max-height: none; overflow: visible; }
.reg-form-compact {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 5px 8px;
  align-items: end;
}
.reg-form-compact .ca-form-group { margin-bottom: 0; }
.reg-form-compact .ca-form-group label { font-size: 10px; line-height:1.2; margin-bottom:2px; color:#3d5670; font-weight:600; }
.reg-form-compact .ca-form-group input,
.reg-form-compact .ca-form-group select,
.reg-form-compact .ca-form-group textarea { padding: 5px 8px; font-size: 14px; }
.reg-form-compact textarea { min-height: 36px; }
.reg-form-compact .ca-rental-list:empty { display:none; }
.reg-form-compact .ca-input-with-btn input { padding: 5px 8px; }
.reg-form-compact .ca-toggle { padding: 4px 0; }
.reg-form-compact .reg-col-full  { grid-column: 1 / -1; }
/* スマホでも6カラムグリッドを維持し、span指定通りに配置 */
.reg-form-compact .ca-input-with-btn { display:flex; gap:4px; }
.reg-form-compact .ca-input-with-btn input { flex:1; min-width:0; }
.reg-form-compact .ca-input-with-btn .ca-btn { flex-shrink:0; padding:5px 8px; font-size:11px; }
.reg-form-compact .ca-toggle__label { font-size:12px; }

/* メニューグリッド（予約者一覧・割り振り・名簿・休船欠勤・月別詳細・マスタ管理） */
.ca-menu-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  padding: 0 12px 12px;
}
@media (max-width: 900px) {
  .ca-menu-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
  .ca-menu-grid { grid-template-columns: repeat(3, 1fr); gap: 6px; padding: 0 8px 8px; }
}
.ca-menu-card {
  background: var(--ca-primary, #0077b6);
  color: #fff;
  border-radius: 10px;
  padding: 14px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
  transition: opacity .15s;
}
.ca-menu-card:hover, .ca-menu-card:active { opacity: .85; color: #fff; }
.ca-menu-card i { font-size: 20px; color: var(--ca-orange, #f5a623); }

/* ============================================================
   パネル
   ============================================================ */
.ca-panel {
  background: var(--ca-white);
  border-radius: var(--ca-radius);
  box-shadow: var(--ca-shadow);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.ca-panel__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  background: var(--ca-primary);
  cursor: pointer;
}
.ca-panel-link {
  color: #fff;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  height: 100%;
  -webkit-tap-highlight-color: rgba(0,0,0,.1);
  cursor: pointer;
}
.ca-panel-link:hover {
  opacity: .85;
}
.ca-panel__header h2 {
  font-size: 14px; font-weight: 700; color: #fff;
  display: flex; align-items: center; gap: 8px;
}
.ca-panel__header h2 i { font-size: 13px; }
.ca-panel__toggle {
  color: rgba(255,255,255,.8); font-size: 13px;
  transition: transform .25s; background: none; border: none;
}
.ca-panel.collapsed .ca-panel__toggle { transform: rotate(-90deg); }
.ca-panel__body {
  padding: 14px;
  overflow-x: hidden;
  overflow-y: auto;
  max-height: 480px;
  flex: 1;
  word-break: break-all;
  box-sizing: border-box;
}

.ca-panel__body * {
  max-width: 100%;
  box-sizing: border-box;
}

.ca-form-row {
  grid-template-columns: 1fr;
}


/* ============================================================
   フォーム
   ============================================================ */
.ca-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.ca-form-group { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.ca-form-group label { font-size: 12px; font-weight: 600; color: var(--ca-gray); }
.ca-form-group input,
.ca-form-group input,
.ca-form-group select,
.ca-form-group textarea {
  width: 100%; max-width: 100%; padding: 8px 10px;
  border: 1px solid var(--ca-border); border-radius: 6px;
  background: #fff; color: var(--ca-text);
  transition: border-color .15s;
}

input[type="date"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  min-height: 38px;
}

.ca-form-group input:focus,
.ca-form-group select:focus,
.ca-form-group textarea:focus { outline: none; border-color: var(--ca-primary); }
.ca-req { color: var(--ca-red); }
.ca-input-with-btn { display: flex; gap: 6px; }
.ca-input-with-btn input { flex: 1; }

/* トグル */
.ca-toggle { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; }
.ca-toggle input { display: none; }
.ca-toggle__slider {
  width: 40px; height: 22px; background: #ccc; border-radius: 11px;
  position: relative; transition: background .2s; flex-shrink: 0;
}
.ca-toggle__slider::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; background: #fff; border-radius: 50%;
  transition: transform .2s;
}
.ca-toggle input:checked + .ca-toggle__slider { background: var(--ca-primary); }
.ca-toggle input:checked + .ca-toggle__slider::after { transform: translateX(18px); }
.ca-toggle__label { font-size: 13px; }

/* レンタル釣り具 */
.ca-rental-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 6px; }
.ca-rental-row { display: flex; align-items: center; gap: 6px; }
.ca-rental-row select { flex: 1; }
.ca-rental-row input[type="number"] { width: 60px; }
.ca-rental-row .ca-remove-btn { color: var(--ca-red); font-size: 16px; padding: 4px; flex-shrink: 0; }

/* 定員警告 */
.ca-capacity-warning {
  background: #fff3cd; border: 1px solid #f59e0b;
  border-radius: 6px; padding: 8px 12px; margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: #92400e;
}

.ca-form-footer { display: flex; justify-content: flex-end; gap: 8px; margin-top: 10px; }

/* ============================================================
   検索バー
   ============================================================ */
.ca-search-bar {
  display: flex; align-items: center; gap: 8px;
  background: var(--ca-light); border-radius: 20px;
  padding: 7px 12px; border: 1px solid var(--ca-border);
  margin-bottom: 10px;
}
.ca-search-bar i { color: var(--ca-gray); font-size: 13px; }
.ca-search-bar input { flex: 1; border: none; outline: none; background: transparent; font-size: 16px; }

/* ============================================================
   予約者一覧
   ============================================================ */
.ca-bookings-list { display: flex; flex-direction: column; gap: 6px; }
.ca-booking-item {
  background: var(--ca-light); border-radius: 6px; padding: 6px 10px;
  border-left: 3px solid var(--ca-primary);
}
.ca-booking-item__date { font-size: 11px; color: var(--ca-gray); margin-bottom: 1px; }
.ca-booking-item__name { font-weight: 700; font-size: 13px; margin-bottom: 1px; }
.ca-booking-item__meta { font-size: 12px; color: var(--ca-gray); display: flex; flex-wrap: wrap; gap: 6px; }
.ca-booking-item__ship { font-size: 11px; font-weight: 700; padding: 1px 7px; border-radius: 10px; }
.ca-badge--blue  { background: #dbeafe; color: #1e40af; }
.ca-badge--teal  { background: #ccfbf1; color: #115e59; }
.ca-badge--orange{ background: #fed7aa; color: #92400e; }
.ca-badge--gray  { background: #e5e7eb; color: #374151; }
.ca-badge--red   { background: var(--ca-red); color: #fff; }
.ca-badge--green { background: #dcfce7; color: #166534; }
.ca-badge--charter { background: #f59e0b; color: #fff; }

/* ============================================================
   名簿
   ============================================================ */
.ca-roster-list { display: flex; flex-direction: column; gap: 6px; }
.ca-roster-item {
  background: var(--ca-light); border-radius: 6px; padding: 10px 12px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; transition: background .15s;
}
.ca-roster-item:hover { background: #dbeafe; }
.ca-roster-item__name { font-weight: 700; font-size: 14px; }
.ca-roster-item__phone { font-size: 12px; color: var(--ca-gray); }
.ca-roster-item__count { font-size: 11px; color: var(--ca-primary); }

/* ============================================================
   マスタ管理
   ============================================================ */
.ca-master-section { margin-bottom: 16px; }
.ca-master-section:last-child { margin-bottom: 0; }
.ca-master-section__header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px; padding-bottom: 6px;
  border-bottom: 1px solid var(--ca-border);
}
.ca-master-section__header h3 { font-size: 13px; font-weight: 700; color: var(--ca-dark); display: flex; align-items: center; gap: 6px; }
.ca-master-section__header h3 i { color: var(--ca-primary); }
.ca-master-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 10px; background: var(--ca-light); border-radius: 6px;
  margin-bottom: 5px; gap: 8px; font-size: 13px;
}
.ca-master-item__name { font-weight: 600; }
.ca-master-item__meta { color: var(--ca-gray); font-size: 12px; }
.ca-master-item__actions { display: flex; gap: 4px; }

/* ============================================================
   予約一覧
   ============================================================ */
.ca-schedule-section {
  margin: 0 12px 24px;
  background: var(--ca-white);
  border-radius: var(--ca-radius);
  box-shadow: var(--ca-shadow);
  overflow: hidden;
}
.ca-schedule-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; background: var(--ca-dark);
  flex-wrap: wrap; gap: 10px;
}
.ca-schedule-header h2 { font-size: 15px; font-weight: 700; color: #fff; display: flex; align-items: center; gap: 8px; }
.ca-schedule-header h2 i { color: var(--ca-orange); }
.ca-month-nav { display: flex; gap: 6px; flex-wrap: wrap; }
.ca-month-btn {
  padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 700;
  background: rgba(255,255,255,.15); color: #fff; border: 1px solid rgba(255,255,255,.3);
  cursor: pointer; transition: all .15s;
}
.ca-month-btn:hover, .ca-month-btn.active { background: var(--ca-orange); border-color: var(--ca-orange); color: var(--ca-dark); }

.ca-schedule-list { padding: 12px; display: flex; flex-direction: column; gap: 8px; }

.ca-schedule-item { border-radius: 8px; overflow: hidden; border: 1px solid var(--ca-border); }
.ca-schedule-item__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; cursor: pointer;
  border-left: 4px solid var(--ca-primary);
  background: #fff; transition: background .15s;
}
.ca-schedule-item__header:hover { background: var(--ca-light); }
.ca-schedule-item__header.holiday { border-left-color: var(--ca-gray); }
.ca-schedule-item__header.no-accept { border-left-color: var(--ca-red); }
.ca-schedule-item__date { font-size: 15px; font-weight: 700; color: var(--ca-dark); margin-bottom: 4px; }
.ca-schedule-item__badges { display: flex; flex-wrap: wrap; gap: 4px; }
.ca-schedule-badge { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 10px; }
.ca-schedule-item__toggle { color: var(--ca-gray); font-size: 13px; transition: transform .25s; }
.ca-schedule-item.open .ca-schedule-item__toggle { transform: rotate(180deg); }

.ca-schedule-item__body {
  display: none; padding: 12px 14px;
  border-top: 1px solid var(--ca-border); background: var(--ca-light);
}
.ca-schedule-item.open .ca-schedule-item__body { display: block; }
.ca-schedule-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.ca-booking-cards { display: flex; flex-direction: column; gap: 6px; }
.ca-booking-card {
  background: #fff; border-radius: 6px; padding: 10px 12px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; flex-wrap: wrap; border: 1px solid var(--ca-border);
}
.ca-booking-card__name { font-weight: 700; font-size: 14px; }
.ca-booking-card__meta { font-size: 12px; color: var(--ca-gray); }
.ca-unavail-info { font-size: 12px; color: var(--ca-gray); margin-top: 6px; }
.ca-unavail-info li { display: flex; align-items: center; gap: 5px; padding: 2px 0; }

/* ============================================================
   割り振り（モーダル内）
   ============================================================ */
.ca-assign-toolbar { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.ca-assign-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.ca-ship-lane { background: var(--ca-light); border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; }
.ca-ship-lane__header {
  padding: 8px 12px; display: flex; align-items: center; justify-content: space-between;
  font-weight: 700; font-size: 13px; color: #fff;
}
.ca-ship-lane__header small { font-size: 11px; opacity: .8; }
.ca-ship-lane__header--gray  { background: var(--ca-gray); }
.ca-ship-lane__header--blue  { background: var(--ca-primary); }
.ca-ship-lane__header--teal  { background: var(--ca-teal); }
.ca-ship-lane__body { flex: 1; min-height: 120px; padding: 6px; display: flex; flex-direction: column; gap: 5px; }
.ca-ship-lane__body.drag-over { background: #dbeafe; }
.ca-ship-fish { padding: 6px 8px; border-top: 1px solid var(--ca-border); display: flex; align-items: center; gap: 6px; }
.ca-fish-set-btn { font-size: 12px; color: var(--ca-gray); border: 1px dashed var(--ca-border); border-radius: 4px; padding: 3px 8px; transition: all .15s; }
.ca-fish-set-btn:hover { border-color: var(--ca-primary); color: var(--ca-primary); }
.ca-fish-set-name { font-size: 12px; font-weight: 700; color: var(--ca-primary); }

.ca-assign-card {
  background: #fff; border-radius: 5px; padding: 8px 10px;
  cursor: grab; border: 1px solid var(--ca-border); user-select: none;
  font-size: 13px;
}
.ca-assign-card:active { cursor: grabbing; }
.ca-assign-card.dragging { opacity: .4; }
.ca-assign-card.charter-mark { border-left: 3px solid var(--ca-orange); }
.ca-assign-card__name { font-weight: 700; margin-bottom: 2px; }
.ca-assign-card__meta { font-size: 11px; color: var(--ca-gray); }
.ca-capacity-over { background: #fee2e2 !important; }

.ca-btn:disabled,
.ca-btn[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: auto;
  cursor: pointer;
}

/* ============================================================
   ボタン
   ============================================================ */
.ca-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  padding: 8px 14px; border-radius: 6px; font-size: 13px; font-weight: 700;
  border: none; transition: all .18s; white-space: nowrap; cursor: pointer;
}
.ca-btn--primary { background: var(--ca-primary); color: #fff; }
.ca-btn--primary:hover { background: var(--ca-dark); }
.ca-btn--outline { background: transparent; color: var(--ca-primary); border: 1.5px solid var(--ca-primary); }
.ca-btn--outline:hover { background: var(--ca-primary); color: #fff; }
.ca-btn--danger { background: transparent; color: var(--ca-red); border: 1.5px solid var(--ca-red); }
.ca-btn--danger:hover { background: var(--ca-red); color: #fff; }
.ca-btn--sm { padding: 5px 10px; font-size: 12px; }
.ca-btn--icon { padding: 5px 8px; }

/* ============================================================
   モーダル
   ============================================================ */
.ca-modal {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.5); align-items: center; justify-content: center;
  padding: 12px;
}
.ca-modal.is-open { display: flex; }
.ca-modal__inner {
  background: #fff; border-radius: 12px;
  width: 100%; max-width: 560px; max-height: 88vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-sizing: border-box;
}
.ca-modal__inner--sm  { max-width: 420px; }
.ca-modal__inner--wide{ max-width: 720px; }
.ca-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--ca-border);
  flex-shrink: 0;
}
.ca-modal__header h3 { font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.ca-modal__close { color: var(--ca-gray); font-size: 17px; padding: 4px; }
.ca-modal__body { flex: 1; overflow-y: auto; overflow-x: hidden; padding: 14px 18px; display: flex; flex-direction: column; gap: 10px; box-sizing: border-box; }
.ca-modal__footer { padding: 12px 18px; border-top: 1px solid var(--ca-border); display: flex; justify-content: flex-end; gap: 8px; flex-shrink: 0; }

.ca-fish-select-item {
  padding: 10px 14px; background: var(--ca-light); border-radius: 6px;
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 5px; font-size: 13px;
}
.ca-fish-select-item:hover { background: #dbeafe; }

.ca-roster-select-item {
  padding: 10px 12px; background: var(--ca-light); border-radius: 6px;
  cursor: pointer; margin-bottom: 5px; transition: background .15s;
}
.ca-roster-select-item:hover { background: #dbeafe; }
.ca-roster-select-item__name { font-weight: 700; font-size: 14px; }
.ca-roster-select-item__phone { font-size: 12px; color: var(--ca-gray); }

/* ============================================================
   トースト
   ============================================================ */
.ca-toast {
  position: fixed; top: 20px; left: 50%; transform: translateX(-50%) translateY(-120px);
  background: #1a2e42; color: #fff; padding: 10px 22px;
  border-radius: 20px; font-size: 13px; font-weight: 600;
  z-index: 999; transition: transform .28s ease;
  white-space: normal; word-break: break-all;
  max-width: calc(100vw - 32px);
  text-align: center;
  pointer-events: auto;
  cursor: pointer;
}
.ca-toast.show { transform: translateX(-50%) translateY(0); }
.ca-toast.success { background: var(--ca-green); }
.ca-toast.error   { background: var(--ca-red); }
.ca-toast.warning { background: var(--ca-orange); color: var(--ca-dark); }

/* ============================================================
   ローディング・空
   ============================================================ */
.ca-loading { text-align: center; padding: 24px; color: var(--ca-gray); font-size: 13px; }
.ca-empty   { text-align: center; padding: 16px; color: var(--ca-gray); font-size: 13px; }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 480px) {
  .ca-grid-4 { grid-template-columns: 1fr 1fr; gap: 8px; padding: 8px; }
  .ca-panel__body { max-height: 360px; }
  .ca-assign-grid { grid-template-columns: 1fr; }
  .ca-form-row { grid-template-columns: 1fr; }
}
@media (min-width: 1024px) {
  .ca-grid-4 { grid-template-columns: 1fr 1fr; max-width: 1200px; margin: 0 auto; }
  .ca-schedule-section { max-width: 1200px; margin: 0 auto 24px; }
  .ca-panel__body { max-height: 600px; }
}

