/* ============================================================
   Tech Station LLC — osTicket client portal UI overlay
   Loaded AFTER assets/default/css/theme.css (so it wins).
   Non-destructive: edits no core logic. To change the brand
   color, edit --ts-primary below. To remove, delete this file
   and the matching <link> line in include/client/header.inc.php.
   ============================================================ */

:root {
  --ts-primary:       #2563eb;   /* main brand blue  */
  --ts-primary-dark:  #1d4ed8;
  --ts-primary-soft:  #eaf1ff;
  --ts-accent:        #0ea5e9;
  --ts-success:       #16a34a;
  --ts-success-dark:  #15803d;
  --ts-bg:            #eef2f7;
  --ts-card:          #ffffff;
  --ts-text:          #1f2933;
  --ts-muted:         #6b7280;
  --ts-border:        #e6e9ef;
  --ts-radius:        14px;
  --ts-radius-sm:     9px;
  --ts-shadow:        0 1px 2px rgba(16,24,40,.06), 0 10px 30px rgba(16,24,40,.06);
  --ts-shadow-sm:     0 1px 2px rgba(16,24,40,.08);
  --ts-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
             Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
}

/* ---------- Base / layout ---------- */
body {
  background: var(--ts-bg) !important;
  font-family: var(--ts-font) !important;
  color: var(--ts-text) !important;
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
}

#container {
  max-width: 1040px !important;
  margin: 0 auto !important;
  padding: 22px 18px 48px !important;
  background: transparent !important;
}

a { color: var(--ts-primary); text-decoration: none; }
a:hover { color: var(--ts-primary-dark); text-decoration: underline; }

h1, h2, h3 { color: var(--ts-text); font-weight: 700; letter-spacing: -.01em; }

/* ---------- Header ---------- */
#header {
  background: var(--ts-card) !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow) !important;
  padding: 16px 24px !important;
  height: auto !important;
  min-height: 64px;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
#header #logo { position: static !important; margin: 0 !important; order: -1; }   /* logo on the left */
#header #logo img { max-height: 52px !important; width: auto !important; }
#header .pull-right { float: none !important; text-align: right; order: 2; }       /* account links on the right */
#header p { color: var(--ts-muted) !important; font-size: 13px; margin: 0; }
#header a { color: var(--ts-primary) !important; font-weight: 600; }

/* ---------- Navigation ---------- */
#nav {
  background: var(--ts-card) !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow-sm) !important;
  padding: 8px !important;
  height: auto !important;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}
#nav li { float: none !important; list-style: none; margin: 0 !important; }
#nav li a {
  background: transparent !important;
  background-image: none !important;   /* drop dated icon sprites */
  color: var(--ts-text) !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 10px 18px !important;
  height: auto !important;
  line-height: 1.2 !important;
  font-weight: 600;
  font-size: 14px;
  border: none !important;
  transition: background .15s ease, color .15s ease;
}
#nav li a:hover {
  background: var(--ts-primary-soft) !important;
  color: var(--ts-primary-dark) !important;
}
#nav li a.active {
  background: var(--ts-primary) !important;
  color: #fff !important;
}

/* ---------- Content card ---------- */
#content {
  background: var(--ts-card) !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow) !important;
  padding: 30px 32px !important;
  margin: 0 !important;
}
#content > h1:first-child { margin-top: 0; }
hr { border: 0; border-top: 1px solid var(--ts-border); margin: 22px 0; }

