:root{
  --bg-900:#0f1013;
  --bg-850:#16171b;
  --bg-800:#1b1e23;
  --border:rgba(255,255,255,.08);
  --accent:#ffc107;
  --success:#22c55e;
  --info:#0dcaf0;
  --text-strong:#eef2f6;
  --text-subtle:#cfd6e4;
  --grid:#ffffff1f;

  /* Neon palette for charts / accents */
  --neon-blue:#00e7f3;
  --neon-pink:#ff3cac;
  --neon-green:#22c55e;
  --neon-red:#ff4d4d;
  --neon-orange:#ffb300;
  --neon-purple:#7367f0;
}

html,body{height:100%; max-width:100vw; overflow-x:hidden}
body{
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(255,193,7,.12), transparent 40%),
    radial-gradient(1000px 500px at 120% 20%, rgba(13,202,240,.10), transparent 40%),
    linear-gradient(180deg, #0c0d10 0%, #0f1013 100%);
  color:var(--text-strong);
  font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

/* Higher-contrast fields on the login card only */
.login-card .form-control-dark,
.login-card .form-select.form-control-dark{
  background: #0f1116;             /* darker field surface */
  border-color: #3b4253;           /* brighter border */
  color: var(--text-strong);
}
.login-card .form-control-dark::placeholder{
  color:#b8c2d0;
}
.login-card .form-control-dark:focus,
.login-card .form-select.form-control-dark:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 .2rem rgba(255,193,7,.35);
}

