/* Trans Express Logistics — Frontend Styles */

:root {
  --tel-blue:        #1e3a5f;
  --tel-blue-dark:   #152c47;
  --tel-blue-light:  #2d5380;
  --tel-orange:      #f5821f;
  --tel-orange-dark: #d96d0e;
  --tel-green:       #28a745;
  --tel-red:         #dc3545;
  --tel-gray:        #6c757d;
  --tel-light:       #f8f9fa;
  --tel-border:      #dee2e6;
  --tel-white:       #ffffff;
  --tel-shadow:      0 4px 20px rgba(30, 58, 95, 0.12);
  --tel-radius:      10px;
}

/* =====================================================
   QUOTE FORM
   ===================================================== */
.tel-quote-wrapper {
  max-width: 860px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Progress Steps */
.tel-progress-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 30px 0 40px;
  padding: 0 20px;
}
.tel-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.tel-step-num {
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 2px solid var(--tel-border);
  background: var(--tel-white);
  color: var(--tel-gray);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: 15px;
  transition: all 0.3s;
}
.tel-step-active .tel-step-num,
.tel-step-done .tel-step-num {
  background: var(--tel-blue);
  border-color: var(--tel-blue);
  color: #fff;
}
.tel-step-label {
  font-size: 12px;
  color: var(--tel-gray);
  font-weight: 500;
  white-space: nowrap;
}
.tel-step-active .tel-step-label { color: var(--tel-blue); font-weight: 600; }
.tel-step-line {
  flex: 1;
  height: 2px;
  background: var(--tel-border);
  margin: 0 10px;
  margin-bottom: 20px;
  transition: background 0.3s;
}
.tel-step-line.done { background: var(--tel-blue); }

/* Form card */
.tel-form {
  background: var(--tel-white);
  border-radius: var(--tel-radius);
  box-shadow: var(--tel-shadow);
  overflow: hidden;
}
.tel-form-step { padding: 35px 40px; }
@media (max-width: 600px) { .tel-form-step { padding: 20px; } }

/* Section titles */
.tel-form-section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--tel-blue);
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--tel-border);
  display: flex;
  align-items: center;
  gap: 10px;
}
.tel-section-icon { font-size: 20px; }

/* Fields */
.tel-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.tel-field { display: flex; flex-direction: column; gap: 6px; }
.tel-field-full { grid-column: 1 / -1; }
.tel-field label {
  font-size: 13px;
  font-weight: 600;
  color: var(--tel-blue);
}
.tel-required { color: var(--tel-red); }
.tel-field input,
.tel-field select,
.tel-field textarea {
  padding: 10px 14px;
  border: 1.5px solid var(--tel-border);
  border-radius: 7px;
  font-size: 14px;
  color: #333;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: var(--tel-white);
  width: 100%;
  box-sizing: border-box;
}
.tel-field input:focus,
.tel-field select:focus,
.tel-field textarea:focus {
  outline: none;
  border-color: var(--tel-blue);
  box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.12);
}
.tel-field input.tel-error,
.tel-field textarea.tel-error { border-color: var(--tel-red); }
.tel-hint { font-size: 11px; color: var(--tel-gray); }

/* Dimensions grid */
.tel-dims-grid { grid-template-columns: 1fr 1fr 1fr 1fr; }
.tel-cbm-display {
  background: var(--tel-light);
  border: 1.5px solid var(--tel-border);
  border-radius: 7px;
  padding: 10px 14px;
  font-weight: 700;
  color: var(--tel-blue);
  font-size: 14px;
}