/* ---------- Buttons ---------- */
.button, .button:visited,
input[type="submit"], input[type="button"], button {
  background: var(--ts-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 11px 22px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  box-shadow: var(--ts-shadow-sm);
  transition: transform .08s ease, box-shadow .15s ease, background .15s ease;
  cursor: pointer;
}
.button:hover,
input[type="submit"]:hover, input[type="button"]:hover, button:hover {
  background: var(--ts-primary-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(37,99,235,.28);
}
.button:active { transform: translateY(0); }

.green.button, .green.button:visited {
  background: var(--ts-success) !important;
}
.green.button:hover { background: var(--ts-success-dark) !important;
  box-shadow: 0 6px 16px rgba(22,163,74,.28); }

.blue.button, .blue.button:visited { background: var(--ts-accent) !important; }
.blue.button:hover { background: #0284c7 !important;
  box-shadow: 0 6px 16px rgba(14,165,233,.28); }

/* Secondary button (e.g. Reset) — quiet, outlined */
input[type="reset"] {
  background: #fff !important;
  color: var(--ts-text) !important;
  border: 1px solid var(--ts-border) !important;
  box-shadow: none !important;
}
input[type="reset"]:hover {
  background: #f4f6fb !important;
  color: var(--ts-text) !important;
  border-color: #cbd2dd !important;
  box-shadow: none !important;
}

/* ---------- Landing page CTA tiles ---------- */
#landing_page #new_ticket,
#landing_page #check_status {
  background-color: var(--ts-card) !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow-sm) !important;
  padding: 26px 26px 26px 92px !important;
  background-position: 24px 24px !important;
  background-repeat: no-repeat !important;
  transition: transform .12s ease, box-shadow .15s ease, border-color .15s ease;
}
#landing_page #new_ticket:hover,
#landing_page #check_status:hover {
  transform: translateY(-2px);
  box-shadow: var(--ts-shadow) !important;
  border-color: var(--ts-primary) !important;
}

/* ---------- Forms ---------- */
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="tel"], input[type="url"],
input[type="search"], select, textarea {
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 9px 12px !important;
  font-size: 14px !important;
  font-family: var(--ts-font) !important;
  color: var(--ts-text) !important;
  background: #fff !important;
  transition: border-color .15s ease, box-shadow .15s ease;
}
input[type="text"]:focus, input[type="email"]:focus,
input[type="password"]:focus, textarea:focus, select:focus {
  border-color: var(--ts-primary) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important;
  outline: none !important;
}

/* ---------- Tables ---------- */
table.list, table.padded, #ticketTable {
  border-collapse: separate !important;
  border-spacing: 0;
  width: 100%;
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-sm);
  overflow: hidden;
}
table.list thead th, #ticketTable thead th {
  background: #f4f6fb !important;
  color: var(--ts-muted) !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  font-size: 11.5px;
  letter-spacing: .03em;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--ts-border) !important;
}
table.list tbody td, #ticketTable tbody td {
  padding: 12px 14px !important;
  border-bottom: 1px solid #f1f3f7 !important;
}
table.list tbody tr:hover, #ticketTable tbody tr:hover {
  background: var(--ts-primary-soft) !important;
}

/* ---------- Status / labels ---------- */
.label {
  border-radius: 999px !important;
  padding: 3px 10px !important;
  font-weight: 600 !important;
  font-size: 11.5px !important;
}

/* ---------- Alert messages ---------- */
#msg_notice, #msg_error, #msg_warning, #msg_info {
  border-radius: var(--ts-radius-sm) !important;
  border: 1px solid transparent !important;
  border-left-width: 4px !important;
  padding: 13px 16px 13px 42px !important;
  background-repeat: no-repeat !important;
  background-position: 14px 50% !important;
  font-size: 14px;
  margin-bottom: 16px !important;
}
#msg_notice  { background-color: #e7f7ec !important; border-color: var(--ts-success) !important; color: #14532d !important; }
#msg_error   { background-color: #fdecec !important; border-color: #dc2626 !important; color: #7f1d1d !important; }
#msg_warning { background-color: #fff7e6 !important; border-color: #f59e0b !important; color: #7c2d12 !important; }
#msg_info    { background-color: #e8f3fb !important; border-color: var(--ts-accent) !important; color: #0c4a6e !important; }

/* ---------- Footer ---------- */
#footer {
  margin-top: 26px !important;
  border: none !important;
  color: var(--ts-muted) !important;
  font-siz