/* Input group that matches dark fields */
.input-group-dark .btn{
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left: 1px solid var(--border);
  height: 100%;
}
.input-group-dark .form-control{
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.app-shell, .container { overflow-x:hidden; }

.text-secondary, .text-muted, .text-subtle { color: var(--text-subtle)!important; }
.text-strong { color: var(--text-strong)!important; }

.navbar{background:#0b0c0e!important;border-bottom:1px solid var(--border)}
.glass-top{backdrop-filter:saturate(120%) blur(8px)}

.card{border:1px solid var(--border)}
.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  backdrop-filter: blur(10px) saturate(120%);
  border:1px solid var(--border);
  border-radius:16px;
}

.kpi{padding:1rem;border-radius:16px; text-align:center;}

.table-dark{
  --bs-table-bg:var(--bg-850);
  --bs-table-striped-bg:#181b21;
  --bs-table-striped-color:var(--text-strong);
  --bs-table-hover-bg:#1f232b;
}
.table-hover tbody tr:hover{transform: translateZ(0); transition: background .2s ease}
/* Strong edit highlight */
table.dataTable tbody tr.editing{
  background: linear-gradient(180deg, rgba(255,193,7,.16), rgba(255,193,7,.10)) !important;
  box-shadow: inset 4px 0 0 0 var(--accent);
}

.form-label{color:var(--text-strong)}
.form-control-dark,.form-select.form-control-dark{
  background:#1b1e23;border:1px solid var(--border);color:var(--text-strong);
  border-radius:12px;
}
.form-control-dark::placeholder{color:#aab4c3}
.form-control-dark:focus,.form-select.form-control-dark:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 .15rem rgb(255 193 7 / 25%)
}

.badge-chip{font-weight:600}
.badge-status-unacted{background:var(--neon-pink)}
.badge-status-inprog{background:var(--neon-blue)}
.badge-status-resolved{background:var(--neon-green)}
.badge-sev-high{background:var(--neon-red)}
.badge-sev-medium{background:var(--neon-orange); color:#111}
.badge-sev-low{background:#20c997}
.badge-sev-critical{
  background: linear-gradient(90deg, rgba(255,0,0,.28), rgba(0,0,0,.88));
  color:#fff;
  border:1px solid #ff0000;
  box-shadow:0 0 8px rgba(255,0,0,.35);
}

.btn-ghost{
  background:transparent;border:1px solid var(--border);color:var(--text-strong);border-radius:10px;
}
.btn-ghost:hover{background:#242833}
.btn-gradient{
  border:0;border-radius:12px;color:#0b0c0e;font-weight:600;
  background: linear-gradient(135deg, #ffd85a, #ffb300 70%);
  box-shadow: 0 6px 18px rgba(255,193,7,.25);
  transition: transform .08s ease, box-shadow .2s ease;
}
.btn-gradient:active{transform: translateY(1px); box-shadow: 0 2px 8px rgba(255,193,7,.2)}

.hover-rise{transition: transform .2s ease, box-shadow .2s ease}
.hover-rise:hover{transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.28)}

.row-refresh{animation: flash .7s ease}
@keyframes flash{0%{background:#263045}100%{background:transparent}}

#lastUpdated { opacity:.95 }

.login-hero{
  background:
    radial-gradient(800px 400px at 0% 0%, rgba(255,193,7,.12), transparent 50%),
    radial-gradient(900px 500px at 100% 100%, rgba(13,202,240,.10), transparent 50%);
}
.login-card{max-width:420px;width:100%}
.logo-badge{
  width:60px;height:60px;border-radius:16px;
  display:inline-flex;align-items:center;justify-content:center;
  background: linear-gradient(135deg, #ffd85a, #ffb300);
  color:#1a1b1f;font-size:1.6rem; box-shadow: 0 8px 24px rgba(255,193,7,.25);
}

.divider{border-color:var(--border)}

/* Required asterisk */
.form-label .req{ color:var(--neon-pink); margin-left:.25rem; font-weight:700; }

/* Loading state for buttons */
.btn[disabled], .btn:disabled{ opacity:.7; cursor:not-allowed; }
.btn .spinner-border{ width:1rem; height:1rem; border-width:.15rem; margin-right:.5rem; }

.loading-overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.2));
  backdrop-filter: blur(4px);
  z-index: 2; border-radius:12px;
}
.loading-overlay .spinner-grow{width:2.4rem;height:2.4rem;color:#ffc107;margin-bottom:12px}
.shimmer-line{
  width:90%; height:12px; margin:6px 0; border-radius:6px;
  background: linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.15), rgba(255,255,255,.06));
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite linear;
}
@keyframes shimmer{0%{background-position: 200% 0}100%{background-position: -200% 0}}

.chart-card{
  height: 260px;
  padding: 16px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}

/* Details pane: left-stacked, compact */
.details-pane{
  max-width: 900px;     /* stays left, doesn’t spread full table width */
  padding-right: 1rem;
}

.details-pane .small.text-subtle{
  color: var(--text-subtle);
}

/* Keep details images modest and non-stretchy */
.details-photo-wrap { max-width: 100%; }
.details-photo{
  display:block;
  max-width:100%;
  max-height:260px;     /* lower size in details */
  height:auto;
  object-fit:contain;
  border-radius:10px;
  border:1px solid var(--border);
  cursor:zoom-in;
  box-shadow:0 0 0 1px rgba(255,255,255,0.03) inset;
}

/* Modal: fit to screen without stretching */
#imgModalImg{
  max-width:100%;
  max-height:85vh;
  width:auto;
  height:auto;
  object-fit:contain;
}

/* Prevent child rows from weird spacing */
table.dataTable tbody tr.shown + tr > td .details-pane{
  margin-top: .25rem;
}

.img-modal-wrap{
  width: 100%;
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
}
#imgModalImg{
  width: 100%;
  height: auto;
}

/* Floating Action Button: keep inside safe area on mobile */
.fab{
  position: fixed;
  right:  calc(16px + env(safe-area-inset-right));
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 1050;
  width: 56px; height: 56px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  transform: translateZ(0);
}
.fab i{font-size: 1.2rem}
@media (max-width:420px){
  .fab{ width:52px; height:52px; border-radius:12px; }
}

/* Text utilities for neon colors */
.neon-blue   { color: var(--neon-blue)  !important; }
.neon-green  { color: var(--neon-green) !important; }
.neon-pink   { color: var(--neon-pink)  !important; }
.neon-orange { color: var(--neon-orange)!important; }
.neon-red    { color: var(--neon-red)   !important; }
.neon-purple { color: var(--neon-purple)!important; }

/* Entry Type chips */
.badge-et-complaint { background: var(--neon-pink); }
.badge-et-report    { background: var(--neon-blue); }
.badge-et-request   { background: var(--neon-green); }

/* Entry Type tiles (gate) */
.entry-type-tiles{
  display:flex; flex-wrap:wrap; gap:.75rem;
}
.entry-type-tiles .tile{
  appearance:none; border:1px solid var(--border); background:#1b1e23; color:var(--text-strong);
  padding:.6rem .9rem; border-radius:12px; font-weight:600; display:inline-flex; align-items:center;
  transition: transform .06s ease, box-shadow .15s ease, border-color .15s ease;
}
.entry-type-tiles .tile:hover{ transform: translateY(-1px); box-shadow: 0 8px 20px rgba(0,0,0,.25); }
.entry-type-tiles .tile-complaint:hover{ border-color: var(--neon-pink); }
.entry-type-tiles .tile-report:hover   { border-color: var(--neon-blue); }
.entry-type-tiles .tile-request:hover  { border-color: var(--neon-green); }
.entry-type-tiles .tile.active{
  outline: 2px solid var(--accent);
  box-shadow: 0 0 0 3px rgba(255,193,7,.25);
}

/* Dark disabled fields: keep them subdued, not white */
.form-control-dark:disabled,
.form-select.form-control-dark:disabled,
.form-control-dark[disabled],
.form-select.form-control-dark[disabled]{
  background:#121419 !important;
  color:#8e98a9 !important;
  border-color:#2a2f3b !important;
  opacity:1;                 /* keep readable */
  cursor:not-allowed;
}

/* Move lock mask to fields wrapper only (not the tiles) */
#formFields.is-locked{
  position:relative;
}
#formFields.is-locked::after{
  content:"Select an Entry Type to continue";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.35));
  color:var(--text-subtle); font-weight:600;
  border-radius: 0.5rem;
  pointer-events:none;
}

