@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Fraunces:ital,wght@0,700;0,900&display=swap');

:root {
  --g900:#0d2b1e;--g800:#1a4731;--g700:#21623f;--g600:#2d7a52;--g500:#3a9068;
  --g400:#52b082;--g300:#7ecba1;--g200:#b7e4c7;--g100:#dff2e9;--g50:#f2faf5;
  --white:#ffffff;
  --s50:#f8fafc;--s100:#f1f5f9;--s200:#e2e8f0;--s300:#cbd5e1;
  --s400:#94a3b8;--s500:#64748b;--s700:#334155;--s900:#0f172a;
  --red-bg:#fef2f2;--red:#dc2626;--red-b:#fee2e2;
  --amber-bg:#fffbeb;--amber:#d97706;--amber-b:#fde68a;
  --blue-bg:#eff6ff;--blue:#2563eb;--blue-b:#bfdbfe;
  --sidebar-w:248px;
  --r-lg:16px;--r-md:10px;--r-sm:7px;
  --sh-sm:0 2px 8px rgba(13,43,30,0.07);
  --sh-md:0 8px 28px rgba(13,43,30,0.12);
  --sh-lg:0 24px 64px rgba(0,0,0,0.24);
  --tr:0.18s cubic-bezier(0.4,0,0.2,1);
  --font-ui:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-d:'Fraunces',Georgia,serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{height:100%;}
body{font-family:var(--font-ui);background:var(--s50);color:var(--s900);min-height:100vh;display:flex;}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar-w);background:linear-gradient(175deg,var(--g900) 0%,var(--g800) 55%,var(--g700) 100%);color:white;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;box-shadow:4px 0 32px rgba(0,0,0,0.2);}
.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,0.08);}
.logo-row{display:flex;align-items:center;gap:10px;margin-bottom:4px;}
.logo-ico-wrap{width:38px;height:38px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.16);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.logo-text h2{font-family:var(--font-d);font-size:0.95rem;font-weight:700;line-height:1.3;color:white;}
.logo-text p{font-size:0.63rem;color:rgba(255,255,255,0.48);margin-top:1px;text-transform:uppercase;letter-spacing:0.05em;}
.sidebar-admin{margin:10px 12px;padding:10px 13px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);border-radius:var(--r-md);font-size:0.78rem;}
.sidebar-admin strong{display:block;font-size:0.84rem;color:white;margin-bottom:2px;}
.sidebar-admin span{color:rgba(255,255,255,0.5);font-size:0.7rem;}
.sidebar-nav{flex:1;padding:6px 10px;}
.nav-section-label{font-size:0.6rem;font-weight:700;color:rgba(255,255,255,0.3);text-transform:uppercase;letter-spacing:0.1em;padding:10px 10px 4px;}
.nav-link{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--r-md);color:rgba(255,255,255,0.65);text-decoration:none;font-size:0.84rem;font-weight:500;margin-bottom:2px;transition:all var(--tr);}
.nav-link:hover{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.92);}
.nav-link.active{background:rgba(255,255,255,0.15);color:white;font-weight:600;box-shadow:inset 2px 0 0 rgba(126,203,161,0.6);}
.nav-link svg{flex-shrink:0;opacity:0.75;}
.nav-link.active svg,.nav-link:hover svg{opacity:1;}
.sidebar-foot{padding:12px 10px;border-top:1px solid rgba(255,255,255,0.08);}
.btn-logout{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:var(--r-md);color:rgba(255,255,255,0.75);font-family:var(--font-ui);font-size:0.82rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all var(--tr);}
.btn-logout:hover{background:rgba(220,38,38,0.2);border-color:rgba(220,38,38,0.3);color:white;}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;}
.topbar{background:white;padding:14px 24px;border-bottom:1px solid var(--s100);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--sh-sm);position:sticky;top:0;z-index:100;}
.topbar h1{font-family:var(--font-d);font-size:1.2rem;color:var(--g800);}
.topbar-meta{font-size:0.75rem;color:var(--s400);}
.page-body{padding:20px 24px;flex:1;}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;}
.stat-card{background:white;border-radius:var(--r-lg);padding:18px 20px;border:1px solid var(--s100);box-shadow:var(--sh-sm);display:flex;align-items:center;gap:14px;transition:transform var(--tr),box-shadow var(--tr);}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md);}
.stat-ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-ico.g{background:var(--g100);}
.stat-ico.t{background:#ccfbf1;}
.stat-ico.b{background:var(--blue-bg);}
.stat-val{font-family:var(--font-d);font-size:1.9rem;font-weight:700;color:var(--g800);line-height:1;}
.stat-lbl{font-size:0.74rem;color:var(--s500);margin-top:3px;}

/* ── CARD ── */
.card{background:white;border-radius:var(--r-lg);border:1px solid var(--s100);box-shadow:var(--sh-sm);overflow:hidden;}
.card-head{padding:13px 18px;background:var(--g50);border-bottom:1px solid var(--g100);display:flex;align-items:center;justify-content:space-between;}
.card-head h3{font-size:0.9rem;font-weight:700;color:var(--g800);}
.card-head a{font-size:0.75rem;color:var(--g600);text-decoration:none;font-weight:600;}
.card-head a:hover{text-decoration:underline;}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ── BUTTONS ── */
.btn{padding:9px 16px;border:none;border-radius:var(--r-md);font-family:var(--font-ui);font-size:0.82rem;font-weight:700;cursor:pointer;transition:all var(--tr);display:inline-flex;align-items:center;gap:6px;text-decoration:none;letter-spacing:0.01em;}
.btn-primary{background:linear-gradient(135deg,var(--g900),var(--g600));color:white;box-shadow:0 4px 14px rgba(13,43,30,0.25);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(13,43,30,0.35);}
.btn-sm{padding:6px 11px;font-size:0.75rem;}
.btn-edit{background:var(--g50);color:var(--g700);border:1px solid var(--g200);}
.btn-edit:hover{background:var(--g100);}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b);}
.btn-danger:hover{background:#fee2e2;}
.btn-reset{background:var(--s100);color:var(--s700);border:1px solid var(--s200);}

/* ── ALERTS ── */
.alert{padding:11px 14px;border-radius:var(--r-md);font-size:0.82rem;margin-bottom:16px;font-weight:500;display:flex;align-items:flex-start;gap:8px;}
.alert svg{flex-shrink:0;margin-top:1px;}
.alert-success{background:var(--g50);color:var(--g800);border:1px solid var(--g200);}
.alert-error{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b);}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead th{text-align:left;padding:10px 14px;font-size:0.71rem;font-weight:700;color:var(--s500);text-transform:uppercase;letter-spacing:0.06em;background:var(--g50);border-bottom:1px solid var(--g100);}
tbody td{padding:11px 14px;font-size:0.82rem;border-bottom:1px solid var(--s100);vertical-align:middle;}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:var(--g50);}
.mono{font-family:'Courier New',monospace;font-size:0.75rem;color:var(--g600);}
.text-dim{color:var(--s400);}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:0.69rem;font-weight:700;white-space:nowrap;}
.badge-login{background:#dcfce7;color:#166534;}
.badge-logout{background:var(--red-bg);color:var(--red);}
.badge-register{background:var(--blue-bg);color:var(--blue);}
.badge-add{background:var(--g100);color:var(--g800);}
.badge-edit{background:var(--amber-bg);color:var(--amber);}
.badge-delete{background:var(--red-bg);color:var(--red);}
.badge-failed{background:#fce7f3;color:#9d174d;}
.badge-active{background:#dcfce7;color:#166534;}
.badge-default{background:var(--s100);color:var(--s700);}

/* ── LOG LIST ── */
.log-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--s100);font-size:0.8rem;}
.log-item:last-child{border-bottom:none;}
.log-who{font-weight:700;color:var(--s900);}
.log-what{color:var(--s500);margin-top:1px;font-size:0.77rem;}
.log-time{font-size:0.68rem;color:var(--s400);margin-top:3px;}
.spot-row{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--s100);font-size:0.82rem;}
.spot-row:last-child{border-bottom:none;}
.spot-row .s-name{font-weight:700;color:var(--g800);}
.spot-row .s-coord{font-size:0.69rem;color:var(--s400);font-family:'Courier New',monospace;margin-top:2px;}

