: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;
}

.chip.subtle{
  background:rgba(255,255,255,.02);
  border-color:rgba(255,255,255,.06);
  color:#a7b3c7;
}

.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;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:12px;
}

.vehicle-check-header{
  display:grid;
  grid-template-columns:minmax(0,1fr) 110px 110px;
  align-items:end;
  gap:14px;
  padding:0 12px 2px;
}

.vehicle-check-header-col{
  text-align:center;
  font-size:13px;
  font-weight:800;
  color:#dfe9f8;
}

.vehicle-check-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) 110px 110px;
  align-items:center;
  gap:14px;
  padding:14px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:linear-gradient(90deg, rgba(255,255,255,.02), rgba(255,255,255,.00) 40%, rgba(255,255,255,.02));
}

.vehicle-check-info{
  min-width:0;
}

.vehicle-check-name{
  font-size:18px;
  font-weight:800;
  color:#fff;
  line-height:1.25;
}

.vehicle-check-car{
  margin-top:4px;
  font-size:15px;
  font-weight:700;
  color:#dce6f5;
}

.vehicle-check-meta{
  margin-top:6px;
  font-size:13px;
  color:#aebcd0;
  line-height:1.6;
}

.vehicle-check-toggle{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:74px;
  padding:10px 8px;
  border-radius:16px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.08);
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}

.vehicle-check-toggle-work{
  color:#e8eef9;
}

.vehicle-check-toggle-last{
  color:#ffdf8c;
}

.vehicle-check-input,
.driver-last-trip-input{
  width:19px;
  height:19px;
  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;
  margin:0 0 10px;
}

.direction-ui-matrix-table{
  min-width:760px;
}

.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);}


/* ===============================
   Daily vehicle checklist tuning
================================ */
@media (max-width: 900px){
  .vehicle-check-header,
  .vehicle-check-item{
    grid-template-columns:minmax(0,1fr) 92px 92px;
  }
}