/* --- Professional palette for Entry Type tiles --- */
:root{
  --et-complaint:#d84c4c;    /* refined danger */
  --et-complaint-ink:#2a1416;

  --et-report:#2aa6ff;       /* refined info */
  --et-report-ink:#0f1a26;

  --et-request:#22c55e;      /* refined success */
  --et-request-ink:#0f1a12;

  --tile-surface:#1b1e23;
  --tile-border:#2a2f3b;
  --tile-hover:#222630;
  --tile-focus: rgba(255,193,7,.35); /* accent glow */
}

/* Gate spacing: bring fields up a bit */
#formGate { margin-bottom: .5rem; }
#formGate .divider { margin: .6rem 0 .2rem 0; opacity: .5; }

/* Tile row spacing and wrap behavior */
.entry-type-tiles { gap: .5rem .6rem; margin-top: .25rem; }

.entry-type-tiles .tile{
  appearance:none;
  border:1px solid var(--tile-border);
  background:var(--tile-surface);
  color:var(--text-strong);
  padding:.5rem .8rem;
  border-radius:12px;
  font-weight:600;
  display:inline-flex; align-items:center;
  transition: transform .06s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.entry-type-tiles .tile:hover{ transform: translateY(-1px); background:var(--tile-hover); }
.entry-type-tiles .tile:focus-visible{
  outline:2px solid var(--accent);
  box-shadow: 0 0 0 3px var(--tile-focus);
}

/* Color coding per type (border/ink/hover accents) */
.entry-type-tiles .tile-complaint{ border-color: color-mix(in srgb, var(--et-complaint) 45%, var(--tile-border)); }
.entry-type-tiles .tile-complaint:hover{ border-color: var(--et-complaint); }
.entry-type-tiles .tile-complaint i{ color: var(--et-complaint); }

.entry-type-tiles .tile-report{ border-color: color-mix(in srgb, var(--et-report) 45%, var(--tile-border)); }
.entry-type-tiles .tile-report:hover{ border-color: var(--et-report); }
.entry-type-tiles .tile-report i{ color: var(--et-report); }

.entry-type-tiles .tile-request{ border-color: color-mix(in srgb, var(--et-request) 45%, var(--tile-border)); }
.entry-type-tiles .tile-request:hover{ border-color: var(--et-request); }
.entry-type-tiles .tile-request i{ color: var(--et-request); }

/* Active state = subtle tinted surface + clear outline */
.entry-type-tiles .tile.active.tile-complaint{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-complaint) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-complaint);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-complaint) 25%, transparent);
}
.entry-type-tiles .tile.active.tile-report{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-report) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-report);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-report) 25%, transparent);
}
.entry-type-tiles .tile.active.tile-request{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-request) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-request);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-request) 25%, transparent);
}

