/* ═══════════════════════════════════════════════════════
   NEW MORNING COFFEE ROASTERS — App Styles
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=DM+Mono:wght@300;400;500&family=Lato:wght@300;400;700&display=swap');

:root {
  --bg:      #13141a;
  --surf:    #1a1c22;
  --surf2:   #22252e;
  --surf3:   #2a2d38;
  --bdr:     #363a45;
  --bdr2:    #484d5a;
  --gold:    #F0B414;
  --gold2:   #F0C828;
  --slate:   #787878;
  --tx:      #e8eaf0;
  --tx2:     #a0a8b8;
  --tx3:     #646c7e;
  --red:     #e05252;
  --orange:  #e08040;
  --yellow:  #d4b840;
  --green:   #4caf7a;
  --blue:    #5899d4;
  --r:       8px;
  --r2:      12px;
}

/* BASE */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background: var(--bg);
  color: var(--tx);
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  line-height: 1.5;
}
a { color: var(--gold); text-decoration: none; }
a:hover { color: var(--gold2); }

/* NAV */
.navbar {
  background: var(--surf) !important;
  border-bottom: 1px solid var(--bdr);
  padding: 0 24px;
  height: 56px;
  display: flex;
  align-items: center;
}
.navbar-brand {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 17px;
  color: var(--tx) !important;
  margin-right: 24px;
  line-height: 1.2;
}
.navbar-brand .sun { color: var(--gold); }
.navbar-brand .sub {
  font-style: normal;
  font-size: 9px;
  letter-spacing: .15em;
  color: var(--slate);
  display: block;
  font-family: 'Lato', sans-serif;
}
.nav-link {
  color: var(--tx2) !important;
  font-size: 13px;
  padding: 6px 12px !important;
  border-radius: 6px;
  transition: all .15s;
}
.nav-link:hover { background: var(--surf2); color: var(--tx) !important; }
.nav-link.active { background: var(--surf3) !important; color: var(--gold) !important; }

/* MAIN CONTENT */
main { padding: 28px 24px; max-width: 1800px; margin: 0 auto; }

/* PAGE HEADER */
.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 24px;
  gap: 16px;
}
.page-title {
  font-family: 'Playfair Display', serif;
  font-size: 24px;
  color: var(--tx);
  margin-bottom: 3px;
}
.page-sub {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .07em;
  color: var(--tx3);
}

/* ALERTS */
.alert-success {
  background: rgba(76,175,122,.1);
  border: 1px solid rgba(76,175,122,.3);
  border-radius: var(--r);
  padding: 12px 16px;
  color: #70d090;
  font-size: 13px;
  margin-bottom: 16px;
}

/* FILTER BAR */
.filter-bar { margin-bottom: 16px; }
.filter-form { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.search-input {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 8px 14px;
  color: var(--tx);
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  width: 280px;
  outline: none;
  transition: border-color .15s;
}
.search-input:focus { border-color: var(--gold); }
.filter-select {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 8px 12px;
  color: var(--tx2);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}
.filter-select:focus { border-color: var(--gold); }

/* TABLE */
.table-card {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r2);
  overflow: hidden;
}
.table-scroll { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tx3);
  text-align: left;
  padding: 10px 16px;
  border-bottom: 1px solid var(--bdr);
  background: var(--surf2);
  white-space: nowrap;
}
.data-table td {
  padding: 9px 16px;
  border-bottom: 1px solid var(--bdr);
  font-size: 13px;
  color: var(--tx2);
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(255,255,255,.02); }
.table-foot {
  padding: 8px 16px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--tx3);
  text-align: right;
  border-top: 1px solid var(--bdr);
  background: var(--surf2);
}

/* TAGS & PILLS */
.blend-tag {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--gold2);
  background: rgba(240,200,40,.1);
  border: 1px solid rgba(240,200,40,.2);
  border-radius: 4px;
  padding: 2px 7px;
  margin-right: 6px;
}
.blend-name { font-size: 12px; color: var(--tx3); }
.grind-tag {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--tx3);
  background: var(--surf3);
  border-radius: 4px;
  padding: 2px 7px;
}
.no-blend { font-size: 12px; color: var(--tx3); font-style: italic; }
.pill-green {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(76,175,122,.18);
  color: #70d090;
  border: 1px solid rgba(76,175,122,.3);
}
.pill-slate {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(120,120,120,.15);
  color: #909098;
  border: 1px solid rgba(120,120,120,.25);
}
.pill-red {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(224,82,82,.18);
  color: #f08080;
  border: 1px solid rgba(224,82,82,.3);
}
.pill-orange {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(224,128,64,.18);
  color: #f0a060;
  border: 1px solid rgba(224,128,64,.3);
}
.pill-yellow {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(212,184,64,.18);
  color: #e8d060;
  border: 1px solid rgba(212,184,64,.3);
}

/* TYPOGRAPHY */
.mono {
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  color: var(--tx2);
}
.item-desc { color: var(--tx); max-width: 320px; }