/* Checkboxes */
.tel-checkbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 10px;
}
.tel-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
  padding: 10px 14px;
  border: 1.5px solid var(--tel-border);
  border-radius: 7px;
  transition: border-color 0.2s, background 0.2s;
}
.tel-checkbox-label:hover { border-color: var(--tel-blue); background: #f0f4f8; }
.tel-checkbox-label input { width: auto; }

/* Shipping Mode Cards */
.tel-mode-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.tel-mode-card { position: relative; }
.tel-mode-card input[type="radio"] { position: absolute; opacity: 0; }
.tel-mode-content {
  border: 2px solid var(--tel-border);
  border-radius: 10px;
  padding: 18px 12px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.tel-mode-card input:checked + .tel-mode-content {
  border-color: var(--tel-blue);
  background: #f0f4f8;
}
.tel-mode-card:hover .tel-mode-content { border-color: var(--tel-blue-light); }
.tel-mode-icon { font-size: 28px; margin-bottom: 8px; }
.tel-mode-name { font-weight: 700; font-size: 13px; color: var(--tel-blue); }
.tel-mode-desc { font-size: 11px; color: var(--tel-gray); margin-top: 4px; line-height: 1.4; }

/* Service cards */
.tel-service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.tel-service-card { position: relative; }
.tel-service-card input { position: absolute; opacity: 0; }
.tel-service-content {
  border: 2px solid var(--tel-border);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.tel-service-card input:checked + .tel-service-content {
  border-color: var(--tel-orange);
  background: #fff7f0;
}
.tel-service-content strong { display: block; font-size: 14px; color: var(--tel-blue); }
.tel-service-content small { font-size: 11px; color: var(--tel-gray); }

/* Port autocomplete */
.tel-port-select-wrapper { position: relative; }
.tel-port-suggestions {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  background: #fff;
  border: 1px solid var(--tel-border);
  border-top: none;
  border-radius: 0 0 8px 8px;
  z-index: 100;
  max-height: 220px;
  overflow-y: auto;
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
  display: none;
}
.tel-port-suggestions.open { display: block; }
.tel-port-suggestion-item {
  padding: 10px 14px;
  cursor: pointer;
  font-size: 13px;
  border-bottom: 1px solid #f0f0f0;
}
.tel-port-suggestion-item:hover { background: #f0f4f8; }
.tel-port-suggestion-item strong { color: var(--tel-blue); }
.tel-port-suggestion-item small { color: var(--tel-gray); display: block; font-size: 11px; }
.tel-port-tag {
  display: inline-block;
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 5px;
  font-weight: 600;
}
.tel-port-tag-sea  { background: var(--tel-blue); color: #fff; }
.tel-port-tag-air  { background: #6f42c1; color: #fff; }
.tel-port-tag-road { background: var(--tel-orange); color: #fff; }

/* Rate estimator */
.tel-rate-estimator {
  background: linear-gradient(135deg, var(--tel-blue), var(--tel-blue-light));
  color: #fff;
  border-radius: var(--tel-radius);
  padding: 25px 30px;
  margin-top: 30px;
}
.tel-rate-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  font-size: 14px;
  opacity: 0.9;
}
.tel-rate-loading { font-style: italic; opacity: 0.7; }
.tel-rate-amount {
  font-size: 36px;
  font-weight: 800;
  margin-bottom: 10px;
  color: var(--tel-orange);
}
.tel-rate-breakdown {
  font-size: 12px;
  opacity: 0.8;
  line-height: 1.8;
}
.tel-rate-transit {
  margin-top: 10px;
  font-size: 13px;
  opacity: 0.9;
}
.tel-rate-note {
  font-size: 11px;
  opacity: 0.6;
  margin-top: 10px;
  font-style: italic;
}

/* Review step */
.tel-review-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 30px;
}
.tel-review-section {
  background: var(--tel-light);
  border: 1px solid var(--tel-border);
  border-radius: 8px;
  padding: 18px;
}
.tel-review-section h4 {
  font-size: 13px;
  color: var(--tel-blue);
  font-weight: 700;
  text-transform: uppercase;
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--tel-border);
}
.tel-review-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  padding: 5px 0;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
.tel-review-row:last-child { border-bottom: none; }
.tel-review-row label { color: var(--tel-gray); }
.tel-review-row span  { font-weight: 600; color: #333; }

/* Form navigation */
.tel-form-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 25px;
  margin-top: 25px;
  border-top: 1px solid var(--tel-border);
}

/* Buttons */
.tel-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 24px;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
}
.tel-btn-primary {
  background: var(--tel-blue);
  color: #fff;
  border-color: var(--tel-blue);
}
.tel-btn-primary:hover { background: var(--tel-blue-dark); border-color: var(--tel-blue-dark); color: #fff; }
.tel-btn-outline {
  background: transparent;
  color: var(--tel-blue);
  border-color: var(--tel-blue);
}
.tel-btn-outline:hover { background: var(--tel-blue); color: #fff; }
.tel-btn-submit {
  background: var(--tel-orange);
  color: #fff;
  border-color: var(--tel-orange);
  width: 100%;
  justify-content: center;
  padding: 14px;
  font-size: 16px;
}
.tel-btn-submit:hover { background: var(--tel-orange-dark); border-color: var(--tel-orange-dark); color: #fff; }
.tel-btn-sm { padding: 6px 14px; font-size: 12px; }

/* Success / Error boxes */
.tel-success-box {
  text-align: center;
  padding: 50px 40px;
  background: #fff;
  border-radius: var(--tel-radius);
  box-shadow: var(--tel-shadow);
}
.tel-success-icon { font-size: 60px; margin-bottom: 15px; }
.tel-success-box h3 { font-size: 24px; color: var(--tel-green); margin-bottom: 10px; }
.tel-success-tracking-id {
  background: var(--tel-blue);
  color: #fff;
  font-size: 24px;
  font-weight: 800;
  padding: 15px 30px;
  border-radius: 8px;
  margin: 15px auto;
  display: inline-block;
  letter-spacing: 2px;
}
.tel-success-rate {
  font-size: 20px;
  color: var(--tel-orange);
  font-weight: 700;
  margin: 15px 0;
}
.tel-error-box {
  background: #f8d7da;
  border: 1px solid #f5c2c7;
  border-radius: 8px;
  padding: 15px 20px;
  color: #842029;
  font-size: 14px;
}

/* =====================================================
   TRACKING
   ===================================================== */
.tel-tracking-wrapper { max-width: 700px; margin: 0 auto; }
.tel-tracking-form { margin-bottom: 30px; }
.tel-track-input-group {
  display: flex;
  gap: 10px;
}
.tel-track-input {
  flex: 1;
  padding: 12px 16px;
  border: 2px solid var(--tel-border);
  border-radius: 8px;
  font-size: 15px;
}
.tel-track-input:focus { border-color: var(--tel-blue); outline: none; }
.tel-track-btn {
  padding: 12px 24px;
  background: var(--tel-orange);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}
.tel-tracking-result {
  background: #fff;
  border-radius: var(--tel-radius);
  padding: 30px;
  box-shadow: var(--tel-shadow);
}
.tel-tracking-id-display {
  font-size: 22px;
  font-weight: 800;
  color: var(--tel-blue);
  margin-bottom: 10px;
}
.tel-tracking-route {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 16px;
  margin: 15px 0;
  font-weight: 600;
}
.tel-track-arrow { color: var(--tel-orange); font-size: 20px; }
.tel-tracking-not-found {
  background: var(--tel-light);
  border-radius: var(--tel-radius);
  padding: 30px;
  text-align: center;
}

/* =====================================================
   MANAGE PORTAL
   ===================================================== */
.tel-portal-wrapper { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }
.tel-portal-header {
  background: var(--tel-blue);
  color: #fff;
  padding: 18px 25px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: var(--tel-radius) var(--tel-radius) 0 0;
}
.tel-portal-logo { display: flex; align-items: center; gap: 12px; }
.tel-logo-text { font-size: 18px; font-weight: 800; letter-spacing: 1px; }
.tel-portal-badge {
  background: var(--tel-orange);
  padding: 3px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
}
.tel-portal-nav {
  background: var(--tel-blue-dark);
  display: flex;
  gap: 0;
  overflow-x: auto;
}
.tel-portal-nav-item {
  padding: 13px 20px;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  transition: all 0.2s;
  border-bottom: 3px solid transparent;
}
.tel-portal-nav-item:hover,
.tel-portal-nav-item.tel-nav-active {
  color: #fff;
  border-bottom-color: var(--tel-orange);
  background: rgba(255,255,255,0.05);
}
.tel-portal-content {
  background: var(--tel-light);
  padding: 25px;
  border-radius: 0 0 var(--tel-radius) var(--tel-radius);
}
.tel-portal-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
  margin-bottom: 25px;
}
.tel-portal-stat {
  background: #fff;
  padding: 20px;
  border-radius: 8px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.tel-portal-stat-num  { font-size: 28px; font-weight: 800; color: var(--tel-blue); }
.tel-portal-stat-label{ font-size: 12px; color: var(--tel-gray); margin-top: 4px; }
.tel-portal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.tel-portal-card {
  background: #fff;
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.tel-portal-card h3 { font-size: 15px; color: var(--tel-blue); margin: 0 0 15px; }
.tel-portal-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.tel-portal-table th {
  background: var(--tel-light);
  padding: 8px 10px;
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  color: var(--tel-gray);
  font-weight: 600;
}
.tel-portal-table td { padding: 8px 10px; border-bottom: 1px solid #f0f0f0; }
.tel-portal-table-full { width: 100%; }
.tel-portal-empty { color: var(--tel-gray); font-style: italic; text-align: center; padding: 20px; }

/* Container board */
.tel-container-board { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 15px; }
.tel-container-card {
  background: #fff;
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  border-left: 4px solid var(--tel-border);
}
.tel-container-in_transit { border-left-color: var(--tel-orange); }
.tel-container-available  { border-left-color: var(--tel-green); }
.tel-container-at_port    { border-left-color: #6f42c1; }
.tel-container-delivered  { border-left-color: var(--tel-blue); }
.tel-container-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.tel-container-card-type  { font-size: 11px; background: var(--tel-light); padding: 2px 8px; border-radius: 3px; margin-bottom: 8px; }
.tel-container-card-route { font-size: 13px; color: var(--tel-gray); margin-bottom: 5px; }
.tel-container-card-eta   { font-size: 12px; color: var(--tel-orange); }
.tel-container-card-location { font-size: 12px; margin-top: 6px; }

/* Mode badge (frontend) */
.tel-mode-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
}
.tel-mode-sea  { background: var(--tel-blue); color: #fff; }
.tel-mode-air  { background: #6f42c1; color: #fff; }
.tel-mode-road { background: var(--tel-orange); color: #fff; }
.tel-mode-rail { background: var(--tel-green); color: #fff; }

/* Status badges (frontend) */
.tel-badge { display: inline-block; padding: 3px 9px; border-radius: 12px; font-size: 11px; font-weight: 600; }
.tel-badge-pending  { background: #fff3cd; color: #856404; }
.tel-badge-quoted   { background: #cfe2ff; color: #084298; }
.tel-badge-accepted { background: #d1e7dd; color: #0a3622; }
.tel-badge-rejected { background: #f8d7da; color: #58151c; }
.tel-badge-active   { background: #d1e7dd; color: #0a3622; }
.tel-badge-delivered{ background: #d1e7dd; color: #0a3622; }

/* Login required */
.tel-login-required, .tel-access-denied {
  background: var(--tel-light);
  border: 1px solid var(--tel-border);
  border-radius: var(--tel-radius);
  padding: 40px;
  text-align: center;
}

/* Responsive */
@media (max-width: 768px) {
  .tel-form-grid, .tel-dims-grid, .tel-mode-grid { grid-template-columns: 1fr 1fr; }
  .tel-checkbox-grid { grid-template-columns: 1fr; }
  .tel-service-grid  { grid-template-columns: 1fr 1fr; }
  .tel-portal-stats  { grid-template-columns: 1fr 1fr; }
  .tel-portal-grid   { grid-template-columns: 1fr; }
  .tel-review-grid   { grid-template-columns: 1fr; }
  .tel-track-input-group { flex-direction: column; }
}
@media (max-width: 480px) {
  .tel-form-grid, .tel-dims-grid { grid-template-columns: 1fr; }
  .tel-form-step { padding: 15px; }
  .tel-mode-grid { grid-template-columns: 1fr 1fr; }
  .tel-portal-stats { grid-template-columns: 1fr 1fr; }
}

/* ── Cargo category radio grid ──────────────────────────── */
.tel-cargo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 10px;
  margin: 10px 0 6px;
}
.tel-cargo-card {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  border: 2px solid #dde4ed;
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
  background: #fff;
  position: relative;
}
.tel-cargo-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.tel-cargo-card:has(input:checked),
.tel-cargo-card.selected {
  border-color: #f5821f;
  box-shadow: 0 0 0 3px rgba(245,130,31,.2);
}
.tel-cargo-content {
  padding: 12px 10px;
  text-align: center;
}
.tel-cargo-icon  { font-size: 26px; margin-bottom: 6px; }
.tel-cargo-name  { font-size: 13px; font-weight: 700; color: #1e3a5f; }
.tel-cargo-desc  { font-size: 11px; color: #888; margin-top: 3px; }

/* ── Services Needed checkbox grid ─────────────────────── */
.tel-services-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px 14px;
  padding: 14px 16px;
  background: #f7f9fc;
  border: 1px solid #dde4ed;
  border-radius: 6px;
  margin: 8px 0 4px;
}
.tel-service-check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13.5px;
  color: #333;
  line-height: 1.4;
  user-select: none;
  pointer-events: auto !important;
}
.tel-service-check-label input[type="checkbox"] {
  width: 17px;
  height: 17px;
  min-width: 17px;
  accent-color: #f5821f;
  cursor: pointer;
  pointer-events: auto !important;
  position: relative;
  z-index: 1;
}
/* Ensure checkboxes in the special-handling grid are also clickable */
.tel-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
  padding: 12px 0;
}
.tel-checkbox-label input[type="checkbox"] {
  width: 17px;
  height: 17px;
  min-width: 17px;
  accent-color: #f5821f;
  cursor: pointer;
  pointer-events: auto !important;
  position: relative;
  z-index: 1;
}

/* ── Math captcha block ─────────────────────────────────── */
.tel-captcha-block {
  background: #fff8f0;
  border: 1px solid rgba(245,130,31,.35);
  border-radius: 6px;
  padding: 16px 20px;
  margin: 20px 0 10px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.tel-captcha-label {
  font-size: 14px;
  color: #444;
  font-weight: 500;
  flex: 1 1 200px;
}
.tel-captcha-label strong { color: #f5821f; font-size: 16px; }
#tel_captcha_answer {
  border: 2px solid #f5821f88;
  border-radius: 4px;
  padding: 8px 12px;
  font-size: 16px;
  text-align: center;
  width: 100px;
}
#tel_captcha_answer:focus {
  border-color: #f5821f;
  box-shadow: 0 0 0 3px rgba(245,130,31,.2);
  outline: none;
}
#tel_captcha_answer.tel-error { border-color: #dc3545; }
.tel-captcha-hint { font-size: 11px; color: #888; }

/* ── Port suggestions dropdown ──────────────────────────── */
.tel-port-select-wrapper { position: relative; }
.tel-port-suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #dde4ed;
  border-radius: 0 0 6px 6px;
  box-shadow: 0 6px 20px rgba(0,0,0,.1);
  z-index: 9999;
  max-height: 260px;
  overflow-y: auto;
  display: none;
}
.tel-port-suggestion-item {
  padding: 9px 14px;
  cursor: pointer;
  border-bottom: 1px solid #f0f2f5;
  font-size: 13px;
}
.tel-port-suggestion-item:hover { background: #f7f9fc; }
.tel-port-suggestion-item strong { color: #1e3a5f; display: block; }
.tel-port-suggestion-item small  { color: #888; }
.tel-port-tag {
  font-size: 10px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 5px;
  vertical-align: middle;
}
.tel-port-tag-sea  { background: #e3f0ff; color: #1e3a5f; }
.tel-port-tag-air  { background: #fff0e3; color: #f5821f; }
.tel-port-tag-road { background: #e8f5e9; color: #2e7d32; }
.tel-port-tag-rail { background: #f3e5f5; color: #6a1b9a; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 600px) {
  .tel-cargo-grid { grid-template-columns: repeat(2, 1fr); }
  .tel-services-check-grid { grid-template-columns: 1fr; }
  .tel-captcha-block { flex-direction: column; align-items: flex-start; }
}


/* ═══════════════════════════════════════════════════════════════
   TheGem / combobox overrides — force visible inputs & cards
   ═══════════════════════════════════════════════════════════════ */

/* Port / city text inputs (origin & destination) */
#origin_port_input,
#dest_port_input,
.tel-port-select-wrapper input[type="text"],
.tel-port-select-wrapper input[type="search"] {
    color: #333333 !important;
    -webkit-text-fill-color: #333333 !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    border: 1.5px solid #dee2e6 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    line-height: 1.5 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    border-radius: 7px !important;
    box-shadow: none !important;
    outline: none !important;
    /* Undo combobox transform */
    -webkit-appearance: none !important;
    appearance: none !important;
}

#origin_port_input:focus,
#dest_port_input:focus,
.tel-port-select-wrapper input[type="text"]:focus {
    border-color: #1e3a5f !important;
    box-shadow: 0 0 0 3px rgba(30,58,95,0.12) !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    color: #333333 !important;
    -webkit-text-fill-color: #333333 !important;
}

#origin_port_input::placeholder,
#dest_port_input::placeholder,
.tel-port-select-wrapper input::placeholder {
    color: #999999 !important;
    -webkit-text-fill-color: #999999 !important;
    opacity: 1 !important;
}

/* Ensure the wrapper itself doesn't hide children */
.tel-port-select-wrapper {
    position: relative !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Cargo type radio cards */
.tel-cargo-grid {
    opacity: 1 !important;
    visibility: visible !important;
}

.tel-cargo-card {
    opacity: 1 !important;
    visibility: visible !important;
    display: flex !important;
    cursor: pointer !important;
    color: #1e3a5f !important;
}

.tel-cargo-card *,
.tel-cargo-content,
.tel-cargo-content * {
    opacity: 1 !important;
    visibility: visible !important;
    color: inherit !important;
    -webkit-text-fill-color: currentColor !important;
}

.tel-cargo-name {
    color: #1e3a5f !important;
    -webkit-text-fill-color: #1e3a5f !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    opacity: 1 !important;
}

.tel-cargo-desc {
    color: #6c757d !important;
    -webkit-text-fill-color: #6c757d !important;
    font-size: 11px !important;
    opacity: 1 !important;
}

.tel-cargo-icon {
    opacity: 1 !important;
    font-size: 22px !important;
    line-height: 1 !important;
}

/* Origin / destination selects (hidden real selects) */
.tel-field select,
.tel-field-full select {
    color: #333333 !important;
    -webkit-text-fill-color: #333333 !important;
    background: #ffffff !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Make sure .tel-field wrapper doesn't clip anything */
.tel-field,
.tel-field-full {
    position: relative !important;
    overflow: visible !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   Services / Special-handling checkboxes — JS-driven, TheGem-proof
   Native <input> is hidden-but-functional; visual done entirely by .tel-chk
   ═══════════════════════════════════════════════════════════════════════════ */

/* Hide the native input — keep it functional for form submit & label clicks */
.tel-service-check-label input[type="checkbox"],
.tel-checkbox-label       input[type="checkbox"] {
    position: absolute !important;
    opacity:  0        !important;
    width:    1px      !important;
    height:   1px      !important;
    margin:   0        !important;
    padding:  0        !important;
    border:   0        !important;
    overflow: hidden   !important;
    clip:     rect(0,0,0,0) !important;
    white-space: nowrap !important;
    pointer-events: none !important;   /* label handles clicks */
}

/* Custom visual checkbox box */
.tel-chk {
    display:      inline-flex    !important;
    align-items:  center         !important;
    justify-content: center      !important;
    width:        18px           !important;
    height:       18px           !important;
    min-width:    18px           !important;
    flex-shrink:  0              !important;
    border:       2px solid #c0cadb !important;
    border-radius: 4px           !important;
    background:   #ffffff        !important;
    transition:   background 0.15s, border-color 0.15s !important;
    pointer-events: none         !important;  /* clicks go to label */
    box-sizing:   border-box     !important;
}

/* Checked state — orange fill + white tick — toggled by JS */
.tel-chk.checked {
    background:   #f5821f !important;
    border-color: #f5821f !important;
}
.tel-chk.checked::after {
    content:      ''           !important;
    display:      block        !important;
    width:        5px          !important;
    height:       9px          !important;
    border:       2.5px solid #ffffff !important;
    border-top:   none         !important;
    border-left:  none         !important;
    transform:    rotate(45deg) translateY(-1px) !important;
    flex-shrink:  0            !important;
}

/* Label row */
.tel-service-check-label,
.tel-checkbox-label {
    display:        flex        !important;
    align-items:    center      !important;
    gap:            9px         !important;
    cursor:         pointer     !important;
    position:       relative    !important;
    pointer-events: auto        !important;
    user-select:    none        !important;
    opacity:        1           !important;
    visibility:     visible     !important;
}

/* Checked label highlight */
.tel-service-check-label.is-checked,
.tel-checkbox-label.is-checked {
    border-color: #f5821f !important;
    background:   #fff5ec !important;
}
.tel-service-check-label:hover,
.tel-checkbox-label:hover {
    border-color: #f5821f !important;
    background:   #fffaf5 !important;
}
.tel-service-check-label:hover .tel-chk,
.tel-checkbox-label:hover .tel-chk {
    border-color: #f5821f !important;
}


/* ── CF7 dark-form (gem-contact-form-dark) service checkboxes ───────────────── */
/* On the Routes page the services checkboxes are inside a dark CF7 form variant. */
/* These overrides ensure label text is readable and the .tel-chk is visible.    */
.gem-contact-form-dark .tel-cf-services-label,
.gem-contact-form-dark .tel-cf-services-label span {
    color: #e0e8f4 !important;
}
.gem-contact-form-dark .tel-cf-services-grid .wpcf7-list-item-label,
.gem-contact-form-dark .tel-cf-services-grid .tel-service-check-label {
    color: #e0e8f4 !important;
}

/* CF7 injects its own appearance on inputs; undo dark background for checkboxes */
.gem-contact-form-dark .tel-cf-services-grid input[type="checkbox"],
.wpcf7-form.gem-contact-form-dark .tel-cf-services-grid input[type="checkbox"] {
    background-color: transparent !important;
    border: none !important;
}

/* Make sure CF7-transformed labels look like cards on the dark form */
.gem-contact-form-dark .tel-cf-services-grid .tel-service-check-label {
    border-color: #3d5a80 !important;
    background: rgba(255,255,255,0.07) !important;
}
.gem-contact-form-dark .tel-cf-services-grid .tel-service-check-label.is-checked {
    background: rgba(245,130,31,0.25) !important;
    border-color: #f5821f !important;
}
.gem-contact-form-dark .tel-cf-services-grid .tel-service-check-label:hover {
    border-color: #f5821f !important;
    background: rgba(245,130,31,0.15) !important;
}

/* Ensure .tel-chk border is visible on dark backgrounds */
.gem-contact-form-dark .tel-cf-services-grid .tel-chk {
    border-color: #5a7ba8 !important;
    background: rgba(255,255,255,0.1) !important;
}
.gem-contact-form-dark .tel-cf-services-grid .tel-chk.checked {
    background: #f5821f !important;
    border-color: #f5821f !important;
}

