:root{
  --bg:#0e1116;
  --bg-2:#151a21;
  --bg-3:#1b2129;
  --panel:#171c23;
  --panel-2:#1d232c;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.12);
  --text:#e7eaee;
  --muted:#aab2bc;
  --shadow:0 16px 36px rgba(0,0,0,.38);

  --accent:#c9a45c;
  --accent-2:#8e7443;
  --success:#3f8f6b;
  --warn:#c7a23a;
  --danger:#b85252;

  --chip-bajo:#2f7d60;
  --chip-medio:#c1a039;
  --chip-alto:#b96f25;
  --chip-muy-alto:#af4747;

  --topbar-h:72px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1000px 500px at 15% 0%, rgba(201,164,92,.08) 0%, transparent 55%),
    linear-gradient(180deg, #0d1015 0%, #10141a 100%);
}

.topbar{
  position:sticky;
  top:0;
  z-index:5000;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:var(--topbar-h);
  padding:10px 16px;
  background:rgba(14,17,22,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:0 6px 20px rgba(0,0,0,.18);
}

.topbar .brand,
.topbar h1,
.topbar .title{
  margin:0;
  font-size:18px;
  font-weight:800;
  line-height:1.1;
  letter-spacing:.2px;
  color:#e9ecef;
}

.nav{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.nav a{
  color:#d8dde3;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  opacity:.92;
}
.nav a:hover{color:#f0e2c2}

.footer{
  padding:8px 14px;
  border-top:1px solid var(--line);
  font-size:12px;
  color:var(--muted);
  background:rgba(0,0,0,.08);
}

.layout{
  height:calc(100vh - var(--topbar-h) - 42px);
  display:grid;
  grid-template-columns:380px 1fr;
  position:relative;
}

.sidebar{
  padding:12px;
  overflow:auto;
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(18,22,28,.95), rgba(14,18,24,.95));
}

.mapwrap{
  position:relative;
  height:calc(100vh - var(--topbar-h) - 42px);
  min-height:420px;
  background:#0f1318;
}
.map{position:absolute;inset:0}

.panel{
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    var(--panel);
  border:1px solid var(--line);
  border-radius:20px;
  padding:14px;
  box-shadow:var(--shadow);
}

.panel h2{
  margin:0 0 12px 0;
  font-size:17px;
  font-weight:800;
  color:#ece7dc;
  letter-spacing:.2px;
}

.field{margin:10px 0}
label{
  display:block;
  font-size:12px;
  margin-bottom:6px;
  color:var(--muted);
  font-weight:600;
}

input,select,textarea{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:#11161c;
  color:var(--text);
  font-size:15px;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(201,164,92,.55);
  box-shadow:0 0 0 3px rgba(201,164,92,.14);
  background:#141a21;
}
input::placeholder,textarea::placeholder{color:#7f8a96}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

.minirow{
  display:flex;
  gap:8px;
  margin:8px 0;
  flex-wrap:wrap;
}

.btn{
  cursor:pointer;
  border:1px solid rgba(201,164,92,.22);
  background:linear-gradient(180deg, #a7874f 0%, #876d40 100%);
  color:#f5efe4;
  padding:11px 12px;
  border-radius:13px;
  font-weight:800;
  font-size:14px;
  min-height:44px;
  text-align:center;
  box-shadow:0 8px 18px rgba(0,0,0,.20);
  transition:transform .12s ease, filter .12s ease, border-color .12s ease;
}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:translateY(1px)}

.btn.ghost{
  background:linear-gradient(180deg, #252c35 0%, #1e252d 100%);
  border-color:rgba(255,255,255,.08);
  color:#e0e5ea;
}

.btn.danger{
  background:linear-gradient(180deg, #b85a5a 0%, #934646 100%);
  border-color:rgba(184,90,90,.35);
  color:#fff4f4;
}

.btn.wide{width:100%}

.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.small{font-size:12px;color:var(--muted)}
.hr{
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  margin:14px 0;
}

.floating{
  position:absolute;
  right:12px;
  top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  z-index:3000;
  max-width:72%;
  justify-content:flex-end;
}

.pill{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(18,22,28,.72);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter:blur(6px);
  color:#eef1f4;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}

.tabbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:0 0 12px 0;
}

.tabbtn{
  cursor:pointer;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, #242b34 0%, #1c232b 100%);
  color:#d8dfe5;
  padding:9px 12px;
  border-radius:12px;
  font-weight:700;
  font-size:13px;
  box-shadow:0 6px 14px rgba(0,0,0,.14);
}
.tabbtn.active{
  background:linear-gradient(180deg, #c4a15d 0%, #927442 100%);
  color:#17120a;
  border-color:rgba(201,164,92,.45);
}

.tabpanel{display:none}
.tabpanel.active{display:block}

.mobile-toggle{
  display:none;
  position:absolute;
  left:12px;
  bottom:14px;
  z-index:4600;
  border:1px solid rgba(201,164,92,.24);
  background:linear-gradient(180deg, #b39258 0%, #8a6f42 100%);
  color:#f6f0e5;
  padding:12px 14px;
  border-radius:999px;
  font-weight:800;
  box-shadow:0 12px 24px rgba(0,0,0,.35);
}

.sidebar.mobile-open{transform:translateY(0)!important}

.zone-badge-wrap{background:transparent;border:none}
.zone-badge{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  min-width:110px;
  max-width:180px;
  padding:5px 8px;
  border-radius:11px;
  font-size:11px;
  line-height:1.12;
  box-shadow:0 6px 18px rgba(0,0,0,.30);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(2px);
}
.zone-badge-risk{font-weight:900;text-transform:uppercase}
.zone-badge-name{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:150px;
  font-weight:800;
}
.zone-badge-sub{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:150px;
  font-size:10px;
  opacity:.95;
}

.zone-badge-bajo{background:rgba(47,125,96,.94)}
.zone-badge-medio{background:rgba(193,160,57,.95)}
.zone-badge-alto{background:rgba(185,111,37,.95)}
.zone-badge-muy_alto{background:rgba(175,71,71,.96)}

.link{
  color:#d7c39b;
  text-decoration:none;
  font-weight:700;
}
.link:hover{color:#efe0be}

.inline-suffix{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
}
.inline-suffix span{
  padding:10px 12px;
  border-radius:12px;
  background:#171d24;
  border:1px solid var(--line);
  font-size:13px;
  color:#d8dee5;
}

.stats-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:10px 0;
}

.stat-pill{
  font-size:12px;
  padding:8px 10px;
  border-radius:12px;
  background:linear-gradient(180deg, #1b2128 0%, #161b21 100%);
  border:1px solid rgba(255,255,255,.07);
  color:#d7dde3;
}

.inline-check label{
  display:flex;
  align-items:center;
  gap:8px;
}

.weather-box{
  padding:12px;
  border-radius:14px;
  background:linear-gradient(180deg, #1a2027 0%, #151a20 100%);
  border:1px solid rgba(255,255,255,.08);
  min-height:78px;
  color:#dfe4e9;
}

.danger-text{
  color:#ff9f9f;
  font-weight:800;
}

.risk-color-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:10px 0 14px 0;
}
.risk-chip{
  border:none;
  border-radius:14px;
  padding:12px 10px;
  font-weight:900;
  cursor:pointer;
  min-height:46px;
  box-shadow:0 6px 18px rgba(0,0,0,.22);
  transition:transform .12s ease, filter .12s ease;
}
.risk-chip:hover{filter:brightness(1.04)}
.risk-chip.active{
  outline:3px solid rgba(255,255,255,.72);
  transform:scale(1.02);
}
.risk-chip-bajo{background:var(--chip-bajo);color:#fff}
.risk-chip-medio{background:var(--chip-medio);color:#17140b}
.risk-chip-alto{background:var(--chip-alto);color:#17110a}
.risk-chip-muy_alto{background:var(--chip-muy-alto);color:#fff}

.leaflet-control-zoom a,
.leaflet-draw-toolbar a{
  width:42px !important;
  height:42px !important;
  line-height:42px !important;
  font-size:18px !important;
  background:#f0eee9 !important;
  color:#15181d !important;
  border-bottom:1px solid rgba(0,0,0,.12) !important;
  box-shadow:0 4px 14px rgba(0,0,0,.16);
}

.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
  background:#171c23 !important;
  color:#e8ebef !important;
}
.leaflet-popup-content{
  color:#e8ebef !important;
}

@media (max-width: 900px){
  :root{ --topbar-h: 86px; }

  .topbar{
    align-items:flex-start;
    flex-direction:column;
    justify-content:center;
    gap:8px;
    padding:10px 12px;
  }

  .topbar .brand,
  .topbar h1,
  .topbar .title{
    font-size:16px;
  }

  .nav{
    width:100%;
    justify-content:flex-start;
    gap:14px;
  }
  .nav a{font-size:14px}

  .layout{
    grid-template-columns:1fr;
    height:calc(100vh - var(--topbar-h) - 38px);
  }

  .mapwrap{
    height:calc(100vh - var(--topbar-h) - 38px);
  }

  .mobile-toggle{display:block}

  .sidebar{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    top:auto;
    width:100%;
    max-height:76vh;
    z-index:4300;
    overflow:auto;
    border-right:none;
    border-top:1px solid var(--line);
    background:rgba(15,18,23,.97);
    backdrop-filter:blur(12px);
    padding:10px;
    transform:translateY(105%);
    transition:transform .22s ease;
    border-top-left-radius:18px;
    border-top-right-radius:18px;
    box-shadow:0 -12px 36px rgba(0,0,0,.45);
  }

  .sidebar .panel{
    border-radius:16px;
    padding:12px;
  }

  .grid2,.grid3,.stats-grid,.risk-color-row{
    grid-template-columns:1fr;
  }

  .minirow{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }

  .minirow .btn,
  .minirow a.btn{
    width:100%;
    text-align:center;
  }

  .tabbar{
    display:flex;
    flex-wrap:nowrap;
    overflow:auto;
    padding-bottom:4px;
    scrollbar-width:none;
  }
  .tabbar::-webkit-scrollbar{display:none}
  .tabbtn{
    flex:0 0 auto;
    white-space:nowrap;
  }

  .floating{
    top:10px;
    right:10px;
    left:70px;
    max-width:none;
    gap:6px;
  }

  .pill{
    font-size:11px;
    padding:5px 8px;
  }

  .leaflet-control-container .leaflet-top.leaflet-left{
    top:6px;
  }
}

@media (max-width: 520px){
  :root{ --topbar-h: 92px; }

  .topbar{
    padding:8px 10px;
  }

  .topbar .brand,
  .topbar h1,
  .topbar .title{
    font-size:15px;
  }

  .nav a{font-size:13px}

  .panel{padding:12px}

  input,select,textarea{
    font-size:16px;
    padding:10px 11px;
  }

  .btn{
    font-size:14px;
    padding:10px 11px;
  }

  .minirow{
    grid-template-columns:1fr;
  }

  .mobile-toggle{
    left:10px;
    bottom:10px;
    padding:11px 13px;
    font-size:14px;
  }
}



.worklog-list{
  display:grid;
  gap:10px;
  margin-top:8px;
}

.worklog-card{
  padding:12px;
  border-radius:14px;
  background:linear-gradient(180deg, #1a2027 0%, #151a20 100%);
  border:1px solid rgba(255,255,255,.08);
}

.worklog-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  margin-bottom:6px;
}

.worklog-title{
  font-weight:800;
  color:#ece7dc;
}

.worklog-meta{
  font-size:12px;
  color:var(--muted);
}

.worklog-desc{
  font-size:13px;
  color:#dfe4e9;
  margin:8px 0;
  white-space:pre-wrap;
}



.map-side-toggle{
  position:absolute;
  left:12px;
  top:12px;
  z-index:4600;
  border:1px solid rgba(201,164,92,.24);
  background:linear-gradient(180deg, #b39258 0%, #8a6f42 100%);
  color:#f6f0e5;
  padding:10px 12px;
  border-radius:12px;
  font-weight:800;
  box-shadow:0 12px 24px rgba(0,0,0,.25);
}

@media (min-width: 901px){
  .layout{
    grid-template-columns:340px 1fr;
  }

  body.sidebar-collapsed .layout{
    grid-template-columns:0 1fr;
  }

  body.sidebar-collapsed .sidebar{
    width:0;
    min-width:0;
    padding:0;
    overflow:hidden;
    border-right:none;
    opacity:0;
  }

  body.sidebar-collapsed .mapwrap{
    width:100%;
  }
}

@media (max-width: 900px){
  .map-side-toggle{
    top:auto;
    bottom:64px;
    left:12px;
    border-radius:999px;
  }

  .layout{
    grid-template-columns:1fr !important;
  }

  .mapwrap{
    height:calc(100vh - var(--topbar-h) - 38px) !important;
  }

  .sidebar{
    max-height:68vh !important;
  }
}




/* =========================
   CLIENTE MAPA FULLSCREEN
   ========================= */
.layout-floating-client{
  position:relative;
  grid-template-columns:1fr !important;
  height:calc(100vh - var(--topbar-h) - 38px) !important;
}

.layout-floating-client .mapwrap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.layout-floating-client .map{
  position:absolute;
  inset:0;
}

.layout-floating-client .sidebar{
  position:absolute;
  left:14px;
  top:14px;
  width:min(360px, 42vw);
  max-width:360px;
  max-height:calc(100vh - 120px);
  z-index:4200;
  border-right:none !important;
  background:transparent !important;
  padding:0 !important;
  overflow:visible !important;
}

.layout-floating-client .sidebar .panel{
  background:rgba(18,22,30,.78);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 42px rgba(0,0,0,.34);
}

.floating-client-toggle{
  position:absolute;
  left:14px;
  bottom:18px;
  z-index:4600;
  border:1px solid rgba(201,164,92,.24);
  background:linear-gradient(180deg, #b39258 0%, #8a6f42 100%);
  color:#f6f0e5;
  padding:11px 14px;
  border-radius:999px;
  font-weight:800;
  box-shadow:0 12px 24px rgba(0,0,0,.25);
}

body.client-panel-hidden .layout-floating-client .sidebar{
  display:none;
}

.layout-floating-client .floating{
  right:14px;
  top:14px;
  left:auto;
  max-width:calc(100vw - 28px);
}

@media (max-width: 900px){
  .layout-floating-client .sidebar{
    width:min(82vw, 320px);
    max-width:none;
    max-height:68vh;
    left:10px;
    top:10px;
  }

  .layout-floating-client .sidebar .panel{
    border-radius:20px;
  }

  .floating-client-toggle{
    left:10px;
    bottom:14px;
  }

  .layout-floating-client .floating{
    right:10px;
    top:10px;
    gap:6px;
  }

  .layout-floating-client .floating .pill{
    font-size:11px;
    padding:5px 8px;
  }
}




/* =========================
   ADMIN MAPA FULLSCREEN
   ========================= */
.layout-floating-admin{
  position:relative;
  grid-template-columns:1fr !important;
  height:calc(100vh - var(--topbar-h) - 38px) !important;
}

.layout-floating-admin .mapwrap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.layout-floating-admin .map{
  position:absolute;
  inset:0;
}

.layout-floating-admin .sidebar{
  position:absolute;
  left:14px;
  top:14px;
  width:min(360px, 42vw);
  max-height:calc(100vh - 120px);
  z-index:4200;
  border-right:none !important;
  background:transparent !important;
  padding:0 !important;
}

.layout-floating-admin .sidebar .panel{
  background:rgba(18,22,30,.78);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 42px rgba(0,0,0,.34);
}

.floating-admin-toggle{
  position:absolute;
  left:14px;
  bottom:18px;
  z-index:4600;
  border:1px solid rgba(201,164,92,.24);
  background:linear-gradient(180deg,#b39258,#8a6f42);
  color:#fff;
  padding:10px 14px;
  border-radius:999px;
  font-weight:800;
}

body.admin-panel-hidden .layout-floating-admin .sidebar{
  display:none;
}

@media (max-width:900px){
  .layout-floating-admin .sidebar{
    width:82vw;
    max-height:70vh;
    left:10px;
    top:10px;
  }
}