/* ── FORMS ── */
.form-group{margin-bottom:14px;}
.form-group label{display:block;font-size:0.78rem;font-weight:700;color:var(--g800);margin-bottom:5px;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:9px 12px;border:1.5px solid var(--s200);border-radius:var(--r-md);font-family:var(--font-ui);font-size:0.85rem;color:var(--s900);background:var(--s50);outline:none;transition:border-color var(--tr),box-shadow var(--tr);}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--g400);background:white;box-shadow:0 0 0 3px rgba(58,144,104,0.1);}
.form-group textarea{resize:vertical;min-height:86px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-hint{font-size:0.71rem;color:var(--s400);margin-top:4px;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.55);z-index:500;align-items:center;justify-content:center;backdrop-filter:blur(3px);}
.modal-overlay.open{display:flex;}
.modal-box{background:white;border-radius:20px;padding:28px 26px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--sh-lg);animation:mIn 0.2s ease;}
@keyframes mIn{from{opacity:0;transform:translateY(10px) scale(0.97);}to{opacity:1;transform:none;}}
.modal-box h2{font-family:var(--font-d);color:var(--g800);font-size:1.2rem;margin-bottom:18px;}
.modal-foot{display:flex;gap:8px;margin-top:16px;}
.btn-cancel{padding:9px 16px;background:var(--s100);color:var(--s700);border:none;border-radius:var(--r-md);font-family:var(--font-ui);font-size:0.84rem;font-weight:600;cursor:pointer;transition:background var(--tr);}
.btn-cancel:hover{background:var(--s200);}
#miniMap{height:185px;border-radius:var(--r-md);border:1.5px solid var(--s200);margin-top:6px;overflow:hidden;}

