@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Inter:wght@300;400;500;600&display=swap');

/* ================================================================
   SAF Woodworks — Premium Styles
   Palette: Navy #1a2a3a | Gold #c8a55a | Warm White #f8f5f0
   ================================================================ */

:root {
  --sidebar-width: 252px;
  --navy: #1a2a3a;
  --navy-dark: #0f1d2a;
  --navy-mid: #243548;
  --gold: #c8a55a;
  --gold-light: #ddb96e;
  --gold-pale: #f5ead4;
  --bg: #f4f1eb;
  --bg-warm: #ede9e1;
  --card-bg: #ffffff;
  --text: #2c3e50;
  --muted: #7a8a99;
  --border: #e2ddd5;
  --shadow-sm: 0 2px 10px rgba(26,42,58,.07);
  --shadow-md: 0 6px 24px rgba(26,42,58,.11);
  --shadow-lg: 0 12px 48px rgba(26,42,58,.18);
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 18px;
  --ease: .2s ease;
}

/* ---- Base ---------------------------------------------------- */
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  font-size: 0.925rem;
  line-height: 1.65;
}

h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  color: var(--navy);
}

.wrapper { min-height: 100vh; }

/* ---- Sidebar ------------------------------------------------- */
.sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  max-width: var(--sidebar-width);
  background: linear-gradient(180deg, var(--navy-dark) 0%, var(--navy) 55%, #1e3248 100%);
  min-height: 100vh;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  z-index: 200;
  transition: transform .25s ease;
  box-shadow: 3px 0 20px rgba(0,0,0,.18);
  scrollbar-width: thin;
  scrollbar-color: rgba(200,165,90,.25) transparent;
}
.sidebar::-webkit-scrollbar { width: 3px; }
.sidebar::-webkit-scrollbar-thumb { background: rgba(200,165,90,.25); border-radius: 3px; }

.sidebar-brand {
  background: transparent;
  border-bottom: 1px solid rgba(200,165,90,.18);
  padding: 1rem 1rem .9rem;
  gap: .65rem;
}
.sidebar-logo {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--gold);
  flex-shrink: 0;
  box-shadow: 0 0 0 4px rgba(200,165,90,.12);
  transition: box-shadow var(--ease);
}
.sidebar-logo:hover { box-shadow: 0 0 0 6px rgba(200,165,90,.22); }
.sidebar-brand .fw-bold { color: #fff; font-size: .95rem; font-family: 'Playfair Display', Georgia, serif; }
.sidebar-tagline {
  font-size: 0.62rem;
  color: rgba(200,165,90,.65);
  letter-spacing: .06em;
  display: block;
  text-transform: uppercase;
  font-weight: 500;
}
/* legacy icon fallback */
.brand-icon { font-size: 1.5rem; color: var(--gold); }

.sidebar .nav-link {
  color: rgba(255,255,255,.65);
  border-radius: var(--radius-sm);
  padding: .52rem .85rem;
  margin-bottom: 2px;
  font-size: 0.865rem;
  font-weight: 500;
  transition: background var(--ease), color var(--ease), padding-left var(--ease), border-left var(--ease);
  display: flex;
  align-items: center;
  gap: .5rem;
  border-left: 3px solid transparent;
}
.sidebar .nav-link i { font-size: .95rem; width: 1.2rem; flex-shrink: 0; opacity: .8; }
.sidebar .nav-link:hover {
  background: rgba(200,165,90,.14);
  color: var(--gold-light);
  padding-left: 1.1rem;
}
.sidebar .nav-link.active {
  background: rgba(200,165,90,.2);
  color: var(--gold-light);
  font-weight: 600;
  border-left-color: var(--gold);
}
.sidebar .nav-link.active i { opacity: 1; }
.sidebar hr { border-color: rgba(200,165,90,.14); margin: .4rem 0; }
.sidebar-footer {
  color: rgba(255,255,255,.28);
  font-size: 0.7rem;
  padding: .7rem 1rem;
  border-top: 1px solid rgba(200,165,90,.12);
}

/* ---- Main content -------------------------------------------- */
.main-content { min-width: 0; overflow: hidden; }

.topbar {
  background: linear-gradient(to right, #fff 0%, #fafaf8 100%);
  border-bottom: 2px solid var(--gold-pale);
  position: sticky;
  top: 0;
  z-index: 100;
  min-height: 60px;
  box-shadow: var(--shadow-sm);
}
.topbar h5 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.1rem;
  color: var(--navy);
}

.content-area { max-width: 1400px; }

/* ---- Cards --------------------------------------------------- */
.card {
  border: none;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  background: var(--card-bg);
  transition: box-shadow var(--ease), transform var(--ease);
}
.card-header {
  background: #fff;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
  border-radius: var(--radius) var(--radius) 0 0 !important;
  padding: .85rem 1.25rem;
  letter-spacing: .01em;
}
.card-header.bg-primary {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%) !important;
  border: none;
}