@media (max-width: 700px){
  .vehicle-checklist{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .vehicle-check-header{
    display:none;
  }

  .vehicle-check-item{
    grid-template-columns:1fr 1fr;
    gap:8px;
    padding:12px 10px;
    align-items:stretch;
  }

  .vehicle-check-info{
    grid-column:1 / -1;
  }

  .vehicle-check-name{
    font-size:16px;
  }

  .vehicle-check-car{
    font-size:14px;
  }

  .vehicle-check-meta{
    font-size:12px;
  }

  .vehicle-check-toggle{
    min-height:auto;
    flex-direction:row;
    justify-content:center;
    gap:7px;
    padding:8px 6px;
    font-size:12px;
  }
}

/* =========================================
   Matrix legend + status colors
   ========================================= */
.matrix-legend{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  margin:0 0 10px;
  font-size:12px;
  color:#cdd8ea;
}
.matrix-legend-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.matrix-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  display:inline-block;
  box-shadow:0 0 0 1px rgba(255,255,255,.14) inset;
}
.matrix-dot.pending{ background:#f0c24b; }
.matrix-dot.done{ background:#2fbf7a; }
.matrix-dot.cancel{ background:#e05252; }

.matrix-line{
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.matrix-name{
  font-weight:700;
}
.matrix-name.status-pending,
.matrix-name.status-assigned,
.matrix-name.status-planned,
.matrix-name.status-waiting{
  color:#f0c24b;
}
.matrix-name.status-done{
  color:#2fbf7a;
}
.matrix-name.status-cancel{
  color:#ff7b86;
}
.matrix-meta{
  color:#dce5f4;
  white-space:nowrap;
  word-break:keep-all;
}

.matrix-subarea{
  color:#9fb1cc;
  font-size:12px;
  line-height:1.35;
  padding-left:2px;
}

@media (max-width:640px){
  .matrix-legend{
    gap:8px 12px;
    font-size:11px;
  }
  .matrix-line{
    align-items:flex-start;
    gap:4px;
  }
  .matrix-name{
    line-height:1.3;
  }
  .matrix-meta{
    font-size:12px;
  }
}


/* mileage month matrix */
.mileage-report-grid{
  display:grid;
  gap:16px;
}

.mileage-matrix-section{
  display:grid;
  gap:10px;
}

.mileage-matrix-wrap{
  margin-top:0;
}

.mileage-matrix-table{
  min-width:1200px;
}

.mileage-matrix-table th,
.mileage-matrix-table td{
  white-space:nowrap;
  text-align:center;
}

.mileage-matrix-table th:first-child,
.mileage-matrix-table td:first-child{
  text-align:left;
  position:sticky;
  left:0;
  z-index:1;
  background:#101722;
}

.mileage-matrix-table thead th:first-child{
  z-index:2;
}

.mileage-driver-cell{
  min-width:120px;
  font-weight:800;
}

.mileage-day-cell{
  color:#dce5f4;
}

@media (max-width: 900px){
  .mileage-matrix-table{
    min-width:980px;
  }
}


.list-toggle-block{
  margin-top:14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.02);
  padding:12px;
}

.list-toggle-block summary{
  list-style:none;
  cursor:pointer;
  font-weight:800;
  color:#f4f8ff;
  display:flex;
  align-items:center;
  gap:8px;
  user-select:none;
}

.list-toggle-block summary::-webkit-details-marker{
  display:none;
}

.list-toggle-block summary::before{
  content:"▶";
  font-size:12px;
  color:#b9c7da;
  transition:transform .18s ease;
}

.list-toggle-block[open] summary::before{
  transform:rotate(90deg);
}

.list-toggle-block .table-wrap{
  margin-top:12px;
}

.cast-list-toggle:not([open]) .table-wrap{
  display:none;
}


.sim-toggle-row{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  background:rgba(255,255,255,.03);
  color:#e8eef9;
  font-size:13px;
  font-weight:700;
}

.sim-toggle-row input{
  width:18px;
  height:18px;
  margin:0;
  accent-color:#2f6df6;
}


/* daily hybrid on-demand + visual readability */
.hybrid-grid-stack{
  grid-template-columns:1fr;
}

.hybrid-toggle-card{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  overflow:hidden;
}

.hybrid-toggle-summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  cursor:pointer;
}
.hybrid-toggle-summary::-webkit-details-marker{ display:none; }
.hybrid-toggle-title-wrap{ display:flex; align-items:center; gap:12px; min-width:0; }
.hybrid-toggle-icon{
  width:40px; height:40px; border-radius:14px; display:grid; place-items:center;
  background:rgba(47,109,246,.18); font-size:20px;
}
.hybrid-toggle-title{ font-size:16px; font-weight:800; color:#fff; }
.hybrid-toggle-sub{ font-size:12px; color:#aebcd0; margin-top:2px; }
.hybrid-card-inner{ border:none; box-shadow:none; background:transparent; padding:0 16px 16px; }

.hybrid-summary-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.hybrid-summary-item{
  display:flex; align-items:center; gap:12px; min-width:0;
  border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:12px;
  background:rgba(255,255,255,.03);
}
.hybrid-summary-item.tone-blue{ background:rgba(47,109,246,.12); }
.hybrid-summary-item.tone-indigo{ background:rgba(89,89,216,.12); }
.hybrid-summary-item.tone-amber{ background:rgba(217,149,39,.12); }
.hybrid-summary-item.tone-green{ background:rgba(47,191,122,.12); }
.hybrid-summary-icon{
  width:38px; height:38px; border-radius:12px; display:grid; place-items:center;
  background:rgba(255,255,255,.08); font-size:18px; flex:0 0 auto;
}
.hybrid-summary-body{ min-width:0; }
.hybrid-summary-label{ font-size:12px; color:#aebcd0; font-weight:700; }
.hybrid-summary-value{ margin-top:3px; font-size:18px; color:#fff; font-weight:800; }

.hybrid-diagnosis{
  margin-top:12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:12px;
  background:rgba(255,255,255,.03);
}
.hybrid-diagnosis.ok{ background:rgba(47,191,122,.10); border-color:rgba(47,191,122,.28); }
.hybrid-diagnosis.warn{ background:rgba(230,174,32,.10); border-color:rgba(230,174,32,.28); }
.hybrid-diagnosis.danger{ background:rgba(224,82,82,.10); border-color:rgba(224,82,82,.28); }

.hybrid-state-row{
  display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px;
}
.status-pill{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04); font-weight:800;
}
.status-pill.ok{ background:rgba(47,191,122,.15); border-color:rgba(47,191,122,.38); }
.status-pill.warn{ background:rgba(230,174,32,.15); border-color:rgba(230,174,32,.38); }
.status-pill.danger{ background:rgba(224,82,82,.15); border-color:rgba(224,82,82,.38); }
.status-pill-label{ font-size:12px; color:#dbe7f7; }
.status-pill-value{ font-size:13px; color:#fff; }

.hybrid-legend-grid{
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px;
}
.hybrid-legend-card{
  border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:12px;
  background:rgba(255,255,255,.03);
}
.hybrid-legend-title{ font-size:12px; color:#aebcd0; font-weight:700; }
.hybrid-legend-value{ margin-top:5px; font-size:15px; color:#fff; font-weight:800; line-height:1.45; }

.sim-preview-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.sim-preview-title{ margin:0; font-size:15px; font-weight:800; }
.sim-preview-meta{ margin-top:8px; font-size:13px; color:#aebcd0; line-height:1.55; }
.sim-mini-chip-grid{
  display:flex; flex-wrap:wrap; gap:8px; margin-top:10px;
}
.sim-mini-chip{
  display:flex; flex-direction:column; gap:4px; min-width:112px;
  padding:10px 12px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.sim-mini-name{ font-size:14px; font-weight:800; color:#fff; }
.sim-mini-area{ font-size:12px; color:#aebcd0; }
.simulation-preview{
  margin-top:12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:12px;
  background:rgba(255,255,255,.03);
}
.simulation-preview.muted{ color:#aebcd0; }

.dispatch-summary-bar{
  position:sticky;
  top:0;
  z-index:30;
  background:#121823;
  border:1px solid rgba(255,255,255,.10);
  padding:14px;
  border-radius:14px;
  font-weight:800;
  margin:14px 0 10px;
  box-shadow:0 4px 12px rgba(0,0,0,0.22);
  font-size:15px;
}

@media (max-width: 768px){
  .hybrid-toggle-summary{ padding:12px; }
  .hybrid-toggle-icon{ width:34px; height:34px; border-radius:12px; font-size:17px; }
  .hybrid-toggle-title{ font-size:15px; }
  .hybrid-summary-grid,
  .hybrid-legend-grid{ grid-template-columns:1fr; }
  .hybrid-summary-item{ padding:10px; }
  .hybrid-summary-value{ font-size:16px; }
  .status-pill{ width:100%; justify-content:space-between; }
  .sim-mini-chip-grid{ display:grid; grid-template-columns:1fr 1fr; }
}

@media (max-width: 480px){
  .sim-mini-chip-grid{ grid-template-columns:1fr; }
}


.header-actions{
  align-items:center;
}

#adminHeaderBtn{
  min-width:132px;
}

/* =========================================================
   mileage report mobile horizontal scroll fix
   ========================================================= */
@media (max-width: 900px){
  #vehiclesTab #mileageReportTableWrap.table-wrap,
  #vehiclesTab .mileage-matrix-wrap.table-wrap{
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.02);
  }
}

@media (max-width: 640px){
  #vehiclesTab #mileageReportTableWrap.table-wrap,
  #vehiclesTab .mileage-matrix-wrap.table-wrap{
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.02);
    border-radius:14px;
  }

  #vehiclesTab #mileageReportTableWrap .mileage-matrix-table,
  #vehiclesTab .mileage-matrix-wrap .mileage-matrix-table{
    display:table;
    width:max-content;
    min-width:980px;
  }

  #vehiclesTab #mileageReportTableWrap .mileage-matrix-section,
  #vehiclesTab .mileage-matrix-wrap .mileage-matrix-section{
    min-width:max-content;
  }
}


/* =========================================
   Direction UI finish
   ========================================= */
.direction-ui-shell{
  display:grid;
  gap:12px;
}

.direction-ui-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
}

.direction-ui-summary{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.direction-ui-origin,
.direction-ui-pill{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:#dce5f4;
  font-size:12px;
  font-weight:700;
}

.direction-ui-origin{
  color:#ffffff;
  background:rgba(81,132,255,.14);
  border-color:rgba(81,132,255,.30);
}

.direction-ui-table-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.015));
}

.direction-ui-empty{
  padding:14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(255,255,255,.02);
  color:#9fb1cc;
}

.direction-ui-matrix-table{
  min-width:920px;
}

.direction-ui-matrix-table thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:rgba(10,16,28,.94);
  backdrop-filter:blur(10px);
}

.direction-ui-matrix-table th:first-child,
.direction-ui-matrix-table td:first-child{
  position:sticky;
  left:0;
  z-index:1;
  min-width:72px;
  width:72px;
  background:rgba(10,16,28,.96);
  font-weight:800;
}

.direction-ui-matrix-table thead th:first-child{
  z-index:3;
}

.direction-ui-matrix-table td{
  min-width:220px;
}

.direction-ui-matrix-table th{
  white-space:nowrap;
}

.matrix-cell-empty{
  color:#6f819d;
}

.matrix-empty-mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:44px;
  color:#6f819d;
}

.direction-ui-matrix-table .matrix-card{
  gap:10px;
}

.direction-ui-matrix-table .matrix-item{
  display:grid;
  gap:4px;
  align-items:flex-start;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  background:rgba(255,255,255,.02);
}

.direction-ui-matrix-table .matrix-subarea{
  padding-left:0;
}

@media (max-width: 900px){
  .direction-ui-matrix-table{
    min-width:760px;
  }

  .direction-ui-matrix-table td{
    min-width:180px;
  }
}

@media (max-width: 640px){
  .direction-ui-header{
    gap:10px;
  }

  .direction-ui-summary{
    gap:6px;
  }

  .direction-ui-origin,
  .direction-ui-pill{
    min-height:28px;
    padding:5px 10px;
    font-size:11px;
  }

  .direction-ui-table-wrap{
    border-radius:14px;
  }

  .direction-ui-matrix-table{
    min-width:700px;
  }

  .direction-ui-matrix-table th:first-child,
  .direction-ui-matrix-table td:first-child{
    min-width:64px;
    width:64px;
  }

  .direction-ui-matrix-table .matrix-item{
    padding:8px 10px;
    border-radius:12px;
  }
}


.admin-team-name-wrap{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.admin-forced-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(120, 220, 160, .35);
  background:rgba(120, 220, 160, .14);
  color:#c9f7d7;
  font-size:12px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
}

.admin-team-row-forced td{
  background:rgba(120, 220, 160, .06);
}

.btn.ghost.forced-active,
.btn.forced-active{
  border-color:rgba(120, 220, 160, .38);
  background:rgba(120, 220, 160, .14);
  color:#d6ffe3;
}

.btn.ghost.forced-active:disabled,
.btn.forced-active:disabled{
  opacity:1;
  cursor:default;
}

.platform-admin-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:12px;
  margin:16px 0 14px;
}

.platform-admin-summary-card,
.platform-admin-detail-card{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:12px 14px;
}

.platform-admin-summary-label,
.platform-admin-detail-label{
  font-size:12px;
  color:rgba(255,255,255,.62);
  margin-bottom:6px;
}

.platform-admin-summary-value,
.platform-admin-detail-value{
  font-size:24px;
  font-weight:800;
  line-height:1.1;
}

.platform-admin-detail-value-small{
  font-size:13px;
  font-weight:700;
  line-height:1.45;
}

.platform-admin-filter-row{
  display:grid;
  grid-template-columns:minmax(220px, 1.5fr) minmax(140px, .8fr) auto;
  gap:12px;
  align-items:end;
  margin:12px 0 10px;
}

.platform-admin-filter-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.platform-admin-filter-field span{
  font-size:12px;
  color:rgba(255,255,255,.62);
}

.platform-admin-detail-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(120px, 1fr));
  gap:10px;
  margin:12px 0 10px;
}

