:root{
  --nf-navy:#0E0940;
  --nf-gold:#9B8A32;
  --bg:#070A12;
  --card:#0F1A2E;
  --card2:#0B1220;
  --text:#EAF0FF;
  --muted:rgba(234,240,255,.72);
  --line:rgba(255,255,255,.12);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius:16px;
  --radius2:22px;
  --pad:14px;
  --max:1120px;
  --ok:#31d08b;
  --warn:#f4c542;
  --bad:#ff5c6b;
  --blue:#4aa3ff;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 600px at 20% 0%, rgba(155,138,50,.12), transparent 50%),
              radial-gradient(900px 500px at 90% 10%, rgba(74,163,255,.10), transparent 45%),
              var(--bg);
  color:var(--text);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:var(--max); margin:0 auto; padding:18px 14px 32px;}

.topbar{
  position:sticky; top:0; z-index:50;
  display:flex; gap:12px; align-items:center;
  padding:10px 12px;
  background: linear-gradient(180deg, rgba(14,9,64,.92), rgba(7,10,18,.88));
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(10px);
}

.brand{display:flex; align-items:center; gap:10px; padding:4px 8px; border-radius:12px;}
.brand img{height:36px; width:auto;}

.topbar__search{
  flex:1;
  display:flex; gap:8px; align-items:center;
  max-width:520px;
}
.topbar__search input{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(11,18,32,.75);
  color:var(--text);
  outline:none;
}
.topbar__search input::placeholder{color:rgba(234,240,255,.45)}
.topbar__right{margin-left:auto; display:flex; align-items:center; gap:10px;}

.footer{
  border-top:1px solid var(--line);
  padding:14px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:12px;
  background: rgba(11,18,32,.55);
}

.card{
  background: linear-gradient(180deg, rgba(15,26,46,.96), rgba(11,18,32,.92));
  border:1px solid var(--line);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
}

.card__hd{padding:14px 14px 10px; border-bottom:1px solid var(--line); display:flex; gap:10px; align-items:center; justify-content:space-between;}
.card__bd{padding:14px;}
.card__ft{padding:12px 14px; border-top:1px solid var(--line);}

.h1{font-size:20px; margin:0}
.h2{font-size:16px; margin:0}
.muted{color:var(--muted)}

.grid{display:grid; gap:12px;}
.grid--2{grid-template-columns: 1fr;}
.grid--3{grid-template-columns: 1fr;}

.grid--stack{grid-template-columns: 1fr !important;}
.kv--grid{display:grid; gap:10px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));}
.kv--grid .kv__item{width:auto;}
@media (min-width: 960px){
  .grid--2{grid-template-columns: 1fr 1fr;}
  .grid--3{grid-template-columns: 1.25fr .9fr .9fr;}
}

