:root{
  --bg:#060b12;
  --bg2:#0b1120;
  --panel:#101722;
  --panel2:#131c28;
  --panel3:#0d141e;
  --text:#f5f7fb;
  --muted:#a7b3c7;
  --line:rgba(255,255,255,.10);
  --primary:#2f6df6;
  --primary2:#1f4db7;
  --danger:#7d1f2a;
  --danger-line:#b33b49;
  --chip:#182232;
  --shadow:0 12px 40px rgba(0,0,0,.30);
  --radius-xl:22px;
  --radius-lg:18px;
  --radius-md:14px;
  --radius-sm:10px;
  --done-bg:rgba(47,191,122,.14);
  --done-line:rgba(47,191,122,.45);
  --cancel-bg:rgba(224,82,82,.14);
  --cancel-line:rgba(224,82,82,.45);
  --pending-bg:rgba(255,255,255,.04);
  --assigned-bg:rgba(47,109,246,.14);
  --assigned-line:rgba(47,109,246,.40);
}

*{
  box-sizing:border-box;
}

html,
body{
  margin:0;
  padding:0;
  min-height:100%;
}

body{
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  background:
    radial-gradient(900px 600px at 100% 0%, rgba(65,31,122,.35), transparent 45%),
    linear-gradient(180deg, #04080f 0%, #06101a 100%);
}

button,
input,
select,
textarea{
  font:inherit;
}

.hidden{
  display:none !important;
}

/* shell */
.app-shell{
  width:min(100% - 32px, 1360px);
  margin:0 auto;
  padding:18px 0 28px;
}

.app-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:20px;
  margin-bottom:18px;
}

.brand-wrap{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.app-title{
  margin:0;
  font-size:22px;
  font-weight:800;
  letter-spacing:.01em;
}

.app-subtitle{
  margin:0;
  color:#c8d3e5;
  font-size:15px;
}

.header-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

/* tabs */
.main-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.main-tab{
  appearance:none;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:#fff;
  border-radius:999px;
  padding:10px 16px;
  min-height:42px;
  cursor:pointer;
  transition:.18s ease;
}

.main-tab:hover{
  border-color:rgba(255,255,255,.18);
  transform:translateY(-1px);
}

.main-tab.active{
  background:rgba(47,109,246,.20);
  border-color:rgba(47,109,246,.75);
  box-shadow:inset 0 0 0 1px rgba(47,109,246,.30);
}

/* panels */
.page-panel{
  display:none;
}

.page-panel.active{
  display:block;
}

.panel-grid{
  display:grid;
  gap:18px;
}

.panel-grid.two-col{
  grid-template-columns:1fr 1fr;
}

.panel-card{
  background:
    linear-gradient(90deg, rgba(255,255,255,.03), rgba(255,255,255,.00) 35%, rgba(255,255,255,.03) 100%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  padding:18px 18px 16px;
}

.panel-card h2{
  margin:0 0 18px;
  font-size:19px;
  font-weight:800;
}

.panel-card h3{
  margin:0 0 14px;
  font-size:16px;
  font-weight:800;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

/* home */
.status-chips,
.home-monthly-list,
.quick-actions,
.panel-actions,
.action-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:#d8e2f2;
  font-size:13px;
}

.memo-list{
  margin:0;
  padding-left:18px;
  color:#d8e2f2;
  line-height:1.8;
}

.soft-text{
  margin:0;
  color:#d8e2f2;
  line-height:1.8;
}

.home-monthly-list{
  flex-direction:column;
}

.home-monthly-item{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

/* buttons */
.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:#fff;
  border-radius:16px;
  padding:10px 16px;
  min-height:42px;
  cursor:pointer;
  transition:.18s ease;
  box-shadow:none;
}

.btn:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.18);
}

.btn.primary{
  background:linear-gradient(180deg, #3d7cff, #2e69eb);
  border-color:rgba(83,135,255,.85);
}

.btn.ghost{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.10);
}