.platform-admin-flag-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 12px;
}

.platform-admin-flag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  line-height:1.2;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:#f3f6ff;
  white-space:nowrap;
}

.platform-admin-flag.success{
  border-color:rgba(120, 220, 160, .30);
  background:rgba(120, 220, 160, .12);
  color:#d6ffe3;
}

.platform-admin-flag.warning{
  border-color:rgba(255, 210, 120, .30);
  background:rgba(255, 210, 120, .12);
  color:#ffe6b0;
}

.platform-admin-flag.danger{
  border-color:rgba(255, 110, 110, .28);
  background:rgba(255, 110, 110, .10);
  color:#ffcece;
}

.platform-admin-flag.muted{
  border-color:rgba(180, 190, 220, .22);
  background:rgba(180, 190, 220, .08);
  color:#d8e0ff;
}

.platform-admin-role-badge,
.platform-admin-state-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  line-height:1.2;
  border:1px solid rgba(255,255,255,.12);
}

.platform-admin-role-badge.owner{
  background:rgba(120, 220, 160, .12);
  border-color:rgba(120, 220, 160, .26);
  color:#d9ffe6;
}

.platform-admin-role-badge.admin{
  background:rgba(120, 180, 255, .12);
  border-color:rgba(120, 180, 255, .28);
  color:#dceaff;
}