/* ---- Stats cards --------------------------------------------- */
.stat-card {
  border-left: 4px solid var(--gold) !important;
  border-radius: var(--radius) !important;
  overflow: hidden;
  position: relative;
  transition: transform var(--ease), box-shadow var(--ease);
}
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md) !important; }
.stat-card::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 90px; height: 100%;
  background: linear-gradient(135deg, transparent, rgba(200,165,90,.05));
  pointer-events: none;
}
.stat-card .stat-icon { font-size: 2.1rem; opacity: .18; }
.stat-card .stat-value {
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--navy);
  font-family: 'Playfair Display', Georgia, serif;
}
.stat-card .stat-label {
  font-size: 0.72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
}

/* ---- Accent colour helpers ----------------------------------- */
.bg-navy   { background: var(--navy) !important; }
.bg-accent { background: var(--gold) !important; }
.text-navy { color: var(--navy) !important; }
.text-gold { color: var(--gold) !important; }
.btn-navy  { background: var(--navy); color: #fff; border-color: var(--navy); font-weight: 500; }
.btn-navy:hover { background: var(--navy-dark); color: #fff; border-color: var(--navy-dark); box-shadow: 0 4px 12px rgba(26,42,58,.22); }
.btn-gold  { background: var(--gold); color: #fff; border-color: var(--gold); font-weight: 500; }
.btn-gold:hover { background: var(--gold-light); color: #fff; border-color: var(--gold-light); }

/* ---- Bootstrap button overrides ----------------------------- */
.btn { font-weight: 500; border-radius: var(--radius-sm); letter-spacing: .01em; transition: all var(--ease); }
.btn-primary { background: var(--navy); border-color: var(--navy); }
.btn-primary:hover, .btn-primary:focus { background: var(--navy-dark); border-color: var(--navy-dark); box-shadow: 0 4px 14px rgba(26,42,58,.25); }
.btn-sm { font-size: 0.78rem; padding: .3rem .7rem; }

/* ---- Tables -------------------------------------------------- */
.table > :not(caption) > * > th {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  color: #fff;
  white-space: nowrap;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: .05em;
  padding: .75rem .75rem;
  border: none;
}
.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: #faf8f4; }
.table-hover > tbody > tr:hover > * { background-color: var(--gold-pale) !important; }
.table-responsive { border-radius: var(--radius-sm); }

/* ---- Forms --------------------------------------------------- */
.form-label { font-weight: 600; font-size: 0.8rem; color: var(--navy); margin-bottom: .3rem; }
.form-control, .form-select {
  border-radius: var(--radius-sm);
  border-color: var(--border);
  font-size: 0.885rem;
  transition: border-color var(--ease), box-shadow var(--ease);
  background-color: #fdfdfc;
}
.form-control:focus, .form-select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 .2rem rgba(200,165,90,.22);
  background-color: #fff;
}

/* ---- Badges -------------------------------------------------- */
.badge { font-size: 0.7rem; font-weight: 600; border-radius: 6px; padding: .35em .65em; letter-spacing: .02em; }

/* ---- Alerts -------------------------------------------------- */
.alert { border-radius: var(--radius-sm); border-left-width: 4px; font-size: 0.875rem; }

/* ---- Line item builder --------------------------------------- */
#items-table .item-row td, #itemsTable .item-row td { vertical-align: middle; }
#items-table input, #items-table select,
#itemsTable input, #itemsTable select { font-size: 0.84rem; padding: .28rem .48rem; }
.remove-row { cursor: pointer; }

/* ---- Barcode area -------------------------------------------- */
.barcode-cell { font-family: 'Courier New', monospace; letter-spacing: 2px; }

/* ---- Pagination --------------------------------------------- */
.pagination .page-link { color: var(--navy); border-radius: var(--radius-sm) !important; margin: 0 2px; font-size: 0.85rem; }
.pagination .page-item.active .page-link { background: var(--navy); border-color: var(--navy); }
.pagination .page-link:hover { background: var(--gold-pale); color: var(--navy); }

/* ---- Responsive sidebar -------------------------------------- */
@media (max-width: 991.98px) {
  .sidebar {
    position: fixed;
    left: 0; top: 0;
    transform: translateX(-100%);
  }
  .sidebar.open { transform: translateX(0); }
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.42);
    z-index: 199;
    backdrop-filter: blur(2px);
  }
  .sidebar-overlay.show { display: block; }

  /* Nav link active state visible on mobile overlay */
  .sidebar .nav-link.active {
    background: rgba(200,165,90,.25) !important;
    color: var(--gold-light) !important;
    border-left-color: var(--gold) !important;
  }
  .sidebar .nav-link:hover {
    background: rgba(200,165,90,.18) !important;
    color: #fff !important;
  }

  /* Topbar adjustments */
  .topbar {
    padding: .4rem .75rem !important;
    flex-wrap: nowrap;
    gap: .5rem;
  }
  .topbar h5 { font-size: .9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 40vw; }
  .topbar .d-flex.align-items-center.gap-2 { gap: .35rem !important; flex-shrink: 0; }
  .topbar .badge { font-size: .65rem; padding: .25em .45em; }
  .topbar .btn-sm { padding: .22rem .5rem; font-size: .72rem; }

  /* Content area */
  .content-area { padding: 1rem !important; }
  .content-area h1, .content-area .h1 { font-size: 1.4rem; }
  .content-area h2, .content-area .h2 { font-size: 1.2rem; }

  /* Cards compact on mobile */
  .card { border-radius: 10px; }
  .card-header { padding: .65rem .85rem; font-size: .82rem; }

  /* Stat cards grid */
  .stat-card .stat-value { font-size: 1.3rem; }
  .stat-card .stat-label { font-size: .65rem; }

  /* Forms */
  .form-control, .form-select { font-size: .85rem; padding: .5rem .7rem; }

  /* Toolbar: let it wrap but stay horizontal */
  .content-area > .d-flex.justify-content-between { flex-wrap: wrap; gap: .5rem; }
  .d-flex.gap-2 .btn { font-size: .78rem; }

  /* Filter rows stack properly */
  .card-body .row.g-2 { gap: .35rem 0; }

  /* Hide sidebar toggle text */
  #sidebarToggle { display: flex !important; }

  /* ============================================================
     MOBILE TABLE → HORIZONTAL SCROLL
     All tables scroll horizontally with touch support.
     Targets both .table-responsive wrappers AND tables
     placed directly inside .card-body (no wrapper needed).
     ============================================================ */
  .table-responsive,
  .card-body.p-0 {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--gold) transparent;
  }
  .table-responsive::-webkit-scrollbar,
  .card-body.p-0::-webkit-scrollbar { height: 6px; }
  .table-responsive::-webkit-scrollbar-track,
  .card-body.p-0::-webkit-scrollbar-track { background: transparent; }
  .table-responsive::-webkit-scrollbar-thumb,
  .card-body.p-0::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 3px; }

  /* Ensure tables extend beyond viewport so they actually scroll */
  .table-responsive > table,
  .card-body > table { min-width: 700px; white-space: nowrap; }
  .table-responsive > table th,
  .table-responsive > table td,
  .card-body > table th,
  .card-body > table td { font-size: .82rem; padding: .45rem .55rem; }
  .table-responsive > table .btn,
  .card-body > table .btn { font-size: .75rem; padding: .25rem .5rem; }
  .table-responsive > table .btn-group .btn,
  .card-body > table .btn-group .btn { border-radius: 4px !important; }
  .table-responsive > table .badge,
  .card-body > table .badge { font-size: .72rem; }
}