.btn.danger{
  background:rgba(125,31,42,.18);
  border-color:var(--danger-line);
  color:#fff;
}

/* fields */
.form-grid{
  display:grid;
  gap:12px 14px;
  margin-bottom:14px;
}

.form-grid.two-col{
  grid-template-columns:1fr 1fr;
}

.form-grid.three-col{
  grid-template-columns:1fr 1fr 1fr;
}

.form-grid.five-col{
  grid-template-columns:repeat(5, 1fr);
}

.field{
  display:flex;
  flex-direction:column;
  gap:7px;
}

.field.full{
  grid-column:1 / -1;
}

.field.compact{
  min-width:160px;
}

.field label{
  color:#e9eef8;
  font-size:13px;
  font-weight:700;
}

input,
select,
textarea{
  width:100%;
  color:#fff;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  padding:12px 14px;
  outline:none;
  transition:.18s ease;
}

input::placeholder,
textarea::placeholder{
  color:#8594aa;
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(47,109,246,.75);
  box-shadow:0 0 0 3px rgba(47,109,246,.15);
}

textarea{
  min-height:92px;
  resize:vertical;
}

/* table */
.table-wrap{
  width:100%;
  overflow:auto;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.02);
  margin-top:14px;
}

.data-table{
  width:100%;
  min-width:980px;
  border-collapse:collapse;
}

.data-table thead th{
  text-align:left;
  font-size:13px;
  font-weight:800;
  color:#f4f8ff;
  padding:14px 12px;
  border-bottom:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
}

.data-table tbody td{
  padding:14px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  vertical-align:top;
  color:#f1f5fb;
  font-size:14px;
  line-height:1.5;
}

.data-table tbody tr:last-child td{
  border-bottom:none;
}

.data-table .actions-cell{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

/* misc */
.divider{
  border-top:1px solid rgba(255,255,255,.10);
  margin:18px 0 14px;
}

/* daily */
.daily-header-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:16px;
}

.daily-top-actions{
  display:flex;
  align-items:flex-end;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.daily-vehicles-block{
  margin-top:6px;
}

.vehicle-checklist{
  display:grid;
  gap:10px;
  margin-top:8px;
}

.vehicle-check-item{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:14px;
  padding:10px 0;
}

.vehicle-check-label{
  color:#e8eef9;
  line-height:1.6;
  font-size:14px;
}

.vehicle-check-input{
  width:18px;
  height:18px;
  accent-color:#ff3b2f;
}

.result-head-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.dispatch-result-cards{
  display:grid;
  gap:14px;
}

.vehicle-result-card{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.03), rgba(255,255,255,.00) 35%, rgba(255,255,255,.03) 100%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  padding:12px 12px 8px;
}

.vehicle-result-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.vehicle-result-title{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.vehicle-result-title h4{
  margin:0;
  font-size:16px;
  font-weight:800;
}

.vehicle-result-meta{
  color:#c7d3e6;
  font-size:13px;
}

.vehicle-result-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.metric-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  font-size:12px;
}

.vehicle-result-body{
  display:grid;
  gap:0;
}