.platform-admin-role-badge.user{
  background:rgba(255,255,255,.06);
  color:#f1f4ff;
}

.platform-admin-state-badge.active{
  background:rgba(120, 220, 160, .10);
  border-color:rgba(120, 220, 160, .24);
  color:#d6ffe3;
}

.platform-admin-state-badge.inactive{
  background:rgba(255, 110, 110, .10);
  border-color:rgba(255, 110, 110, .24);
  color:#ffd6d6;
}

.admin-team-row-selected td{
  box-shadow:inset 0 1px 0 rgba(120, 180, 255, .18), inset 0 -1px 0 rgba(120, 180, 255, .18);
  background:rgba(120, 180, 255, .05);
}

.admin-team-row-selected.admin-team-row-forced td{
  background:linear-gradient(0deg, rgba(120, 180, 255, .06), rgba(120, 220, 160, .07));
}

@media (max-width: 900px){
  .platform-admin-filter-row{
    grid-template-columns:1fr;
  }
}


.home-setup-card {
  border-color: rgba(123, 226, 171, 0.22);
  box-shadow: 0 0 0 1px rgba(123, 226, 171, 0.08) inset;
}

.home-setup-priority-card {
  margin-bottom: 18px;
  border-color: rgba(123, 226, 171, 0.34);
  box-shadow: 0 0 0 1px rgba(123, 226, 171, 0.12) inset, 0 10px 28px rgba(40, 120, 80, 0.14);
}