.btn{
  border:1px solid var(--line);
  background: rgba(11,18,32,.8);
  color:var(--text);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  transition: transform .05s ease, opacity .15s ease;
}
.btn:active{transform: translateY(1px)}
.btn--gold{
  background: linear-gradient(180deg, rgba(155,138,50,.95), rgba(114,101,35,.95));
  border-color: rgba(155,138,50,.35);
  color: #0b0f1c;
  font-weight: 700;
}
.btn--ghost{
  background: transparent;
}
.btn--small{padding:8px 10px; border-radius:12px; font-size:13px;}
.btn--danger{border-color: rgba(255,92,107,.35); color:#ffd7db}

.pills{display:flex; flex-wrap:wrap; gap:8px}
.pill{padding:8px 10px; border-radius:999px; border:1px solid var(--line); background:rgba(11,18,32,.65); font-size:13px;}
.pill--active{border-color: rgba(155,138,50,.55); font-size:16px; background: rgba(155,138,50,.18);}

.flash{
  max-width:var(--max);
  margin:12px auto 0;
  padding:10px 14px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(11,18,32,.75);
}
.flash--ok{border-color: rgba(49,208,139,.35)}
.flash--bad{border-color: rgba(255,92,107,.35)}
.flash--warn{border-color: rgba(244,197,66,.35)}

.table{width:100%; border-collapse:collapse; overflow:hidden; border-radius:14px; border:1px solid var(--line);}
.table th,.table td{padding:10px 10px; border-bottom:1px solid var(--line); vertical-align:top; font-size:13px;}
.table th{color:rgba(234,240,255,.75); font-weight:600; background:rgba(11,18,32,.6); text-align:left;}
.table tr:last-child td{border-bottom:none;}
.table input[type="text"], .table input[type="number"], .table input[type="date"], .table select{
  width:100%;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(7,10,18,.35);
  color:var(--text);
}

.input, select, textarea{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(11,18,32,.65);
  color:var(--text);
  outline:none;
}
textarea{min-height:90px; resize:vertical}

.label{font-size:12px; color:rgba(234,240,255,.72); margin:0 0 6px}
.field{display:flex; flex-direction:column; gap:6px}
.form{display:grid; gap:12px}
.form--2{grid-template-columns: 1fr;}
@media(min-width:960px){.form--2{grid-template-columns:1fr 1fr;}}

.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(11,18,32,.6);
  font-size:12px;
}
.badge--green{border-color: rgba(49,208,139,.35); background: rgba(49,208,139,.12)}
.badge--red{border-color: rgba(255,92,107,.35); background: rgba(255,92,107,.12)}
.badge--gold{border-color: rgba(244,197,66,.35); background: rgba(244,197,66,.12)}
.badge--blue{border-color: rgba(74,163,255,.35); background: rgba(74,163,255,.12)}
.badge--muted{opacity:.7}

.userchip{position:relative}
.userchip__btn{
  display:flex; align-items:center; gap:10px;
  padding:8px 10px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(11,18,32,.65);
  cursor:pointer;
}
.userchip__name{font-weight:650; font-size:13px}
.userchip__role{font-size:11px; color:rgba(234,240,255,.6)}
.chev{opacity:.7}

.menu{
  position:absolute; right:0; top:calc(100% + 10px);
  min-width:200px;
  border-radius: 16px;
  border:1px solid var(--line);
  background:rgba(15,26,46,.98);
  box-shadow: var(--shadow);
  padding:8px;
  display:none;
}
.menu__item{display:block; padding:10px 10px; border-radius:12px; font-size:13px;}
.menu__item:hover{background:rgba(155,138,50,.14)}
.menu__sep{height:1px; background: var(--line); margin:6px 0}

[data-menu].is-open .menu{display:block}

.calendar{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap:8px;
}
.cal__dow{
  font-size:11px;
  color:rgba(234,240,255,.65);
  padding:0 4px 6px;
}
.day{
  min-height:96px;
  border-radius:18px;
  border:1px solid var(--line);
  background: rgba(11,18,32,.52);
  padding:10px;
  position:relative;
  overflow:hidden;
}
.day--muted{opacity:.55}
.day__num{font-size:12px; color:rgba(234,240,255,.7); margin-bottom:8px}
.event{
  display:block;
  border-radius: 12px;
  padding:7px 8px;
  margin-bottom:6px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(155,138,50,.14);
  font-size:12px;
  line-height:1.2;
}
.event__title{font-weight:650}
.event__sub{color:rgba(234,240,255,.72); font-size:11px; margin-top:2px}
.event--blue{background: rgba(74,163,255,.14); border-color: rgba(74,163,255,.22)}
.event--green{background: rgba(49,208,139,.12); border-color: rgba(49,208,139,.22)}
.event--red{background: rgba(255,92,107,.10); border-color: rgba(255,92,107,.22)}

