/* =====================================================
   Daily Dispatch - Main Stylesheet
   Mobile-first, clean operational app aesthetic
   ===================================================== */

:root {
  --dd-primary:   #0d6efd;
  --dd-primary-d: #0a58ca;
  --dd-sidebar:   #1f2937;
  --dd-sidebar-h: #111827;
  --dd-text-mute: #6b7280;
  --dd-bg:        #f5f7fb;
  --dd-card:      #ffffff;
  --dd-border:    #e5e7eb;
  --dd-success:   #16a34a;
  --dd-warning:   #f59e0b;
  --dd-danger:    #dc2626;
}

* { box-sizing: border-box; }
html, body { background: var(--dd-bg); font-family: -apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; }

/* ---------- NAVBAR ---------- */
.dd-navbar { background: var(--dd-sidebar); }
.dd-navbar .navbar-brand { letter-spacing: .2px; }

/* ---------- LAYOUT ---------- */
.dd-layout { display: flex; min-height: calc(100vh - 56px); }
.dd-sidebar {
  width: 240px; background: var(--dd-sidebar); color: #cbd5e1;
  position: sticky; top: 56px; align-self: flex-start;
  height: calc(100vh - 56px); overflow-y: auto;
}
.dd-sidebar .nav-link {
  color: #cbd5e1; padding: .65rem 1.1rem; font-size: .92rem;
  border-left: 3px solid transparent;
}
.dd-sidebar .nav-link:hover { background: var(--dd-sidebar-h); color: #fff; }
.dd-sidebar .nav-link.active { background: var(--dd-sidebar-h); color: #fff; border-left-color: var(--dd-primary); }
.dd-sidebar .nav-link i { width: 22px; }
.dd-sidebar .dd-section {
  color: #6b7280; font-size: .72rem; padding: 1rem 1.1rem .3rem;
  text-transform: uppercase; letter-spacing: .07em;
}
.dd-main { flex: 1; padding: 1.25rem; min-width: 0; padding-bottom: 6rem; }

@media (max-width: 767.98px) {
  .dd-sidebar { background: #fff; color: #1f2937; width: 280px; }
  .dd-sidebar .nav-link { color: #1f2937; }
  .dd-sidebar .nav-link.active { background: #f3f4f6; color: var(--dd-primary); }
  .dd-sidebar .nav-link:hover { background: #f9fafb; color: var(--dd-primary); }
  .dd-sidebar .dd-section { color: #6b7280; }
}

/* ---------- CARDS ---------- */
.dd-card {
  background: var(--dd-card); border: 1px solid var(--dd-border);
  border-radius: 12px; padding: 1rem; margin-bottom: 1rem;
}
.dd-kpi {
  background: #fff; border: 1px solid var(--dd-border); border-radius: 12px;
  padding: 1rem; height: 100%;
}
.dd-kpi .label { font-size: .75rem; color: var(--dd-text-mute); text-transform: uppercase; letter-spacing: .04em; }
.dd-kpi .value { font-size: 1.75rem; font-weight: 700; margin-top: .25rem; }
.dd-kpi .ico { font-size: 1.5rem; opacity: .7; }
.dd-kpi.primary { border-left: 4px solid var(--dd-primary); }
.dd-kpi.success { border-left: 4px solid var(--dd-success); }
.dd-kpi.warning { border-left: 4px solid var(--dd-warning); }
.dd-kpi.danger  { border-left: 4px solid var(--dd-danger);  }

/* ---------- PAGE HEADER ---------- */
.dd-page-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1rem; gap: 1rem; flex-wrap: wrap;
}
.dd-page-head h1 { font-size: 1.4rem; margin: 0; font-weight: 600; }
.dd-page-head .subtitle { color: var(--dd-text-mute); font-size: .9rem; }

/* ---------- TABLE ---------- */
.dd-table-wrap { background: #fff; border-radius: 12px; border: 1px solid var(--dd-border); overflow: hidden; }
.dd-table-wrap .table-responsive { margin: 0; }
.dd-table { margin: 0; }
.dd-table thead th {
  background: #f9fafb; font-size: .78rem; text-transform: uppercase;
  letter-spacing: .04em; color: #374151; border-bottom: 1px solid var(--dd-border);
  white-space: nowrap;
}
.dd-table td { font-size: .9rem; vertical-align: middle; }
.dd-table tr:hover td { background: #f9fafb; }

/* ---------- FILTER BAR (desktop) ---------- */
.dd-filter-bar {
  background: #fff; border: 1px solid var(--dd-border); border-radius: 12px;
  padding: .75rem 1rem; margin-bottom: 1rem;
}
.dd-filter-bar label.form-label { font-size: .8rem; color: var(--dd-text-mute); margin-bottom: .15rem; }

/* ---------- TECH JOB CARD (mobile-first) ---------- */
.dd-job-card {
  background: #fff; border: 1px solid var(--dd-border); border-radius: 14px;
  padding: 1rem; margin-bottom: .85rem; box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.dd-job-card .header { display: flex; justify-content: space-between; align-items: flex-start; gap: .5rem; }
.dd-job-card .customer { font-weight: 600; font-size: 1.05rem; line-height: 1.3; }
.dd-job-card .meta { color: var(--dd-text-mute); font-size: .82rem; margin-top: .2rem; }
.dd-job-card .body { margin-top: .75rem; }
.dd-job-card .tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .5rem; }
.dd-job-card .actions { display: flex; gap: .5rem; margin-top: .85rem; flex-wrap: wrap; }
.dd-job-card .btn { min-height: 44px; flex: 1; min-width: 0; }
.dd-job-card .btn-start  { background: var(--dd-primary);  color: #fff; }
.dd-job-card .btn-finish { background: var(--dd-success);  color: #fff; }

/* ---------- MOBILE BOTTOM NAV ---------- */
.dd-mobile-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 1030;
  display: flex; justify-content: space-around; align-items: center;
  background: #fff; border-top: 1px solid var(--dd-border);
  padding: .25rem 0; padding-bottom: max(.25rem, env(safe-area-inset-bottom));
}
.dd-mobile-nav a {
  flex: 1; text-align: center; padding: .4rem 0; color: var(--dd-text-mute);
  text-decoration: none; font-size: .68rem; line-height: 1.2;
}
.dd-mobile-nav a i { font-size: 1.25rem; display: block; margin-bottom: .15rem; }
.dd-mobile-nav a.active { color: var(--dd-primary); font-weight: 600; }
.dd-mobile-fab {
  background: var(--dd-primary); color: #fff !important; border-radius: 50%;
  width: 52px; height: 52px; margin-top: -22px;
  display: flex !important; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(13,110,253,.35); font-size: 1.3rem; flex: 0 0 auto !important;
}
.dd-mobile-fab i { margin: 0 !important; font-size: 1.5rem !important; }

/* ---------- LOGIN PAGE ---------- */
.dd-login-body {
  min-height: 100vh; margin: 0;
  background: linear-gradient(135deg, #1e3a8a 0%, #0d6efd 100%);
  display: flex; align-items: center; justify-content: center; padding: 1rem;
}
.dd-login-wrap { width: 100%; max-width: 420px; }
.dd-login-card { background: #fff; border-radius: 18px; padding: 2.5rem 2rem; }
.dd-login-logo {
  width: 64px; height: 64px; border-radius: 16px;
  background: linear-gradient(135deg, #1e3a8a, #0d6efd);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-size: 2rem; margin: 0 auto .75rem;
}

/* ---------- FORM STYLES ---------- */
.dd-form-section {
  background: #fff; border: 1px solid var(--dd-border); border-radius: 12px;
  padding: 1.25rem; margin-bottom: 1rem;
}
.dd-form-section h6 { font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; color: var(--dd-text-mute); margin-bottom: 1rem; }
.form-label { font-weight: 500; font-size: .85rem; margin-bottom: .3rem; }

/* ---------- BADGES ---------- */
.badge { font-weight: 500; padding: .35em .6em; font-size: .72rem; }

/* ---------- EMPTY STATE ---------- */
.dd-empty {
  text-align: center; padding: 3rem 1rem; color: var(--dd-text-mute);
  background: #fff; border-radius: 12px; border: 1px dashed var(--dd-border);
}
.dd-empty i { font-size: 3rem; opacity: .35; display: block; margin-bottom: .5rem; }

/* ---------- UTILITIES ---------- */
.cursor-pointer { cursor: pointer; }
.text-truncate-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

@media (max-width: 767.98px) {
  .dd-main { padding: .85rem; padding-bottom: 6rem; }
  .dd-page-head h1 { font-size: 1.2rem; }
  .dd-kpi .value { font-size: 1.45rem; }
}