.home-setup-priority-head {
  align-items: flex-start;
  gap: 12px;
}

.home-setup-priority-head h2 {
  margin-bottom: 6px;
}

.home-setup-priority-sub {
  margin: 0;
}

.home-setup-actions {
  margin-top: 12px;
  flex-wrap: wrap;
}

.section-head.compact {
  margin-bottom: 10px;
}

.home-overview-card .quick-actions {
  margin-bottom: 0;
}

.home-secondary-card {
  transition: opacity .2s ease, filter .2s ease, transform .2s ease;
}

#homeTab.setup-priority-active .home-secondary-card {
  opacity: 0.62;
  filter: saturate(.86);
}

#homeTab.setup-priority-active .home-setup-priority-card {
  transform: translateY(-1px);
}

#homeTab .home-setup-priority-card.setup-complete {
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 0 0 1px rgba(255,255,255,.04) inset;
}

#homeTab .home-setup-priority-card.setup-complete .home-setup-priority-sub {
  opacity: .78;
}

@media (max-width: 900px) {
  .home-setup-priority-head {
    align-items: stretch;
  }
}


.dialog-backdrop{
  position:fixed;
  inset:0;
  background:rgba(3,8,15,.72);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  z-index:1200;
}

.dialog-card{
  width:min(100%, 720px);
  max-height:min(80vh, 760px);
  overflow:auto;
  border:1px solid rgba(96,165,250,.18);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(9,16,28,.98), rgba(10,20,34,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  padding:18px;
}

.dialog-head,
.dialog-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.dialog-head{
  margin-bottom:14px;
}

.dialog-actions{
  margin-top:14px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.plan-picker-list{
  display:grid;
  gap:10px;
  margin-top:10px;
}

.plan-picker-row{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  border:1px solid rgba(148,163,184,.18);
  border-radius:14px;
  background:rgba(255,255,255,.02);
}

.plan-picker-row input{
  margin-top:2px;
}

.plan-picker-meta{
  display:grid;
  gap:4px;
}

.plan-picker-main{
  font-weight:700;
}

.plan-picker-sub{
  color:var(--muted);
  font-size:12px;
  line-height:1.5;
}