/* ── FILTER BAR ── */
.filter-bar{background:white;border-radius:var(--r-lg);padding:13px 16px;border:1px solid var(--s100);box-shadow:var(--sh-sm);margin-bottom:16px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.filter-group{display:flex;flex-direction:column;gap:4px;}
.filter-group label{font-size:0.73rem;font-weight:700;color:var(--g800);}
.filter-group select,.filter-group input{padding:7px 11px;border:1.5px solid var(--s200);border-radius:var(--r-md);font-family:var(--font-ui);font-size:0.82rem;background:var(--s50);outline:none;transition:border-color var(--tr);}
.filter-group select:focus,.filter-group input:focus{border-color:var(--g400);}

/* ── PAGINATION ── */
.pagination{display:flex;gap:4px;align-items:center;justify-content:center;margin-top:16px;}
.pag-btn{padding:6px 11px;border-radius:var(--r-sm);text-decoration:none;font-size:0.79rem;font-weight:600;border:1px solid var(--s200);color:var(--g700);background:white;transition:all var(--tr);}
.pag-btn:hover,.pag-btn.cur{background:var(--g700);color:white;border-color:var(--g700);}

/* ── LOGIN ── */
body.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(145deg,var(--g900) 0%,var(--g800) 50%,var(--g700) 100%);position:relative;overflow:hidden;}
body.login-body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(58,144,104,0.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(126,203,161,0.06) 0%,transparent 40%);pointer-events:none;}
.login-card{background:white;border-radius:22px;padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--sh-lg);position:relative;z-index:1;}
.login-ico{width:58px;height:58px;background:linear-gradient(135deg,var(--g900),var(--g600));border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 24px rgba(13,43,30,0.32);}
.login-card h1{font-family:var(--font-d);color:var(--g800);font-size:1.65rem;text-align:center;margin-bottom:4px;}
.login-subtitle{text-align:center;color:var(--s400);font-size:0.8rem;margin-bottom:24px;}
.login-card .btn-primary{width:100%;padding:12px;justify-content:center;font-size:0.9rem;margin-top:4px;}
.toggle-row{text-align:center;margin-top:18px;font-size:0.8rem;color:var(--s500);}
.toggle-row a{color:var(--g600);text-decoration:none;font-weight:700;}
.toggle-row a:hover{text-decoration:underline;}