/* ROW ACTIONS */
.row-actions { display: flex; gap: 6px; white-space: nowrap; }

/* BUTTONS */
.btn-primary {
  display: inline-block;
  padding: 9px 20px;
  background: var(--gold);
  color: #13141a;
  border: none;
  border-radius: var(--r);
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  transition: all .15s;
  white-space: nowrap;
}
.btn-primary:hover { background: var(--gold2); color: #13141a; }
.btn-secondary {
  display: inline-block;
  padding: 9px 20px;
  background: transparent;
  color: var(--tx2);
  border: 1px solid var(--bdr2);
  border-radius: var(--r);
  font-size: 13px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  transition: all .15s;
  white-space: nowrap;
}
.btn-secondary:hover { background: var(--surf2); color: var(--tx); }
.btn-filter {
  padding: 8px 16px;
  background: var(--surf2);
  color: var(--tx2);
  border: 1px solid var(--bdr2);
  border-radius: var(--r);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  transition: all .15s;
}
.btn-filter:hover { color: var(--gold); border-color: rgba(240,180,20,.4); }
.btn-clear {
  padding: 8px 14px;
  background: transparent;
  color: var(--tx3);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  transition: all .15s;
}
.btn-clear:hover { color: var(--tx2); }
.btn-edit {
  padding: 4px 12px;
  background: transparent;
  color: var(--gold);
  border: 1px solid rgba(240,180,20,.3);
  border-radius: var(--r);
  font-size: 12px;
  font-family: 'DM Mono', monospace;
  transition: all .15s;
}
.btn-edit:hover { background: rgba(240,180,20,.08); color: var(--gold2); }
.btn-details {
  padding: 4px 12px;
  background: transparent;
  color: var(--tx3);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  font-size: 12px;
  font-family: 'DM Mono', monospace;
  transition: all .15s;
}
.btn-details:hover { color: var(--tx2); background: var(--surf2); }

/* FORMS */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}
@media(max-width: 900px) { .form-grid { grid-template-columns: 1fr; } }
.form-section {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r2);
  padding: 20px;
}
.form-section-title {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tx3);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--bdr);
}
.field { margin-bottom: 14px; }
/* .field:last-child { margin-bottom: 0; } */
.field-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.field-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.field-row-2 .field, .field-row-3 .field { margin-bottom: 0; }
.field-label {
  display: block;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--tx3);
  margin-bottom: 6px;
}
.field-input, .field-select {
  width: 100%;
  background: var(--surf2);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 9px 12px;
  color: var(--tx);
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
  appearance: none;
}
.field-input:focus, .field-select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(240,180,20,.1);
}
.field-error { display: block; font-size: 11px; color: var(--red); margin-top: 4px; }
.form-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  padding-top: 8px;
}

/* DETAIL ROWS */
.detail-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  padding: 7px 0;
  border-bottom: 1px solid var(--bdr);
  color: var(--tx3);
}
.detail-row:last-child { border-bottom: none; }
.detail-row span:last-child { color: var(--tx2); text-align: right; }

/* CARD HEADER */
.card-hdr {
  padding: 12px 16px;
  border-bottom: 1px solid var(--bdr);
  background: var(--surf2);
}
.card-title {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tx2);
}

/* LINE COMPLETE BUTTONS */
.btn-complete {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--bdr2);
  background: transparent;
  color: var(--tx3);
  cursor: pointer;
  font-size: 14px;
  transition: all .15s;
}
.btn-complete:hover {
  border-color: var(--green);
  color: var(--green);
}
.btn-done {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(76,175,122,.4);
  background: rgba(76,175,122,.1);
  color: var(--green);
  cursor: pointer;
  font-size: 14px;
}
.btn-remove {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--bdr);
  background: transparent;
  color: var(--tx3);
  cursor: pointer;
  font-size: 12px;
  transition: all .15s;
}
.btn-remove:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(224,82,82,.08);
}

/* PILL BLUE */
.pill-blue {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  background: rgba(88,153,212,.18);
  color: #80b8e8;
  border: 1px solid rgba(88,153,212,.3);
}

/* DELETE BUTTON */
.btn-delete {
  padding: 4px 12px;
  background: transparent;
  color: var(--red);
  border: 1px solid rgba(224,82,82,.3);
  border-radius: var(--r);
  font-size: 12px;
  font-family: 'DM Mono', monospace;
  cursor: pointer;
  transition: all .15s;
}
.btn-delete:hover {
  background: rgba(224,82,82,.1);
  border-color: var(--red);
}

/* ═══════════════════════════════════════════════════════
   TICKET & DASHBOARD ADDITIONS
   ═══════════════════════════════════════════════════════ */

/* Filter bar label */
.filter-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--tx3);
}

/* Table footer note */
.tbl-foot {
  padding: 8px 16px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--tx3);
  border-top: 1px solid var(--bdr);
  background: var(--surf2);
}

/* Th/td alignment helpers */
.th-right { text-align: right; }
.th-center { text-align: center; }
.td-center { text-align: center; }