/* Lock form until Entry Type is chosen */
#modalForm.form-locked{
  position:relative;
}
#modalForm.form-locked::after{
  content:"Select Entry Type to continue";
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.35));
  color:var(--text-subtle); font-weight:600;
  border-radius: 0.5rem;
  pointer-events: none;
}


h1,h2,h3,h4,h5,h6,.form-label,.navbar-brand,.card h5 { color: var(--text-strong) !important; }

canvas { image-rendering: -webkit-optimize-contrast; }

/* Details-control cell */
td.details-control { vertical-align: middle; white-space: nowrap }
td.details-control .btn { padding:.15rem .4rem; line-height:1 }
tr.shown td.details-control .btn { background:#242833 }

:root{
  --bg-900:#0f1013;
  --bg-850:#16171b;
  --bg-800:#1b1e23;
  --border:rgba(255,255,255,.08);
  --accent:#ffc107;
  --success:#22c55e;
  --info:#0dcaf0;
  --text-strong:#eef2f6;
  --text-subtle:#cfd6e4;
  --grid:#ffffff1f;

  /* Neon palette for charts / accents */
  --neon-blue:#00e7f3;
  --neon-pink:#ff3cac;
  --neon-green:#22c55e;
  --neon-red:#ff4d4d;
  --neon-orange:#ffb300;
  --neon-purple:#7367f0;
}

html,body{height:100%; max-width:100vw; overflow-x:hidden}
body{
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(255,193,7,.12), transparent 40%),
    radial-gradient(1000px 500px at 120% 20%, rgba(13,202,240,.10), transparent 40%),
    linear-gradient(180deg, #0c0d10 0%, #0f1013 100%);
  color:var(--text-strong);
  font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

/* Higher-contrast fields on the login card only */
.login-card .form-control-dark,
.login-card .form-select.form-control-dark{
  background: #0f1116;             /* darker field surface */
  border-color: #3b4253;           /* brighter border */
  color: var(--text-strong);
}
.login-card .form-control-dark::placeholder{
  color:#b8c2d0;
}
.login-card .form-control-dark:focus,
.login-card .form-select.form-control-dark:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 .2rem rgba(255,193,7,.35);
}

/* Input group that matches dark fields */
.input-group-dark .btn{
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left: 1px solid var(--border);
  height: 100%;
}
.input-group-dark .form-control{
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.app-shell, .container { overflow-x:hidden; }

.text-secondary, .text-muted, .text-subtle { color: var(--text-subtle)!important; }
.text-strong { color: var(--text-strong)!important; }

.navbar{background:#0b0c0e!important;border-bottom:1px solid var(--border)}
.glass-top{backdrop-filter:saturate(120%) blur(8px)}

.card{border:1px solid var(--border)}
.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  backdrop-filter: blur(10px) saturate(120%);
  border:1px solid var(--border);
  border-radius:16px;
}

.kpi{padding:1rem;border-radius:16px; text-align:center;}

.table-dark{
  --bs-table-bg:var(--bg-850);
  --bs-table-striped-bg:#181b21;
  --bs-table-striped-color:var(--text-strong);
  --bs-table-hover-bg:#1f232b;
}
.table-hover tbody tr:hover{transform: translateZ(0); transition: background .2s ease}

.form-label{color:var(--text-strong)}
.form-control-dark,.form-select.form-control-dark{
  background:#1b1e23;border:1px solid var(--border);color:var(--text-strong);
  border-radius:12px;
}
.form-control-dark::placeholder{color:#aab4c3}
.form-control-dark:focus,.form-select.form-control-dark:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 .15rem rgb(255 193 7 / 25%)
}

.badge-chip{font-weight:600}
.badge-status-unacted{background:var(--neon-pink)}
.badge-status-inprog{background:var(--neon-blue)}
.badge-status-resolved{background:var(--neon-green)}
.badge-sev-high{background:var(--neon-red)}
.badge-sev-medium{background:var(--neon-orange); color:#111}
.badge-sev-low{background:#20c997}
.badge-sev-critical{
  background: linear-gradient(90deg, rgba(255,0,0,.28), rgba(0,0,0,.88));
  color:#fff;
  border:1px solid #ff0000;
  box-shadow:0 0 8px rgba(255,0,0,.35);
}

.btn-ghost{
  background:transparent;border:1px solid var(--border);color:var(--text-strong);border-radius:10px;
}
.btn-ghost:hover{background:#242833}
.btn-gradient{
  border:0;border-radius:12px;color:#0b0c0e;font-weight:600;
  background: linear-gradient(135deg, #ffd85a, #ffb300 70%);
  box-shadow: 0 6px 18px rgba(255,193,7,.25);
  transition: transform .08s ease, box-shadow .2s ease;
}
.btn-gradient:active{transform: translateY(1px); box-shadow: 0 2px 8px rgba(255,193,7,.2)}

.hover-rise{transition: transform .2s ease, box-shadow .2s ease}
.hover-rise:hover{transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.28)}

.row-refresh{animation: flash .7s ease}
@keyframes flash{0%{background:#263045}100%{background:transparent}}

#lastUpdated { opacity:.95 }

.login-hero{
  background:
    radial-gradient(800px 400px at 0% 0%, rgba(255,193,7,.12), transparent 50%),
    radial-gradient(900px 500px at 100% 100%, rgba(13,202,240,.10), transparent 50%);
}
.login-card{max-width:420px;width:100%}
.logo-badge{
  width:60px;height:60px;border-radius:16px;
  display:inline-flex;align-items:center;justify-content:center;
  background: linear-gradient(135deg, #ffd85a, #ffb300);
  color:#1a1b1f;font-size:1.6rem; box-shadow: 0 8px 24px rgba(255,193,7,.25);
}

.divider{border-color:var(--border)}

/* Required asterisk */
.form-label .req{ color:var(--neon-pink); margin-left:.25rem; font-weight:700; }

/* Loading state for buttons */
.btn[disabled], .btn:disabled{ opacity:.7; cursor:not-allowed; }
.btn .spinner-border{ width:1rem; height:1rem; border-width:.15rem; margin-right:.5rem; }

.loading-overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.2));
  backdrop-filter: blur(4px);
  z-index: 2; border-radius:12px;
}
.loading-overlay .spinner-grow{width:2.4rem;height:2.4rem;color:#ffc107;margin-bottom:12px}
.shimmer-line{
  width:90%; height:12px; margin:6px 0; border-radius:6px;
  background: linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.15), rgba(255,255,255,.06));
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite linear;
}
@keyframes shimmer{0%{background-position: 200% 0}100%{background-position: -200% 0}}

.chart-card{
  height: 260px;
  padding: 16px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}

/* Details pane: left-stacked, compact */
.details-pane{
  max-width: 900px;     /* stays left, doesn’t spread full table width */
  padding-right: 1rem;
}

.details-pane .small.text-subtle{
  color: var(--text-subtle);
}

/* Keep details images modest and non-stretchy */
.details-photo-wrap { max-width: 100%; }
.details-photo{
  display:block;
  max-width:100%;
  max-height:260px;     /* lower size in details */
  height:auto;
  object-fit:contain;
  border-radius:10px;
  border:1px solid var(--border);
  cursor:zoom-in;
  box-shadow:0 0 0 1px rgba(255,255,255,0.03) inset;
}

/* Modal: fit to screen without stretching */
#imgModalImg{
  max-width:100%;
  max-height:85vh;
  width:auto;
  height:auto;
  object-fit:contain;
}

/* Prevent child rows from weird spacing */
table.dataTable tbody tr.shown + tr > td .details-pane{
  margin-top: .25rem;
}

.img-modal-wrap{
  width: 100%;
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
}
#imgModalImg{
  width: 100%;
  height: auto;
}

/* Floating Action Button: keep inside safe area on mobile */
.fab{
  position: fixed;
  right:  calc(16px + env(safe-area-inset-right));
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 1050;
  width: 56px; height: 56px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  transform: translateZ(0);
}
.fab i{font-size: 1.2rem}
@media (max-width:420px){
  .fab{ width:52px; height:52px; border-radius:12px; }
}

/* Text utilities for neon colors */
.neon-blue   { color: var(--neon-blue)  !important; }
.neon-green  { color: var(--neon-green) !important; }
.neon-pink   { color: var(--neon-pink)  !important; }
.neon-orange { color: var(--neon-orange)!important; }
.neon-red    { color: var(--neon-red)   !important; }
.neon-purple { color: var(--neon-purple)!important; }

/* Entry Type chips */
.badge-et-complaint { background: var(--neon-pink); }
.badge-et-report    { background: var(--neon-blue); }
.badge-et-request   { background: var(--neon-green); }

/* Entry Type tiles (gate) */
.entry-type-tiles{
  display:flex; flex-wrap:wrap; gap:.75rem;
}
.entry-type-tiles .tile{
  appearance:none; border:1px solid var(--border); background:#1b1e23; color:var(--text-strong);
  padding:.6rem .9rem; border-radius:12px; font-weight:600; display:inline-flex; align-items:center;
  transition: transform .06s ease, box-shadow .15s ease, border-color .15s ease;
}
.entry-type-tiles .tile:hover{ transform: translateY(-1px); box-shadow: 0 8px 20px rgba(0,0,0,.25); }
.entry-type-tiles .tile-complaint:hover{ border-color: var(--neon-pink); }
.entry-type-tiles .tile-report:hover   { border-color: var(--neon-blue); }
.entry-type-tiles .tile-request:hover  { border-color: var(--neon-green); }
.entry-type-tiles .tile.active{
  outline: 2px solid var(--accent);
  box-shadow: 0 0 0 3px rgba(255,193,7,.25);
}

/* Dark disabled fields: keep them subdued, not white */
.form-control-dark:disabled,
.form-select.form-control-dark:disabled,
.form-control-dark[disabled],
.form-select.form-control-dark[disabled]{
  background:#121419 !important;
  color:#8e98a9 !important;
  border-color:#2a2f3b !important;
  opacity:1;                 /* keep readable */
  cursor:not-allowed;
}

/* Move lock mask to fields wrapper only (not the tiles) */
#formFields.is-locked{
  position:relative;
}
#formFields.is-locked::after{
  content:"Select an Entry Type to continue";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.35));
  color:var(--text-subtle); font-weight:600;
  border-radius: 0.5rem;
  pointer-events:none;
}