.split{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between;
}
.kv{display:flex; gap:10px; flex-wrap:wrap}
.kv__item{padding:8px 10px; border-radius:14px; border:1px solid var(--line); background:rgba(11,18,32,.55); font-size:13px}
.kv__k{color:rgba(234,240,255,.62); font-size:11px; display:block}
.kv__v{font-weight:650}

.section{margin-top:12px}
.section__title{display:flex; justify-content:space-between; align-items:center; gap:10px; margin:0 0 10px}
hr.sep{border:none; border-top:1px solid var(--line); margin:12px 0}

@media print{
  body{background:#fff;color:#000}
  .topbar,.footer,.btn,.menu,.flash{display:none !important}
  .card{box-shadow:none; border-color:#ddd}
  .table th,.table td{border-color:#ddd}
}


/* --- Job card layout refinements --- */
#visits .visit-form{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:10px;
  align-items:end;
}
#visits .visit-form .field:last-of-type{grid-column:1/-1;}
@media (max-width: 900px){
  #visits .visit-form{grid-template-columns: 1fr;}
}

/* Procurement notes expandable row */
.notes-row.is-hidden{display:none;}
.notes-row__inner{display:grid; gap:8px;}
.notes-row__meta{display:flex; justify-content:space-between; gap:10px; align-items:center;}
.btn--icon{padding:8px 10px; border-radius:12px; line-height:1; font-size:14px;}

/* =========================================================
   FORMS CONTRAST + ACCESSIBILITY (Theme-safe)
   - Ensures dropdowns/options keep readable contrast
   - Normalises inputs across all colour schemes
========================================================= */

:root {
  /* Fallbacks (in case a theme forgets to define them) */
  --bg: #0b0f14;
  --panel: #121824;
  --panel-2: #0f1520;
  --text: #e9eef7;
  --muted: rgba(233,238,247,.72);
  --border: rgba(233,238,247,.14);
  --accent: #9B8A32;
  --accent-2: #0E0940;
  --danger: #ff5b5b;

  /* Form-specific tokens */
  --control-bg: var(--panel);
  --control-bg-2: var(--panel-2);
  --control-text: var(--text);
  --control-border: var(--border);
  --control-focus: var(--accent);
  --control-placeholder: rgba(233,238,247,.55);
}

/* Text + background on all standard form controls */
input,
select,
textarea,
button {
  color: var(--control-text);
}

/* Inputs / selects / textareas */
.input,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="date"],
input[type="time"],
input[type="search"],
select,
textarea {
  background: var(--control-bg);
  color: var(--control-text);
  border: 1px solid var(--control-border);
  border-radius: 12px;
  outline: none;
}

/* Placeholder contrast */
.input::placeholder,
input::placeholder,
textarea::placeholder {
  color: var(--control-placeholder);
  opacity: 1;
}

/* Make select arrow + height consistent */
select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 40px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

/* IMPORTANT: option colors (works in most Chromium/Firefox; Safari can be OS-driven) */
select option,
select optgroup {
  background: var(--control-bg);
  color: var(--control-text);
}

/* Focus states */
.input:focus,
input:focus,
select:focus,
textarea:focus {
  border-color: rgba(155,138,50,.75);
  box-shadow: 0 0 0 3px rgba(155,138,50,.25);
}

/* Disabled states */
.input:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  opacity: .65;
  cursor: not-allowed;
  background: color-mix(in srgb, var(--control-bg) 80%, #000 20%);
}

/* Validation / danger helper (if you use .is-error) */
.is-error,
.input.is-error,
input.is-error,
select.is-error,
textarea.is-error {
  border-color: rgba(255,91,91,.8);
  box-shadow: 0 0 0 3px rgba(255,91,91,.18);
}

/* Dropdown-like menus (if any components use .menu/.dropdown) */
.menu,
.dropdown,
.popover {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
}

/* Links inside menus */
.menu a,
.dropdown a {
  color: var(--text);
}
.menu a:hover,
.dropdown a:hover {
  background: color-mix(in srgb, var(--panel) 75%, #fff 25%);
}

