/* Marama West Campaign — App Styles */
:root {
    --mw-green: #1a7a4a;
    --mw-gold:  #d4a017;
  }
  
  body { min-height: 100vh; display: flex; flex-direction: column; background: #f5f7fa; font-size: 0.93rem; }
  
  /* Navbar accent */
  .navbar.bg-primary { background: linear-gradient(135deg, #1565C0 0%, #0d47a1 100%) !important; }
  
  /* Stat cards */
  .stat-card { border: none; border-radius: 12px; transition: transform .15s; }
  .stat-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.12); }
  .stat-icon { width: 52px; height: 52px; border-radius: 10px; display:flex; align-items:center; justify-content:center; font-size: 1.5rem; }
  
  /* Tables */
  .table-hover tbody tr:hover { background: #eef2ff; }
  .table th { font-size: .8rem; text-transform: uppercase; letter-spacing: .04em; color: #6c757d; border-bottom: 2px solid #dee2e6; }
  
  /* Support badges */
  .badge-strong    { background:#198754; color:#fff; }
  .badge-medium    { background:#0d6efd; color:#fff; }
  .badge-weak      { background:#fd7e14; color:#fff; }
  .badge-undecided { background:#e9ecef; color:#495057; }
  
  /* Sidebar layout */
  .page-wrapper { display: flex; flex: 1; }
  .sidebar { width: 240px; min-height: calc(100vh - 56px); background: #fff; border-right: 1px solid #dee2e6; flex-shrink:0; }
  .main-content { flex: 1; padding: 1.5rem; overflow-x: hidden; }
  
  /* Result cards */
  .result-card { border-left: 4px solid #1565C0; }
  .screenshot-thumb { width: 100px; height: 70px; object-fit: cover; border-radius: 6px; cursor: pointer; border: 2px solid #dee2e6; }
  .screenshot-thumb:hover { border-color: #1565C0; }
  
  /* Form cards */
  .form-card { background:#fff; border-radius: 12px; padding: 1.75rem; box-shadow: 0 2px 12px rgba(0,0,0,.07); }
  
  /* Progress bar tally */
  .tally-bar { height: 22px; border-radius: 8px; }
  
  /* Mobile offcanvas menu (below lg the navbar becomes a slide-in panel) */
  @media (max-width: 991.98px) {
    .navbar-offcanvas {
      background: linear-gradient(160deg, #1565C0 0%, #0d47a1 100%);
      color: #fff;
      width: 290px;
    }
    .navbar-offcanvas .offcanvas-header { border-bottom: 1px solid rgba(255,255,255,.2); }
    .navbar-offcanvas .offcanvas-title { color: #fff; font-size: 1rem; }
    .navbar-offcanvas .nav-link { color: rgba(255,255,255,.9); padding: .65rem .25rem; font-size: 1.02rem; }
    .navbar-offcanvas .nav-link:hover,
    .navbar-offcanvas .nav-link.show { color: #fff; }
    .navbar-offcanvas .nav-item { border-bottom: 1px solid rgba(255,255,255,.08); }
    .navbar-offcanvas .dropdown-menu {
      background: rgba(0,0,0,.18);
      border: 0;
      box-shadow: none;
      margin-bottom: .5rem;
    }
    .navbar-offcanvas .dropdown-item { color: rgba(255,255,255,.85); padding: .5rem 1rem; }
    .navbar-offcanvas .dropdown-item:hover,
    .navbar-offcanvas .dropdown-item:active { background: rgba(255,255,255,.12); color: #fff; }
    .navbar-offcanvas .dropdown-divider { border-color: rgba(255,255,255,.2); }
    .navbar-offcanvas .navbar-user { flex-wrap: wrap; }
  }

  /* Mobile responsiveness */
  @media (max-width: 768px) {
    .sidebar { display: none; }
    .main-content { padding: .75rem; }
    .stat-card .fs-2 { font-size: 1.4rem !important; }
    .stat-card .fs-4 { font-size: 1.15rem !important; }
    .stat-icon { width: 42px; height: 42px; font-size: 1.2rem; }
    .table { font-size: .85rem; }
    .form-card { padding: 1rem; }
    h4, h5 { font-size: 1.05rem; }
    .btn-sm { white-space: nowrap; }
  }
  
  /* Security alert levels */
  .alert-level-red    { background:#dc3545; color:#fff; }
  .alert-level-amber  { background:#fd7e14; color:#fff; }
  .alert-level-yellow { background:#ffc107; color:#212529; }

  /* Security widget panel (admin + security desk) */
  .security-widget-panel {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    z-index: 1050;
    display: flex;
    flex-direction: column;
    gap: .6rem;
    max-width: 220px;
  }
  .security-widget {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .15rem;
    padding: .75rem 1rem;
    border: 3px solid #fff;
    border-radius: 12px;
    color: #fff;
    font-weight: 700;
    box-shadow: 0 4px 20px rgba(0,0,0,.35);
    text-align: center;
    width: 100%;
  }
  .security-widget-red    { background: #dc3545; }
  .security-widget-amber  { background: #fd7e14; }
  .security-widget-yellow { background: #e6a800; color: #212529; }
  .security-widget .widget-name { font-size: 1rem; line-height: 1.2; }
  .security-widget .widget-level { font-size: .7rem; opacity: .9; text-transform: uppercase; }
  .security-widget .widget-pulse { font-size: .65rem; letter-spacing: .08em; }
  .security-widget.blinking { animation: sec-blink 1s ease-in-out infinite; }
  @keyframes sec-blink {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: .65; transform: scale(1.04); box-shadow: 0 0 30px rgba(220,53,69,.8); }
  }
  .alert-bell-menu { max-height: 400px; overflow-y: auto; }

  /* Search highlight */
  mark { background: #fff3cd; padding: 0 2px; border-radius: 3px; }
  
  /* Print styles for results */
  @media print {
    .navbar, .sidebar, .btn, .no-print { display: none !important; }
    .main-content { padding: 0; }
  }