/* BeesMonitor™ Modern UI Layer - PHP 8.4 package */
:root {
  --bm-bg: #f6f4ec;
  --bm-bg-soft: #fffaf0;
  --bm-card: rgba(255, 255, 255, 0.92);
  --bm-card-solid: #ffffff;
  --bm-text: #1f2933;
  --bm-muted: #667085;
  --bm-border: rgba(31, 41, 51, 0.10);
  --bm-shadow: 0 18px 45px rgba(34, 24, 7, 0.12);
  --bm-shadow-soft: 0 10px 24px rgba(34, 24, 7, 0.09);
  --bm-honey: #f2a900;
  --bm-honey-2: #ffd166;
  --bm-amber: #b66b00;
  --bm-green: #1f9d55;
  --bm-red: #d92d20;
  --bm-blue: #2563eb;
  --bm-radius-lg: 24px;
  --bm-radius: 16px;
  --bm-radius-sm: 10px;
  --bm-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Noto Sans", sans-serif;
}

html { scroll-behavior: smooth; }
html, body { min-height: 100%; }
body {
  margin: 0;
  font-family: var(--bm-font) !important;
  color: var(--bm-text);
  background:
    radial-gradient(circle at top left, rgba(255, 209, 102, 0.35), transparent 34rem),
    radial-gradient(circle at top right, rgba(242, 169, 0, 0.18), transparent 34rem),
    linear-gradient(135deg, #fff8e6 0%, #f7f4ea 48%, #eef5ed 100%) !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(30deg, rgba(114, 72, 0, 0.035) 12%, transparent 12.5%, transparent 87%, rgba(114, 72, 0, 0.035) 87.5%, rgba(114, 72, 0, 0.035)),
    linear-gradient(150deg, rgba(114, 72, 0, 0.035) 12%, transparent 12.5%, transparent 87%, rgba(114, 72, 0, 0.035) 87.5%, rgba(114, 72, 0, 0.035));
  background-size: 36px 62px;
  opacity: .55;
  z-index: -1;
}

a { color: #7a4b00; }
a:hover, a:focus { color: #111827; text-decoration: none; }

/* Layout shell */
.main,
.container,
.container-fluid {
  max-width: 1440px;
}
.main {
  width: min(100% - 24px, 1440px);
  margin: 18px auto 36px auto !important;
  padding: 0 !important;
}

/* Top navigation, old Bootstrap navs */
.navbar,
.navbar-default,
.navbar-inverse,
.navbar-fixed-top,
nav,
.topbar,
.header-area {
  border: 0 !important;
  box-shadow: var(--bm-shadow-soft) !important;
}
.navbar,
.navbar-default,
.navbar-inverse {
  background: rgba(38, 28, 4, 0.88) !important;
  backdrop-filter: blur(16px);
  border-radius: 0 0 22px 22px !important;
}
.navbar a,
.navbar .navbar-brand,
.navbar-nav > li > a {
  color: #fff8e7 !important;
  font-weight: 650;
}
.navbar .navbar-brand {
  letter-spacing: -0.03em;
}
.navbar-toggle { border-color: rgba(255,255,255,.22) !important; }
.navbar-toggle .icon-bar { background: #fff !important; }

/* Cards / panels */
.panel,
.well,
.box,
.card,
.modal-content,
.login-form .panel-login,
.dataTables_wrapper,
.bm-card {
  background: var(--bm-card) !important;
  border: 1px solid var(--bm-border) !important;
  border-radius: var(--bm-radius-lg) !important;
  box-shadow: var(--bm-shadow) !important;
  overflow: hidden;
}
.panel-heading,
.box-header,
.card-header {
  background: linear-gradient(135deg, rgba(255, 209, 102, .32), rgba(255,255,255,.82)) !important;
  border-bottom: 1px solid var(--bm-border) !important;
  color: #2d2207 !important;
  font-weight: 800;
}
.panel-body,
.box-body,
.card-body { padding: clamp(14px, 2vw, 24px) !important; }

/* Info blocks inside old grid */
[class*="col-xs-"], [class*="col-sm-"], [class*="col-md-"], [class*="col-lg-"] {
  min-width: 0;
}
.panel .col-xs-12,
.panel .col-sm-4,
.panel .col-md-4,
.panel .col-lg-4 {
  word-break: break-word;
}

/* Buttons */
.btn,
button,
input[type="submit"],
input[type="button"] {
  border-radius: 999px !important;
  font-weight: 750 !important;
  letter-spacing: -0.01em;
  transition: transform .16s ease, box-shadow .16s ease, opacity .16s ease;
}
.btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover {
  transform: translateY(-1px);
}
.btn-primary,
.btn-login,
.btn-radar,
.btn-device,
.btn-weather-radar {
  background: linear-gradient(135deg, #f2a900, #b66b00) !important;
  border-color: transparent !important;
  color: #1d1300 !important;
  box-shadow: 0 10px 22px rgba(242,169,0,.24) !important;
}
.btn-success,
.btn-weather {
  background: linear-gradient(135deg, #22c55e, #15803d) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.btn-danger { background: linear-gradient(135deg, #ef4444, #b91c1c) !important; border-color: transparent !important; }
.btn-default,
.btn-secondary,
.btn-tables,
.btn-graphics {
  background: #ffffff !important;
  border: 1px solid var(--bm-border) !important;
  color: var(--bm-text) !important;
}

/* Forms */
.form-control,
input[type="text"], input[type="password"], input[type="email"], input[type="number"], input[type="date"], input[type="search"], input[type="tel"], select, textarea {
  border-radius: 14px !important;
  border: 1px solid rgba(31,41,51,.14) !important;
  background: rgba(255,255,255,.9) !important;
  box-shadow: none !important;
  min-height: 44px;
  color: var(--bm-text) !important;
}
.form-control:focus,
input:focus,
select:focus,
textarea:focus {
  border-color: var(--bm-honey) !important;
  box-shadow: 0 0 0 4px rgba(242,169,0,.16) !important;
  outline: none !important;
}
label { color: #344054; font-weight: 700; }

/* Tables */
table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
  width: 100%;
}
table th {
  background: #fff2c7 !important;
  color: #3d2b03 !important;
  font-size: 12px;
  letter-spacing: .02em;
  text-transform: uppercase;
}
table th,
table td {
  border-color: rgba(31,41,51,.08) !important;
  vertical-align: middle !important;
}
table tbody tr {
  transition: background .16s ease;
}
table tbody tr:hover {
  background: rgba(255, 209, 102, .14) !important;
}
.table-responsive {
  border: 0 !important;
  border-radius: var(--bm-radius) !important;
  overflow: auto;
}
.dataTables_wrapper {
  padding: 14px;
}
.dataTables_filter input,
.dataTables_length select {
  margin-left: 8px;
}

/* Status text helpers */
.text-success, .green, .positive, [style*="#00FF00"], [style*="00FF00"] { color: var(--bm-green) !important; }
.text-danger, .red, .negative, [style*="#FF0000"], [style*="FF0000"] { color: var(--bm-red) !important; }
.text-primary, .blue { color: var(--bm-blue) !important; }

/* Modern login */
body.bm-login-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 18px;
}
.bm-login-shell {
  width: min(1120px, 100%);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 24px;
  align-items: stretch;
}
.bm-login-hero,
.bm-login-card {
  border-radius: 30px;
  border: 1px solid var(--bm-border);
  box-shadow: var(--bm-shadow);
  overflow: hidden;
}
.bm-login-hero {
  min-height: 620px;
  padding: clamp(24px, 4vw, 48px);
  color: #fff7df;
  background:
    linear-gradient(135deg, rgba(36,24,0,.88), rgba(120,74,0,.86)),
    radial-gradient(circle at 20% 15%, rgba(255,209,102,.42), transparent 20rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
}
.bm-login-hero::after {
  content: "🐝";
  position: absolute;
  right: 28px;
  bottom: 24px;
  font-size: clamp(70px, 12vw, 140px);
  opacity: .18;
}
.bm-login-brand {
  font-size: clamp(32px, 4vw, 54px);
  font-weight: 900;
  letter-spacing: -0.06em;
  line-height: .95;
}
.bm-login-brand span { color: var(--bm-honey-2); }
.bm-login-subtitle {
  margin-top: 16px;
  color: rgba(255,248,231,.84);
  font-size: clamp(16px, 2vw, 20px);
  max-width: 42ch;
}
.bm-login-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 26px;
}
.bm-login-stat {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 18px;
  padding: 16px;
  backdrop-filter: blur(12px);
}
.bm-login-stat strong { display: block; font-size: 22px; color: #fff; }
.bm-login-stat small { color: rgba(255,248,231,.78); }
.bm-login-card {
  background: rgba(255,255,255,.96);
  padding: clamp(20px, 3vw, 34px);
}
.bm-auth-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: #f3ead2;
  border-radius: 999px;
  padding: 5px;
  gap: 4px;
  margin: 18px 0 22px;
}
.bm-auth-tabs a {
  text-align: center;
  padding: 10px 8px;
  border-radius: 999px;
  color: #6b520f;
  font-weight: 850;
}
.bm-auth-tabs a.active {
  background: #fff;
  box-shadow: 0 6px 16px rgba(37, 24, 3, .12);
  color: #1f1600;
}
.bm-form-help { color: var(--bm-muted); font-size: 13px; margin-top: -8px; margin-bottom: 12px; }
.bm-honeypot { position: absolute; left: -9999px; opacity: 0; height: 0; width: 0; }
.bm-version { color: var(--bm-muted); font-size: 12px; margin-top: 18px; text-align: center; }

/* Dashboard helper widgets */
.bm-page-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 16px 0;
  padding: 18px 20px;
  background: rgba(255,255,255,.64);
  border: 1px solid var(--bm-border);
  border-radius: var(--bm-radius-lg);
  box-shadow: var(--bm-shadow-soft);
}
.bm-page-title h1, .bm-page-title h2, .bm-page-title h3 { margin: 0; letter-spacing: -0.04em; }
.bm-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.bm-kpi {
  padding: 18px;
  border-radius: var(--bm-radius-lg);
  background: var(--bm-card);
  border: 1px solid var(--bm-border);
  box-shadow: var(--bm-shadow-soft);
}
.bm-kpi small { color: var(--bm-muted); font-weight: 750; text-transform: uppercase; letter-spacing: .03em; }
.bm-kpi strong { display: block; margin-top: 8px; font-size: clamp(24px, 3vw, 38px); letter-spacing: -0.06em; }

/* Maps/charts */
canvas, svg, #mapid, .leaflet-container, iframe {
  max-width: 100%;
  border-radius: var(--bm-radius) !important;
}
#mapid, .leaflet-container { box-shadow: var(--bm-shadow-soft); border: 1px solid var(--bm-border); }

/* Mobile-first repairs for old Bootstrap */
@media (max-width: 991px) {
  .bm-login-shell { grid-template-columns: 1fr; }
  .bm-login-hero { min-height: auto; }
  .bm-login-stats { grid-template-columns: 1fr; }
  .main { width: min(100% - 16px, 1440px); margin-top: 10px !important; }
  .panel-body { padding: 14px !important; }
  .bm-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .button-bar, .bees-toolbar { justify-content: flex-start !important; overflow-x: auto; padding-bottom: 8px; flex-wrap: nowrap !important; }
  .button-bar .btn, .bees-toolbar .btn { white-space: nowrap; }
}

@media (max-width: 640px) {
  body { font-size: 15px; }
  .bm-login-card { padding: 18px; border-radius: 24px; }
  .bm-login-hero { padding: 24px; border-radius: 24px; }
  .bm-auth-tabs { grid-template-columns: 1fr; border-radius: 18px; }
  .bm-auth-tabs a { border-radius: 14px; }
  .bm-kpi-grid { grid-template-columns: 1fr; }
  .panel, .well, .box, .card, .modal-content, .dataTables_wrapper { border-radius: 18px !important; }
  .table-mini, table { font-size: 12px; }
  .dataTables_wrapper { overflow-x: auto; }
  .form-control { font-size: 16px !important; }
}

@media (prefers-color-scheme: dark) {
  body:not(.bm-login-page) {
    background: radial-gradient(circle at top left, rgba(242,169,0,.16), transparent 32rem), linear-gradient(135deg, #17130b, #1b1d17) !important;
    color: #f7f1df;
  }
  body:not(.bm-login-page) .panel,
  body:not(.bm-login-page) .well,
  body:not(.bm-login-page) .box,
  body:not(.bm-login-page) .card,
  body:not(.bm-login-page) .dataTables_wrapper,
  body:not(.bm-login-page) .bm-card,
  body:not(.bm-login-page) .bm-kpi,
  body:not(.bm-login-page) .bm-page-title {
    background: rgba(31, 28, 21, .88) !important;
    color: #f7f1df !important;
    border-color: rgba(255,255,255,.10) !important;
  }
  body:not(.bm-login-page) .form-control,
  body:not(.bm-login-page) input,
  body:not(.bm-login-page) select,
  body:not(.bm-login-page) textarea {
    background: rgba(255,255,255,.08) !important;
    color: #f7f1df !important;
    border-color: rgba(255,255,255,.14) !important;
  }
  body:not(.bm-login-page) table th { background: rgba(242,169,0,.28) !important; color: #fff4d5 !important; }
  body:not(.bm-login-page) table tbody tr:hover { background: rgba(242,169,0,.10) !important; }
}