.dispatch-row{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:16px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.dispatch-row:last-child{
  border-bottom:none;
}

.dispatch-left{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.badge-time,
.badge-order,
.badge-status,
.badge-area{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  font-size:12px;
  color:#e9eef8;
}

.dispatch-name{
  font-size:15px;
  font-weight:800;
  color:#fff;
}

.dispatch-area{
  font-size:15px;
  color:#d7e1f0;
  font-weight:700;
}

.dispatch-right{
  display:flex;
  align-items:center;
  gap:12px;
}

.dispatch-distance{
  color:#bcd0e8;
  font-size:13px;
  min-width:64px;
  text-align:right;
}

.dispatch-vehicle-select{
  min-width:180px;
  max-width:220px;
}

.empty-vehicle-text{
  color:#c7d3e6;
  padding:12px 0 2px;
}

/* grouped tables from JS */
.grouped-section{
  padding:10px 12px 0;
  border-top:1px solid rgba(255,255,255,.08);
}

.grouped-section:first-child{
  border-top:none;
}

.grouped-hour-title{
  font-size:15px;
  font-weight:800;
  color:#fff;
  margin-bottom:12px;
}

.grouped-area-title{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  font-size:12px;
  margin-bottom:10px;
}

.grouped-area-heading{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.grouped-area-sub{
  font-size:12px;
  color:#a7b3c7;
}

.grouped-plan-list,
.grouped-actual-list{
  display:grid;
  gap:0;
}

.grouped-row{
  display:grid;
  grid-template-columns:120px 1.3fr 1fr .8fr 1.6fr;
  gap:12px;
  align-items:start;
  padding:12px 0;
  border-top:1px solid rgba(255,255,255,.06);
}

.grouped-row:first-child{
  border-top:none;
}

.grouped-row .op-cell{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.state-stack{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.badge-status.done{
  background:var(--done-bg);
  border-color:var(--done-line);
}

.badge-status.cancel{
  background:var(--cancel-bg);
  border-color:var(--cancel-line);
}

.badge-status.assigned{
  background:var(--assigned-bg);
  border-color:var(--assigned-line);
}

/* matrix */
.matrix-table{
  width:100%;
  min-width:820px;
  border-collapse:collapse;
}

.matrix-table th,
.matrix-table td{
  padding:14px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  vertical-align:top;
  text-align:left;
}

.matrix-table th{
  font-size:13px;
  font-weight:800;
}

.matrix-card{
  display:grid;
  gap:8px;
}

.matrix-summary{
  font-size:13px;
  color:#fff;
  font-weight:700;
}

.matrix-item{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  color:#dce5f4;
  font-size:13px;
}

/* history */
.history-list{
  display:grid;
  gap:10px;
}

.history-item{
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(255,255,255,.02);
}

.history-item h4{
  margin:0 0 6px;
  font-size:14px;
}

.history-item p{
  margin:0;
  color:#c8d3e5;
  font-size:13px;
  line-height:1.6;
}

/* utility */
.muted{
  color:var(--muted);
}

.text-danger{
  color:#ffb6be;
}

.text-done{
  color:#9df0bf;
}

/* responsive */
@media (max-width:1200px){
  .panel-grid.two-col{
    grid-template-columns:1fr;
  }

  .form-grid.five-col{
    grid-template-columns:repeat(2, 1fr);
  }

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

@media (max-width:900px){
  .app-shell{
    width:min(100% - 18px, 1360px);
    padding:14px 0 24px;
  }

  .app-header,
  .daily-header-row{
    flex-direction:column;
    align-items:stretch;
  }

  .header-actions,
  .daily-top-actions{
    justify-content:flex-start;
  }

  .form-grid.two-col,
  .form-grid.three-col,
  .form-grid.five-col{
    grid-template-columns:1fr;
  }

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

  .dispatch-right{
    justify-content:space-between;
    width:100%;
  }

  .dispatch-vehicle-select{
    min-width:140px;
  }

  .main-tabs{
    overflow:auto;
    flex-wrap:nowrap;
    padding-bottom:4px;
  }

  .main-tab{
    white-space:nowrap;
  }

  .data-table{
    min-width:760px;
  }
}
.cast-name-link{
  color:#ffffff;
  text-decoration:none;
  font-weight:800;
  transition:.18s ease;
}

.cast-name-link:hover{
  color:#8fb4ff;
  text-decoration:underline;
}
.map-name-link,
.cast-name-link,
.dispatch-name-link{
  color:#ffffff;
  text-decoration:none;
  font-weight:800;
  transition:.18s ease;
}

.map-name-link:hover,
.cast-name-link:hover,
.dispatch-name-link:hover{
  color:#8fb4ff;
  text-decoration:underline;
}

/* ==============================
   Searchable cast input fixes
   ============================== */

.page-body,
.page-panel,
.panel-card,
.form-grid,
.table-wrap{
  overflow: visible;
}

.field{
  position: relative;
  z-index: 1;
}

.field:focus-within{
  z-index: 300;
}

.cast-search-wrap{
  position: relative;
  z-index: 50;
}

.cast-search-wrap:focus-within{
  z-index: 400;
}

.cast-search-suggest{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  z-index:9999;
  max-height:min(65vh, 520px);
  overflow-y:auto;
  overflow-x:hidden;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:#0f1724;
  box-shadow:0 16px 36px rgba(0,0,0,.45);
  padding:4px;
}

.cast-search-suggest.hidden{
  display:none !important;
}

.cast-search-item{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:2px;
  text-align:left;
  background:transparent;
  border:none;
  color:#fff;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
}

.cast-search-item:hover{
  background:rgba(255,255,255,.06);
}

.cast-search-item small{
  color:#b9c7da;
  font-size:11px;
  line-height:1.3;
  white-space:normal;
  word-break:break-word;
}

/* Keep header/nav buttons aligned even when browser default styles leak */
.header-actions .btn,
.main-tabs .main-tab,
.action-row .btn,
.daily-top-actions .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* File input remains hidden */
input.hidden,
.hidden{
  display:none !important;
}


@media (max-width: 640px){
  .cast-search-suggest{
    max-height:min(50vh, 360px);
  }
}



/* =========================================
   Mobile / Tablet readability tuning
   ========================================= */

html, body{
  overflow-x:hidden;
}

img, table, input, select, textarea, button{
  max-width:100%;
}

@media (max-width: 1100px){
  .app-shell{
    width:min(100% - 18px, 1360px);
    padding:14px 0 22px;
  }

  .app-header,
  .daily-header-row{
    flex-direction:column;
    align-items:stretch;
    gap:12px;
  }

  .header-actions,
  .daily-top-actions{
    justify-content:flex-start;
    gap:8px;
    flex-wrap:wrap;
  }

  .panel-grid.two-col{
    grid-template-columns:1fr;
  }

  .form-grid.five-col{
    grid-template-columns:repeat(2, 1fr);
  }
}

@media (max-width: 900px){
  .app-shell{
    width:min(100% - 12px, 1360px);
    padding:12px 0 18px;
  }

  .brand-wrap{
    gap:6px;
  }

  .app-title{
    font-size:18px;
  }

  .app-subtitle{
    font-size:12px;
    line-height:1.5;
  }

  .main-tabs{
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    padding-bottom:6px;
    gap:8px;
  }

  .main-tabs::-webkit-scrollbar{
    height:4px;
  }

  .main-tab{
    white-space:nowrap;
    flex:0 0 auto;
    min-height:40px;
    padding:9px 14px;
  }

  .panel-card{
    padding:14px 14px 12px;
    border-radius:16px;
  }

  .panel-card h2{
    font-size:18px;
    margin-bottom:14px;
  }

  .panel-card h3{
    font-size:15px;
  }

  .form-grid.two-col,
  .form-grid.three-col,
  .form-grid.five-col{
    grid-template-columns:1fr;
    gap:10px;
  }

  .field label{
    font-size:12px;
  }

  input,
  select,
  textarea{
    font-size:16px;
    padding:11px 12px;
  }

  .action-row,
  .button-row,
  .quick-actions,
  .panel-actions,
  .daily-top-actions{
    gap:8px;
    flex-wrap:wrap;
  }

  .action-row .btn,
  .button-row .btn,
  .quick-actions .btn,
  .panel-actions .btn,
  .daily-top-actions .btn{
    min-height:40px;
    padding:9px 14px;
  }

  .table-wrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    border-radius:14px;
  }

  .data-table{
    min-width:760px;
  }

  .matrix-table{
    min-width:720px;
  }

  .dispatch-row{
    grid-template-columns:1fr;
    gap:10px;
  }

  .dispatch-right{
    width:100%;
    justify-content:space-between;
    gap:10px;
  }

  .dispatch-distance{
    min-width:auto;
    text-align:left;
  }

  .dispatch-vehicle-select{
    width:100%;
    min-width:0;
    max-width:none;
  }

  .grouped-row{
    grid-template-columns:1fr;
    gap:8px;
    padding:10px 0;
  }

  .vehicle-result-head{
    flex-direction:column;
    align-items:flex-start;
  }

  .result-head-row{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }

  .cast-search-suggest{
    max-height:min(60vh, 420px);
  }
}

@media (max-width: 640px){
  .app-shell{
    width:min(100% - 8px, 1360px);
    padding:10px 0 16px;
  }

  .app-title{
    font-size:16px;
  }

  .app-subtitle{
    font-size:11px;
  }

  .header-actions{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:8px;
  }

  .header-actions .btn{
    width:100%;
    padding:8px 10px;
    font-size:13px;
  }

  .main-tab{
    min-height:38px;
    padding:8px 12px;
    font-size:13px;
  }

  .panel-card{
    padding:12px 12px 10px;
    border-radius:14px;
  }

  .panel-card h2{
    font-size:16px;
  }

  .panel-card h3{
    font-size:14px;
  }

  .chip{
    padding:6px 10px;
  }

  .action-row .btn,
  .button-row .btn,
  .quick-actions .btn,
  .panel-actions .btn,
  .daily-top-actions .btn{
    flex:1 1 calc(50% - 8px);
    min-width:120px;
  }

  .cast-search-suggest{
    max-height:min(50vh, 360px);
    border-radius:12px;
  }

  .cast-search-item{
    padding:8px 10px;
  }

  .cast-search-item small{
    font-size:11px;
  }

  /* Card layout for wide data tables on phones */
  .table-wrap.mobile-card{
    border:none;
    background:transparent;
    overflow:visible;
  }

  .table-wrap.mobile-card .data-table{
    min-width:0;
    display:block;
  }

  .table-wrap.mobile-card .data-table thead{
    display:none;
  }

  .table-wrap.mobile-card .data-table tbody{
    display:grid;
    gap:12px;
  }

  .table-wrap.mobile-card .data-table tr{
    display:block;
    border:1px solid rgba(255,255,255,.10);
    border-radius:16px;
    background:rgba(255,255,255,.02);
    padding:10px 12px;
  }

  .table-wrap.mobile-card .data-table td{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:12px;
    padding:8px 0;
    border-bottom:1px solid rgba(255,255,255,.06);
    font-size:13px;
    line-height:1.5;
  }

  .table-wrap.mobile-card .data-table td:last-child{
    border-bottom:none;
    display:block;
    padding-top:10px;
  }

  #castsTab .table-wrap,
  #vehiclesTab .table-wrap,
  #castSearchTab .table-wrap{
    border:none;
    background:transparent;
    overflow:visible;
  }

  #castsTab .data-table,
  #vehiclesTab .data-table,
  #castSearchTab .data-table{
    min-width:0;
    display:block;
  }

  #castsTab .data-table thead,
  #vehiclesTab .data-table thead,
  #castSearchTab .data-table thead{
    display:none;
  }

  #castsTab .data-table tbody,
  #vehiclesTab .data-table tbody,
  #castSearchTab .data-table tbody{
    display:grid;
    gap:12px;
  }

  #castsTab .data-table tr,
  #vehiclesTab .data-table tr,
  #castSearchTab .data-table tr{
    display:block;
    border:1px solid rgba(255,255,255,.10);
    border-radius:16px;
    background:rgba(255,255,255,.02);
    padding:10px 12px;
  }

  #castsTab .data-table td,
  #vehiclesTab .data-table td,
  #castSearchTab .data-table td{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:12px;
    padding:8px 0;
    border-bottom:1px solid rgba(255,255,255,.06);
    font-size:13px;
    line-height:1.5;
  }

  #castsTab .data-table td:last-child,
  #vehiclesTab .data-table td:last-child,
  #castSearchTab .data-table td:last-child{
    border-bottom:none;
    display:block;
    padding-top:10px;
  }

  #castsTab .data-table td:nth-child(1)::before{content:"氏名"; color:#a7b3c7; font-weight:700;}
  #castsTab .data-table td:nth-child(2)::before{content:"住所"; color:#a7b3c7; font-weight:700;}
  #castsTab .data-table td:nth-child(3)::before{content:"方面"; color:#a7b3c7; font-weight:700;}
  #castsTab .data-table td:nth-child(4)::before{content:"想定距離"; color:#a7b3c7; font-weight:700;}
  #castsTab .data-table td:nth-child(5)::before{content:"メモ"; color:#a7b3c7; font-weight:700;}
  #castsTab .data-table td:nth-child(6)::before{content:"操作"; color:#a7b3c7; font-weight:700; display:block; margin-bottom:8px;}

  #vehiclesTab .data-table td:nth-child(1)::before{content:"ドライバー"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(2)::before{content:"車両"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(3)::before{content:"担当方面"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(4)::before{content:"帰宅方面"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(5)::before{content:"定員"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(6)::before{content:"月間距離"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(7)::before{content:"出勤日数"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(8)::before{content:"1日平均"; color:#a7b3c7; font-weight:700;}
  #vehiclesTab .data-table td:nth-child(9)::before{content:"操作"; color:#a7b3c7; font-weight:700; display:block; margin-bottom:8px;}

  #castSearchTab .data-table td:nth-child(1)::before{content:"氏名"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(2)::before{content:"住所"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(3)::before{content:"方面"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(4)::before{content:"想定距離"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(5)::before{content:"電話"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(6)::before{content:"メモ"; color:#a7b3c7; font-weight:700;}
  #castSearchTab .data-table td:nth-child(7)::before{content:"操作"; color:#a7b3c7; font-weight:700; display:block; margin-bottom:8px;}
}