/* ── RESPONSIVE ── */
@media(max-width:900px){.stats-grid{grid-template-columns:1fr 1fr;}.dash-grid{grid-template-columns:1fr;}}
@media(max-width:640px){.stats-grid{grid-template-columns:1fr;}.filter-bar{flex-direction:column;align-items:stretch;}}

/* ═══════════════════════════════════════════════
   RESPONSIVE — ADMIN PANEL
═══════════════════════════════════════════════ */

/* ── MOBILE SIDEBAR TOGGLE BUTTON ── */
.mob-menu-btn {
  display: none;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--r-sm);
  color: white; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  flex-shrink: 0;
}

/* ── MOBILE TOP BAR (admin) ── */
.admin-mob-bar {
  display: none;
  position: fixed; top: 0; left: 0; right: 0;
  height: 54px; z-index: 300;
  background: linear-gradient(135deg, var(--g900), var(--g700));
  padding: 0 14px;
  align-items: center; justify-content: space-between;
  box-shadow: 0 2px 12px rgba(0,0,0,.2);
}
.admin-mob-bar h1 {
  font-family: var(--font-d); font-size: .95rem; color: white; font-weight: 700;
}

/* ── OVERLAY SCRIM ── */
.admin-scrim {
  display: none;
  position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 199;
  backdrop-filter: blur(2px);
  opacity: 0; transition: opacity .3s; pointer-events: none;
}
.admin-scrim.show { opacity: 1; pointer-events: auto; }

/* ── SIDEBAR RESPONSIVE ── */
@media (max-width: 900px) {
  /* Show mobile top bar */
  .admin-mob-bar { display: flex; }
  .mob-menu-btn  { display: flex; }

  /* Sidebar slides off-canvas */
  .sidebar {
    transform: translateX(-100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    z-index: 250;
  }
  .sidebar.mob-open { transform: translateX(0); }

  /* Main occupies full width */
  .main { margin-left: 0; }

  /* Offset content below mobile bar */
  .topbar {
    padding-top: 68px; /* 54px bar + padding */
    position: static;
  }
  .page-body { padding: 16px; }

  /* Stats: 2-col then 1-col */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .dash-grid  { grid-template-columns: 1fr; gap: 14px; }

  /* Filter bar stacks */
  .filter-bar { flex-direction: column; align-items: stretch; gap: 10px; }
  .filter-group select, .filter-group input { width: 100%; }

  /* Table horizontal scroll */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { min-width: 520px; }

  /* Modal full-width on mobile */
  .modal-box { padding: 22px 18px; border-radius: 16px 16px 0 0; max-height: 92vh; }
  .modal-overlay.open { align-items: flex-end; }
}

@media (max-width: 540px) {
  .stats-grid { grid-template-columns: 1fr; }
  .topbar h1  { font-size: 1rem; }
  .btn        { font-size: .78rem; padding: 8px 12px; }
  .btn-sm     { font-size: .72rem; padding: 5px 9px; }
  .form-row   { grid-template-columns: 1fr; }

  /* Login card on small phones */
  .login-card { padding: 30px 20px; border-radius: 16px; }
  .login-card h1 { font-size: 1.4rem; }

  /* Topbar back to normal flow since bar is fixed */
  .topbar { padding-top: 58px; }
}

/* ── ENSURE TOPBAR STICKY STILL WORKS ON DESKTOP ── */
@media (min-width: 901px) {
  .admin-mob-bar { display: none; }
  .admin-scrim   { display: none !important; }
}