/* Small phones */
@media (max-width: 575.98px) {
  .topbar { min-height: 48px; }
  .topbar h5 { font-size: .82rem; max-width: 30vw; }
  .topbar .badge { display: none; }

  .content-area { padding: .75rem !important; }
  .stat-card .stat-value { font-size: 1.1rem; }
  .stat-card .stat-icon { font-size: 1.5rem; }

  /* Make inputs larger touch targets */
  .form-control, .form-select { min-height: 42px; }
  .btn { min-height: 38px; }
  .btn-sm { min-height: 32px; }

  /* Table scroll adjustments for very small screens */
  .table-responsive > table,
  .card-body > table { min-width: 600px; }
  .table-responsive > table th,
  .table-responsive > table td,
  .card-body > table th,
  .card-body > table td { font-size: .78rem; padding: .35rem .45rem; }

  /* Line item builder: still needs horizontal scroll */
  #items-table, #itemsTable { min-width: 700px; }
  .line-item-wrapper { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* ---- Login page ---------------------------------------------- */
.login-wrapper {
  min-height: 100vh;
  background: linear-gradient(145deg, var(--navy-dark) 0%, #1e3248 45%, #284059 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.login-wrapper::before {
  content: '';
  position: absolute;
  width: 650px; height: 650px;
  background: radial-gradient(circle, rgba(200,165,90,.1) 0%, transparent 70%);
  top: -250px; right: -200px;
  border-radius: 50%;
  pointer-events: none;
}
.login-wrapper::after {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(200,165,90,.07) 0%, transparent 70%);
  bottom: -150px; left: -100px;
  border-radius: 50%;
  pointer-events: none;
}
.login-card {
  width: 100%;
  max-width: 440px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 1;
  overflow: hidden;
  border: 1px solid rgba(200,165,90,.12);
}
.login-logo {
  width: 92px;
  height: 92px;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid var(--gold);
  box-shadow: 0 0 0 6px rgba(200,165,90,.14), var(--shadow-md);
  display: block;
  margin: 0 auto;
}
/* legacy icon login logo */
.login-logo-icon { font-size: 2.5rem; color: var(--gold); }
.login-card h4 { font-family: 'Playfair Display', Georgia, serif; }

/* ---- Print / PDF area --------------------------------------- */
@media print { .sidebar, .topbar { display: none !important; } .content-area { padding: 0 !important; } }

/* ---- Tablet landscape optimizations -------------------------- */
@media (min-width: 992px) and (max-width: 1199.98px) {
  .sidebar { --sidebar-width: 220px; min-width: 220px; max-width: 220px; width: 220px; }
  .sidebar .nav-link { font-size: .82rem; padding: .45rem .7rem; }
  .sidebar-brand .fw-bold { font-size: .88rem; }
  .stat-card .stat-value { font-size: 1.4rem; }
}

/* ---- Smooth touch scrolling ---------------------------------- */
@supports (-webkit-overflow-scrolling: touch) {
  .sidebar { -webkit-overflow-scrolling: touch; }
  .table-responsive { -webkit-overflow-scrolling: touch; }
}

/* ---- Safe area for notched phones ---------------------------- */
@supports (padding: env(safe-area-inset-bottom)) {
  .sidebar { padding-bottom: env(safe-area-inset-bottom); }
  .topbar { padding-left: max(.75rem, env(safe-area-inset-left)); padding-right: max(.75rem, env(safe-area-inset-right)); }
}