@media (max-width: 420px){
  .header-actions{
    grid-template-columns:1fr 1fr;
  }

  .action-row .btn,
  .button-row .btn,
  .quick-actions .btn,
  .panel-actions .btn,
  .daily-top-actions .btn{
    flex:1 1 100%;
  }

  .main-tab{
    font-size:12px;
    padding:8px 11px;
  }

  .panel-card{
    padding:10px;
  }

  input,
  select,
  textarea{
    padding:10px 11px;
  }
}

/* =========================================
   Extra mobile/tablet layout fixes
   for casts / vehicles / search tables
   ========================================= */

@media (max-width: 900px){
  .app-shell{
    width:min(100% - 10px, 1360px);
  }

  .panel-card{
    overflow:visible;
  }

  .header-actions{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .header-actions .btn{
    min-width:0;
  }

  .action-row,
  .button-row,
  .quick-actions,
  .panel-actions,
  .daily-top-actions{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .action-row .btn,
  .button-row .btn,
  .quick-actions .btn,
  .panel-actions .btn,
  .daily-top-actions .btn{
    flex:1 1 calc(50% - 8px);
    min-width:120px;
  }

  .form-grid.two-col,
  .form-grid.three-col,
  .form-grid.five-col{
    grid-template-columns:1fr;
  }

  .table-wrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}

@media (max-width: 640px){
  .app-shell{
    width:min(100% - 6px, 1360px);
    padding:8px 0 14px;
  }

  .app-header{
    gap:10px;
  }

  .header-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }

  .header-actions .btn{
    width:100%;
    min-height:38px;
    padding:8px 10px;
    font-size:13px;
  }

  .main-tabs{
    gap:8px;
    padding-bottom:6px;
  }

  .main-tab{
    font-size:13px;
    padding:8px 12px;
    min-height:38px;
  }

  .panel-card{
    padding:12px 10px 10px;
    border-radius:14px;
  }

  input,
  select,
  textarea{
    font-size:16px;
  }

  /* Cast / vehicle / search result tables into cards */
  #castsTab .table-wrap,
  #vehiclesTab .table-wrap,
  #castSearchTab .table-wrap{
    border:none;
    background:transparent;
    overflow:visible;
  }

  #castsTab .data-table,
  #vehiclesTab .data-table,
  #castSearchTab .data-table{
    min-width:0;
    width:100%;
    display:block;
    border-collapse:separate;
  }

  #castsTab .data-table thead,
  #vehiclesTab .data-table thead,
  #castSearchTab .data-table thead{
    display:none;
  }

  #castsTab .data-table tbody,
  #vehiclesTab .data-table tbody,
  #castSearchTab .data-table tbody{
    display:grid;
    gap:12px;
  }

  #castsTab .data-table tr,
  #vehiclesTab .data-table tr,
  #castSearchTab .data-table tr{
    display:block;
    border:1px solid rgba(255,255,255,.10);
    border-radius:16px;
    background:rgba(255,255,255,.02);
    padding:10px 12px;
  }

  #castsTab .data-table td,
  #vehiclesTab .data-table td,
  #castSearchTab .data-table td{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:10px;
    padding:7px 0;
    border-bottom:1px solid rgba(255,255,255,.06);
    font-size:13px;
    line-height:1.5;
    word-break:break-word;
  }

  #castsTab .data-table td:last-child,
  #vehiclesTab .data-table td:last-child,
  #castSearchTab .data-table td:last-child{
    border-bottom:none;
    display:block;
    padding-top:10px;
  }

  #castsTab .data-table td::before,
  #vehiclesTab .data-table td::before,
  #castSearchTab .data-table td::before{
    color:#a7b3c7;
    font-weight:700;
    min-width:82px;
    flex:0 0 82px;
  }

  #castsTab .data-table td:nth-child(1)::before{content:"氏名";}
  #castsTab .data-table td:nth-child(2)::before{content:"住所";}
  #castsTab .data-table td:nth-child(3)::before{content:"方面";}
  #castsTab .data-table td:nth-child(4)::before{content:"想定距離";}
  #castsTab .data-table td:nth-child(5)::before{content:"メモ";}
  #castsTab .data-table td:nth-child(6)::before{content:"操作"; display:block; margin-bottom:8px;}

  #vehiclesTab .data-table td:nth-child(1)::before{content:"ドライバー";}
  #vehiclesTab .data-table td:nth-child(2)::before{content:"車両";}
  #vehiclesTab .data-table td:nth-child(3)::before{content:"担当方面";}
  #vehiclesTab .data-table td:nth-child(4)::before{content:"帰宅方面";}
  #vehiclesTab .data-table td:nth-child(5)::before{content:"定員";}
  #vehiclesTab .data-table td:nth-child(6)::before{content:"月間距離";}
  #vehiclesTab .data-table td:nth-child(7)::before{content:"出勤日数";}
  #vehiclesTab .data-table td:nth-child(8)::before{content:"1日平均";}
  #vehiclesTab .data-table td:nth-child(9)::before{content:"操作"; display:block; margin-bottom:8px;}

  #castSearchTab .data-table td:nth-child(1)::before{content:"氏名";}
  #castSearchTab .data-table td:nth-child(2)::before{content:"住所";}
  #castSearchTab .data-table td:nth-child(3)::before{content:"方面";}
  #castSearchTab .data-table td:nth-child(4)::before{content:"想定距離";}
  #castSearchTab .data-table td:nth-child(5)::before{content:"電話";}
  #castSearchTab .data-table td:nth-child(6)::before{content:"メモ";}
  #castSearchTab .data-table td:nth-child(7)::before{content:"操作"; display:block; margin-bottom:8px;}

  .data-table .actions-cell{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .data-table .actions-cell .btn{
    flex:1 1 calc(50% - 8px);
  }
}

