/* ══ Inner-page design ══
   Loaded in <head> on every public inner page.
   Includes full header/navbar styles so top_header.php outputs HTML only. */

/* ── Universal reset (matches index.php) ── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── CSS Variables ── */
:root {
  --wine: #8b1a1a;
  --wine-dark: #6b1414;
  --white: #ffffff;
  --black: #111111;
  --green: #017d43;
  --green-dark: #015a32;
  --accent: #c8962e;
  --navy: #1e2a3b;
  --navy-light: #263449;
  --hero-bg: #d4e8f5;
  --hero-dark: #b8d9ee;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-400: #9ca3af;
  --gray-600: #4b5563;
  --gray-700: #374151;
}

/* ── Base ── */
html, body { margin: 0; padding: 0; }
body > header { margin: 0; padding: 0; position: fixed !important; top: 0; left: 0; width: 100%; z-index: 1000; }
body { padding-top: 104px !important; } /* offset for fixed header: ~36px topbar + 68px navbar */
body {
  font-family: 'Inter', Arial, sans-serif;
  background: var(--gray-50);
  color: var(--gray-700);
  -webkit-font-smoothing: antialiased;
}

/* ══ PUBLIC HEADER STYLES (moved from top_header.php <style>) ══ */

/* Topbar */
.pub-topbar {
  background: var(--navy); color: #cbd5e1; font-size: 12px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 24px; border-bottom: 1px solid var(--navy-light);
  font-family: 'Inter', Arial, sans-serif;
}
.pub-topbar a { color: #94a3b8; text-decoration: none; transition: color .2s; }
.pub-topbar a:hover { color: #fff; }
.pub-tb-left { display: flex; align-items: center; gap: 20px; }
.pub-tb-right { display: flex; align-items: center; gap: 16px; font-size: 13px; }
.pub-tb-div { width: 1px; height: 14px; background: #334155; }
@media(max-width:767px) { .pub-tb-left { display: none; } }

/* Navbar */
.pub-navbar {
  background: var(--white);
  border-bottom: 1px solid var(--gray-200);
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
  font-family: 'Inter', Arial, sans-serif;
}
.pub-nav-inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 24px; height: 68px;
}
.pub-nav-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.pub-nav-logo img { height: 50px; width: auto; display: block; }
.pub-nav-logo-text strong { font-size: 15px; font-weight: 800; color: var(--black); display: block; line-height: 1.2; }
.pub-nav-logo-text span { font-size: 12px; color: var(--wine); font-weight: 700; letter-spacing: .01em; }

.pub-nav-links { display: flex; align-items: center; list-style: none; gap: 2px; margin: 0; padding: 0; }
.pub-nav-links > li { position: relative; }
.pub-nav-links > li > a,
.pub-nav-links > li > .pub-has-dd {
  display: flex; align-items: center; gap: 4px;
  padding: 8px 13px; font-size: 13.5px; font-weight: 600;
  color: var(--gray-700); text-decoration: none; cursor: pointer;
  border-radius: 8px; transition: background .18s, color .18s; white-space: nowrap;
}
.pub-nav-links > li > a:hover,
.pub-nav-links > li > .pub-has-dd:hover { background: var(--gray-100); color: var(--wine); }
.pub-caret { font-size: 10px; margin-top: 1px; transition: transform .2s; }
.pub-nav-links > li:hover .pub-caret { transform: rotate(180deg); }
.pub-nav-links .pub-btn-reg {
  background: var(--wine); color: #fff !important;
  padding: 8px 16px; border-radius: 6px; transition: background .2s !important;
}
.pub-nav-links .pub-btn-reg:hover { background: var(--wine-dark) !important; color: #fff !important; }
.pub-nav-links .pub-btn-login {
  border: 1.5px solid var(--green); color: var(--green) !important;
  padding: 7px 14px; border-radius: 6px; transition: all .2s !important;
}
.pub-nav-links .pub-btn-login:hover { background: var(--green); color: #fff !important; }

/* Dropdowns */
.pub-dropdown {
  display: none; position: absolute; top: 100%; left: 0; padding-top: 8px;
  background: #fff; min-width: 220px; border-radius: 12px;
  box-shadow: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.1);
  list-style: none; padding: 6px; z-index: 300;
  border: 1px solid var(--gray-200);
  animation: pubFadeDown .15s ease;
}
@keyframes pubFadeDown { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.pub-nav-links > li:hover .pub-dropdown { display: block; }
.pub-dropdown li a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; font-size: 13px; font-weight: 500;
  color: var(--gray-700); text-decoration: none; border-radius: 6px;
  transition: background .15s, color .15s;
}
.pub-dropdown li a:hover { background: var(--gray-50); color: var(--wine); }
.pub-dropdown li a .fa,
.pub-dropdown li a .fas,
.pub-dropdown li a .far { width: 16px; color: var(--wine); font-size: 12px; }

/* Hamburger */
.pub-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; background: none; border: none; }
.pub-hamburger span { display: block; width: 22px; height: 2px; background: var(--gray-700); border-radius: 2px; }

/* Mobile menu */
.pub-mob-menu {
  display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: #fff; z-index: 1200; overflow-y: auto; padding-bottom: 40px;
  font-family: 'Inter', Arial, sans-serif;
}
.pub-mob-menu.open { display: block; }
.pub-mob-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--gray-200);
}
.pub-mob-close { background: none; border: none; font-size: 22px; cursor: pointer; color: var(--gray-600); line-height: 1; }
.pub-mob-actions { padding: 16px 20px; display: flex; gap: 12px; }
.pub-mob-btn { flex: 1; text-align: center; padding: 11px; border-radius: 6px; font-weight: 700; font-size: 14px; text-decoration: none; font-family: inherit; }
.pub-mob-btn-reg { background: var(--wine); color: #fff; }
.pub-mob-btn-login { border: 2px solid var(--green); color: var(--green); }
.pub-mob-nav { list-style: none; padding: 8px 12px; margin: 0; }
.pub-mob-nav > li { border-bottom: 1px solid var(--gray-100); }
.pub-mob-nav > li > a,
.pub-mob-nav > li > .pub-mob-parent {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 8px; font-size: 15px; font-weight: 600; color: var(--black);
  text-decoration: none; cursor: pointer; border-radius: 6px; transition: background .15s;
}
.pub-mob-nav > li > a:hover,
.pub-mob-nav > li > .pub-mob-parent:hover { background: var(--gray-50); }
.pub-mob-sub { display: none; padding-left: 16px; padding-bottom: 4px; }
.pub-mob-sub.open { display: block; }
.pub-mob-sub a { display: block; padding: 9px 8px; font-size: 14px; color: var(--gray-600); text-decoration: none; }

/* Responsive: show hamburger, hide desktop nav */
@media(max-width:991px) {
  .pub-nav-links { display: none; }
  .pub-hamburger { display: flex; }
}

/* ══ INNER PAGE STYLES ══ */

/* Hide preloader */
.preloader { display: none !important; }

/* Page section spacing */
section.pt-4 { padding-top: 2rem !important; }
section.pb-4 { padding-bottom: 3rem !important; }

/* Cards */
.card {
  border: 1px solid var(--gray-200) !important;
  border-radius: 10px !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
}
.card-header {
  background: #fff !important;
  border-bottom: 2px solid var(--gray-100) !important;
  font-weight: 700;
  font-size: 15px;
  color: var(--navy);
  border-radius: 10px 10px 0 0 !important;
  padding: 14px 18px !important;
}

/* Page section title */
h4.border-bottom.border-warning {
  font-size: 18px;
  font-weight: 700;
  color: var(--navy);
  padding-bottom: 0.6rem;
  margin-bottom: 1.5rem;
}

/* Tables */
.table a { color: var(--wine); text-decoration: none; font-weight: 500; }
.table a:hover { color: var(--wine-dark); text-decoration: underline; }
.table-bordered th, .table-bordered td { border-color: var(--gray-200) !important; }
.table tbody tr:hover { background: var(--gray-50); }

/* Buttons */
.btn-warning {
  background: var(--accent) !important; border-color: var(--accent) !important;
  color: #fff !important; font-weight: 600;
}
.btn-warning:hover { background: #b07b24 !important; border-color: #b07b24 !important; }
.btn-secondary {
  background: var(--wine) !important; border-color: var(--wine) !important;
  color: #fff !important; font-weight: 600;
}
.btn-secondary:hover {
  background: var(--wine-dark) !important; border-color: var(--wine-dark) !important; color: #fff !important;
}
.btn-primary { background: var(--navy) !important; border-color: var(--navy) !important; font-weight: 600; }

/* Form controls */
.form-control:focus, .form-select:focus {
  border-color: var(--wine);
  box-shadow: 0 0 0 3px rgba(139,26,26,.15);
}

/* Status badges */
.text-success { color: var(--green) !important; }
.text-danger  { color: #dc2626 !important; }
.text-warning { color: var(--accent) !important; }

/* DataTables overrides */
.dataTables_wrapper .dataTables_filter input {
  border: 1px solid var(--gray-200); border-radius: 6px; padding: 5px 10px;
}
.dataTables_wrapper .dataTables_filter input:focus { border-color: var(--wine); outline: none; }
.dataTables_wrapper .dt-buttons .btn { font-size: 12px; padding: 5px 12px; }

/* Page breadcrumb strip */
.page-title-strip { background: var(--navy); color: #fff; padding: 18px 0; margin-bottom: 1.5rem; }
.page-title-strip h2 { font-size: 20px; font-weight: 700; margin: 0; }

/* Info blocks */
.info-card {
  border-left: 4px solid var(--wine); padding: 16px 20px;
  background: #fff; border-radius: 8px; margin-bottom: 1rem;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

/* ── Side Navigation Card ── */
.side-nav-card {
  background: #fff; border-radius: 10px;
  border: 1px solid var(--gray-200);
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  overflow: hidden; margin-bottom: 1rem;
}
.side-nav-heading {
  background: var(--navy); color: #fff;
  font-weight: 700; font-size: 12.5px;
  letter-spacing: .05em; text-transform: uppercase;
  padding: 12px 16px;
}
.side-nav-list { display: flex; flex-direction: column; }
.side-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 16px; font-size: 14px; color: var(--gray-700);
  text-decoration: none; border-bottom: 1px solid var(--gray-100);
  border-left: 3px solid transparent;
  transition: background .15s, color .15s, border-left-color .15s;
}
.side-nav-item:last-child { border-bottom: none; }
.side-nav-item:hover {
  background: var(--gray-50); color: var(--wine);
  border-left-color: var(--wine); text-decoration: none;
}
.side-nav-item.active {
  background: #fdf2f2; color: var(--wine);
  font-weight: 600; border-left-color: var(--wine);
}
.side-nav-item i { width: 16px; text-align: center; flex-shrink: 0; }

/* Collapsible side-nav sub-items */
.side-nav-toggle { justify-content: flex-start; }
.side-nav-chevron { margin-left: auto; transition: transform .25s; font-size: 11px; }
.side-nav-toggle:not(.collapsed) .side-nav-chevron { transform: rotate(180deg); }
.side-nav-sub .side-nav-item { padding-left: 28px; font-size: 13px; background: var(--gray-50); }
.side-nav-sub .side-nav-item:hover { background: #f0f0f0; color: var(--wine); border-left-color: var(--wine); }
