/* FTTH Monitor v7 - Modern UI (Light/Dark)
   Overrides legacy styles in css/style1.css
*/

:root{
  --bg: #f5f7fb;
  --bg2: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --border: rgba(15,23,42,0.12);
  --shadow: 0 12px 40px rgba(2,6,23,0.12);
  --card: rgba(255,255,255,0.72);
  --cardSolid: #ffffff;
  --primary: #2563eb;
  --primary2: #1d4ed8;
  --danger: #ef4444;
  --radius: 18px;
}

html[data-theme="dark"]{
  --bg: #0b1220;
  --bg2: #0f172a;
  --text: #e5e7eb;
  --muted: #94a3b8;
  --border: rgba(148,163,184,0.18);
  --shadow: 0 18px 50px rgba(0,0,0,0.50);
  --card: rgba(15,23,42,0.65);
  --cardSolid: #0f172a;
  --primary: #60a5fa;
  --primary2: #3b82f6;
  --danger: #f87171;
}

html, body{
  background: var(--bg);
  color: var(--text);
}

a{ color: var(--primary); }

#map{
  border-radius: var(--radius);
}

#leftPanel, #menu, #panel, #AddNode, #FormLogin{
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--border) !important;
  background: var(--card) !important;
  backdrop-filter: blur(10px);
}

#AddNodeheader, #FormLoginheader{
  border-bottom: 1px solid var(--border);
  position: relative;
}

input, select{
  border-radius: 14px !important;
  border: 1px solid var(--border) !important;
  background: var(--cardSolid) !important;
  color: var(--text) !important;
  padding: 10px 12px !important;
  outline: none;
}

html[data-theme="dark"] input,
html[data-theme="dark"] select{
  background: rgba(2,6,23,0.35) !important;
}

label{
  color: var(--muted) !important;
  font-weight: 600;
}

.formBtn, .btn, button{
  border-radius: 14px !important;
}

.formBtn{
  background: var(--primary) !important;
  border: 1px solid var(--primary2) !important;
  color: #fff !important;
  padding: 10px 14px !important;
  transition: transform .15s ease, filter .15s ease;
}

.formBtn:hover{ filter: brightness(1.05); }
.formBtn:active{ transform: scale(0.98); }

.theme-toggle{
  position: absolute;
  top: 12px;
  right: 12px;
  width: 42px;
  height: 42px;
  border-radius: 999px !important;
  border: 1px solid var(--border) !important;
  background: var(--cardSolid) !important;
  box-shadow: 0 10px 25px rgba(2,6,23,0.10);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  user-select: none;
}

html[data-theme="dark"] .theme-toggle{
  background: rgba(2,6,23,0.35) !important;
}

.theme-toggle.floating{
  position: fixed;
  top: auto;
  right: 16px;
  bottom: 16px;
  z-index: 99999;
}

#snackbar{
  border-radius: 999px !important;
  box-shadow: var(--shadow) !important;
}

.jconfirm .jconfirm-box{
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
}

.jconfirm .jconfirm-box .jconfirm-title-c{
  color: var(--text) !important;
}

.jconfirm .jconfirm-box{
  background: var(--cardSolid) !important;
}

html[data-theme="dark"] .jconfirm .jconfirm-box{
  background: #0b1220 !important;
}

/* === GoogleDark mode (CSS filter over Google tiles) === */
#map.google-dark { background: #000; }
#map.google-dark .leaflet-tile {
  /* Creates a readable dark theme from Google "m" tiles.
     Tune if needed: increase brightness for lighter, contrast for punchier. */
  filter: invert(100%) hue-rotate(180deg) brightness(85%) contrast(120%) saturate(85%);
}
#map.google-dark .leaflet-control-attribution {
  /* Attribution stays readable after tile inversion */
  filter: invert(100%) hue-rotate(180deg);
}