@media (max-width: 420px){
  .header-actions{
    grid-template-columns:1fr 1fr;
  }

  .main-tab{
    font-size:12px;
    padding:8px 11px;
  }

  .action-row .btn,
  .button-row .btn,
  .quick-actions .btn,
  .panel-actions .btn,
  .daily-top-actions .btn{
    flex:1 1 100%;
  }
}

/* =========================================================
   UI tidy v2: nav / cast-management / settings polish
   ========================================================= */

.main-tabs{
  align-items:center;
}

.main-tabs #openManualBtn{
  margin-left:auto;
  border-radius:999px;
  padding-inline:18px;
  white-space:nowrap;
}

#castsTab .section-head:first-child,
#castSearchTab .section-head:first-child{
  margin-bottom:12px;
}

#castsTab .action-row:first-of-type,
#castSearchTab .action-row:first-of-type{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px;
  margin-bottom:18px !important;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.025);
}

#castsTab .action-row:first-of-type .btn,
#castSearchTab .action-row:first-of-type .btn{
  min-width:132px;
  min-height:40px;
  border-radius:14px;
  padding:9px 14px;
}

#castsTab .action-row:first-of-type .btn.ghost,
#castSearchTab .action-row:first-of-type .btn.ghost{
  background:transparent;
}

#settingsTab .panel-card:first-child .action-row{
  padding:8px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
}