/* Active filter button state */
.btn-filter--active {
  color: var(--gold) !important;
  border-color: rgba(240,180,20,.4) !important;
  background: rgba(240,180,20,.08) !important;
}

/* Alert error (inline, not full-page) */
.alert-error {
  background: rgba(224,82,82,.1);
  border: 1px solid rgba(224,82,82,.3);
  border-radius: var(--r);
  padding: 12px 16px;
  color: #f08080;
  font-size: 13px;
  margin-bottom: 16px;
}

/* Dashboard stat row */
.stat-row { display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap; }
.stat-card {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r2);
  padding: 12px 16px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
  transition: border-color .15s;
}
.stat-card:hover { border-color: var(--bdr2); }
.stat-num {
  font-family: 'DM Mono', monospace;
  font-size: 28px;
  font-weight: 500;
  line-height: 1;
}
.stat-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .07em;
  color: var(--tx3);
  margin-top: 4px;
  white-space: nowrap;
}
.stat-divider { width: 1px; background: var(--bdr); margin: 0 4px; }
.stat--red    { color: var(--red); }
.stat--orange { color: var(--orange); }
.stat--yellow { color: var(--yellow); }
.stat--green  { color: var(--green); }
.stat--slate  { color: var(--tx3); }
.stat--blue   { color: var(--blue); }

/* Dashboard panels */
.dash-panel {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: var(--r2);
  overflow: hidden;
}
.dash-panel-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: var(--surf2);
  border-bottom: 1px solid var(--bdr);
}
.dash-panel-title {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--tx2);
  display: flex;
  align-items: center;
  gap: 8px;
}
.panel-count {
  background: var(--surf3);
  color: var(--tx3);
  border-radius: 8px;
  padding: 1px 7px;
  font-size: 10px;
}
.panel-sub {
  font-size: 10px;
  color: var(--tx3);
  letter-spacing: 0;
  font-family: 'Lato', sans-serif;
}
.panel-link { font-size: 12px; color: var(--tx3); }
.panel-link:hover { color: var(--gold); }
.panel-scroll {
  max-height: 260px;
  overflow-y: auto;
}
.panel-scroll::-webkit-scrollbar { width: 4px; }
.panel-scroll::-webkit-scrollbar-track { background: transparent; }
.panel-scroll::-webkit-scrollbar-thumb { background: var(--bdr2); border-radius: 2px; }

/* Dashboard ticket pipeline */
.pipeline-mini {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--bdr);
}
.pipeline-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}
.stage-num {
  font-family: 'DM Mono', monospace;
  font-size: 22px;
  font-weight: 500;
  color: var(--bdr2);
  line-height: 1;
}
.stage-lbl {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .06em;
  color: var(--tx3);
  margin-top: 3px;
}
.pipeline-arrow { color: var(--bdr2); font-size: 12px; }
.stage--active .stage-num { color: var(--gold); }
.stage--active .stage-lbl { color: var(--tx2); }
.stage--complete .stage-num { color: var(--green); }
.stage--complete .stage-lbl { color: var(--green); }

/* Ticket list in dashboard sidebar */
.ticket-list { display: flex; flex-direction: column; gap: 1px; }
.ticket-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 16px;
  border-left: 3px solid var(--bdr2);
  text-decoration: none;
  transition: background .1s;
}
.ticket-row:hover { background: var(--surf2); }

/* Silo grid in dashboard */
.silo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  padding: 12px;
}
.silo-card {
  background: var(--surf2);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 7px 8px;
}
.silo--empty { opacity: .35; }
.silo-hdr {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}
.silo-bar-wrap {
  height: 3px;
  background: var(--bdr);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 5px;
}
.silo-bar { height: 100%; border-radius: 2px; transition: width .3s; }

/* Mini bar (blend demand table) */
.mini-bar-wrap {
  height: 4px;
  background: var(--bdr);
  border-radius: 2px;
  overflow: hidden;
}
.mini-bar {
  height: 100%;
  background: var(--gold);
  border-radius: 2px;
  opacity: .5;
}

/* Empty state */
.empty-msg {
  padding: 20px 16px;
  font-size: 12px;
  color: var(--tx3);
}

/* Misc helpers */
.blend-name {
  font-size: 12px;
  color: var(--tx3);
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.urgency-bar {
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 16px;
  border-radius: var(--r);
}
.urgency-bar--red {
  background: rgba(224,82,82,.15);
  border: 1px solid rgba(224,82,82,.3);
  color: #f08080;
}
.urgency-bar--orange {
  background: rgba(224,128,64,.15);
  border: 1px solid rgba(224,128,64,.3);
  color: #f0a060;
}

/* Dashboard layout */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 16px;
  align-items: start;
}
@media (max-width: 1100px) { .dash-grid { grid-template-columns: 1fr; } }
.dash-col { display: flex; flex-direction: column; gap: 16px; }
.dash-sidebar {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: sticky;
  top: 16px;
}

/* Flavor field visibility (shown/hidden by JS) */
.flavor-field { display: none; }