/* --- Professional palette for Entry Type tiles --- */
:root{
  --et-complaint:#d84c4c;    /* refined danger */
  --et-complaint-ink:#2a1416;

  --et-report:#2aa6ff;       /* refined info */
  --et-report-ink:#0f1a26;

  --et-request:#22c55e;      /* refined success */
  --et-request-ink:#0f1a12;

  --tile-surface:#1b1e23;
  --tile-border:#2a2f3b;
  --tile-hover:#222630;
  --tile-focus: rgba(255,193,7,.35); /* accent glow */
}

/* Gate spacing: bring fields up a bit */
#formGate { margin-bottom: .5rem; }
#formGate .divider { margin: .6rem 0 .2rem 0; opacity: .5; }

/* Tile row spacing and wrap behavior */
.entry-type-tiles { gap: .5rem .6rem; margin-top: .25rem; }

.entry-type-tiles .tile{
  appearance:none;
  border:1px solid var(--tile-border);
  background:var(--tile-surface);
  color:var(--text-strong);
  padding:.5rem .8rem;
  border-radius:12px;
  font-weight:600;
  display:inline-flex; align-items:center;
  transition: transform .06s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.entry-type-tiles .tile:hover{ transform: translateY(-1px); background:var(--tile-hover); }
.entry-type-tiles .tile:focus-visible{
  outline:2px solid var(--accent);
  box-shadow: 0 0 0 3px var(--tile-focus);
}

/* Color coding per type (border/ink/hover accents) */
.entry-type-tiles .tile-complaint{ border-color: color-mix(in srgb, var(--et-complaint) 45%, var(--tile-border)); }
.entry-type-tiles .tile-complaint:hover{ border-color: var(--et-complaint); }
.entry-type-tiles .tile-complaint i{ color: var(--et-complaint); }

.entry-type-tiles .tile-report{ border-color: color-mix(in srgb, var(--et-report) 45%, var(--tile-border)); }
.entry-type-tiles .tile-report:hover{ border-color: var(--et-report); }
.entry-type-tiles .tile-report i{ color: var(--et-report); }

.entry-type-tiles .tile-request{ border-color: color-mix(in srgb, var(--et-request) 45%, var(--tile-border)); }
.entry-type-tiles .tile-request:hover{ border-color: var(--et-request); }
.entry-type-tiles .tile-request i{ color: var(--et-request); }

/* Active state = subtle tinted surface + clear outline */
.entry-type-tiles .tile.active.tile-complaint{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-complaint) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-complaint);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-complaint) 25%, transparent);
}
.entry-type-tiles .tile.active.tile-report{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-report) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-report);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-report) 25%, transparent);
}
.entry-type-tiles .tile.active.tile-request{
  background: linear-gradient(180deg, color-mix(in srgb, var(--et-request) 16%, var(--tile-surface)), var(--tile-surface));
  outline:2px solid var(--et-request);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--et-request) 25%, transparent);
}