#settingsTab .panel-card:first-child .action-row .btn{
  min-width:140px;
}

#settingsTab h3{
  display:flex;
  align-items:center;
  gap:8px;
}

#settingsTab h3::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(47,109,246,.95);
  box-shadow:0 0 0 6px rgba(47,109,246,.10);
}

@media (max-width: 900px){
  .main-tabs #openManualBtn{
    margin-left:0;
  }

  #castsTab .action-row:first-of-type,
  #castSearchTab .action-row:first-of-type{
    width:100%;
  }

  #castsTab .action-row:first-of-type .btn,
  #castSearchTab .action-row:first-of-type .btn,
  #settingsTab .panel-card:first-child .action-row .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .main-tabs{
    gap:8px;
  }

  .main-tabs .main-tab,
  .main-tabs #openManualBtn{
    min-height:40px;
    padding:9px 14px;
  }

  #castsTab .action-row:first-of-type,
  #castSearchTab .action-row:first-of-type,
  #settingsTab .panel-card:first-child .action-row{
    display:flex;
    width:100%;
    gap:8px;
    padding:6px;
  }

  #castsTab .action-row:first-of-type .btn,
  #castSearchTab .action-row:first-of-type .btn,
  #settingsTab .panel-card:first-child .action-row .btn{
    width:100%;
    min-width:0;
    flex:1 1 100%;
  }
}


.field-full{grid-column:1/-1;}
.geo-status{min-height:50px;padding:12px 14px;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:rgba(255,255,255,.04);color:#a9b4c5;display:flex;align-items:center;line-height:1.5;font-size:.95rem;}
.geo-status.loading{color:#d7e3ff;border-color:rgba(96,149,255,.55);box-shadow:0 0 0 1px rgba(96,149,255,.15) inset;}
.geo-status.success{color:#7be2ab;border-color:rgba(47,191,122,.55);background:rgba(47,191,122,.10);}
.geo-status.error{color:#ffb4b4;border-color:rgba(224,82,82,.55);background:rgba(224,82,82,.10);}
.geo-status.manual{color:#ffd782;border-color:rgba(255,195,0,.45);background:rgba(255,195,0,.08);}