/* Lock form until Entry Type is chosen */
#modalForm.form-locked{
  position:relative;
}
#modalForm.form-locked::after{
  content:"Select Entry Type to continue";
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.35));
  color:var(--text-subtle); font-weight:600;
  border-radius: 0.5rem;
  pointer-events: none;
}


h1,h2,h3,h4,h5,h6,.form-label,.navbar-brand,.card h5 { color: var(--text-strong) !important; }

canvas { image-rendering: -webkit-optimize-contrast; }

/* Details-control cell */
td.details-control { vertical-align: middle; white-space: nowrap }
td.details-control .btn { padding:.15rem .4rem; line-height:1 }
tr.shown td.details-control .btn { background:#242833 }

/* Force all action buttons in Admin Users modal to same width */
#adminUsersTbody .btn {
  min-width: 90px;   /* adjust as needed */
  text-align: center;
}

/* (Sticky columns intentionally removed per request) */

/* Polite refresh banner tweaks: compact, dark-friendly, sticky inside card */
#refreshBanner{
  border-radius: 12px;
  border-color: var(--tile-border);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  color: var(--text-strong);
}
#refreshBanner .btn{ margin-left:.25rem }
#applyRefresh.btn{ padding:.25rem .6rem }
#dismissRefresh.btn{
  border-color: var(--border);
  color: var(--text-subtle);
}
#dismissRefresh.btn:hover{ color: var(--text-strong); background:#242833; }

/* Version badge */
.version-badge{
  background: #2a2f3b !important;
  color: var(--text-subtle) !important;
  border: 1px solid var(--border);
}

/* Map container in New Entry modal */
.loc-map{
  height: 260px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#0f1116;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.45);
  transition:box-shadow .2s ease, transform .2s ease;
}
.loc-map:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 32px rgba(0,0,0,.55);
}
.loc-map-fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  height: 260px;
  border:1px dashed var(--border);
  border-radius:12px;
  padding:1.5rem;
}
.location-block .btn.disabled{
  pointer-events:none;
  opacity:.6;
}

.row-critical{
  background: linear-gradient(90deg, rgba(255,0,0,.18), rgba(255,0,0,.05)) !important;
  box-shadow: inset 4px 0 0 rgba(255,0,0,.7);
}

/* (Sync Status panel removed) */

/* Focus mode switch: dark-friendly */
#toggleFocusMode.form-check-input{
  background-color:#1b1e23; border-color:#2a2f3b;
}
#toggleFocusMode.form-check-input:focus{ box-shadow: 0 0 0 .15rem rgb(255 193 7 / 20%); border-color: var(--accent); }
#toggleFocusMode.form-check-input:checked{ background-color: var(--accent); border-color: var(--accent); }
.form-check-label.small.text-subtle{ color: var(--text-subtle)!important; }

/* Editing HUD: top-right under navbar; non-blocking */
.editing-hud{
  position: fixed;
  top: calc(64px + env(safe-area-inset-top));
  right: calc(12px + env(safe-area-inset-right));
  z-index: 1080;
  pointer-events: none; /* don't block editing underneath */
}
.editing-hud .hud-inner{
  display:flex; align-items:center; gap:.5rem;
  padding:.35rem .55rem; border-radius:14px; border:1px solid var(--border);
  background:#15171c; color: var(--text-strong);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
  pointer-events: auto; /* make buttons clickable */
  font-size: .9rem;
  white-space: nowrap;
}
@media (max-width:420px){
  .editing-hud{ top: calc(56px + env(safe-area-inset-top)); right: calc(8px + env(safe-area-inset-right)); }
  .editing-hud .hud-inner{ padding:.3rem .5rem; font-size:.85rem; }
}
