/* nav.css — Navegación: mapa real (Leaflet) con estilo pergamino + plan de viaje */

.nav-map-wrap{position:relative;}
#nav-map{height:340px;width:100%;border-radius:8px;overflow:hidden;
  border:2px solid var(--border2);box-shadow:0 4px 14px rgba(0,0,0,.4);background:#e8d29a;}

/* Botón de pantalla completa */
.nav-fs-btn{position:absolute;top:8px;right:8px;z-index:500;width:36px;height:36px;
  border:1px solid #6b4a23;border-radius:6px;background:rgba(244,228,186,.95);color:#5a3a18;
  font-size:16px;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.nav-fs-btn:hover{background:#f4e4ba;}

/* Botón de orientación + flecha norte */
.nav-orient-btn{position:absolute;top:52px;right:8px;z-index:500;width:36px;height:36px;
  border:1px solid #6b4a23;border-radius:6px;background:rgba(244,228,186,.95);color:#5a3a18;
  font-family:'Cinzel',serif;font-size:12px;font-weight:700;cursor:pointer;
  box-shadow:0 1px 4px rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;}
.nav-orient-btn:hover{background:#f4e4ba;}
.nav-northarrow{position:absolute;left:8px;bottom:8px;z-index:500;width:34px;height:34px;border-radius:50%;
  background:rgba(244,228,186,.92);border:1px solid #6b4a23;display:flex;flex-direction:column;
  align-items:center;justify-content:center;color:#c0392b;font-size:12px;line-height:.85;
  pointer-events:none;box-shadow:0 1px 4px rgba(0,0,0,.35);transition:transform .2s ease;}
.nav-northarrow span{color:#5a3a18;font-size:8px;font-weight:700;}

/* Rotación del mapa (Head/Course Up): giro + escala para cubrir las esquinas,
   sin cambiar el tamaño del contenedor (evita que el mapa se colapse). */
.nav-map-wrap.rot{overflow:hidden;}
.nav-map-wrap.rot #nav-map{transform:rotate(var(--rot,0deg)) scale(1.45);transform-origin:50% 50%;}
.nav-map-wrap.rot .wp-emoji,.nav-map-wrap.rot .gps-badge{transform:rotate(calc(-1 * var(--rot,0deg)));}

/* Modo pantalla completa (CSS, fiable en iOS) */
.nav-map-wrap.fs{position:fixed;inset:0;z-index:99999;background:#051828;border-radius:0;}
.nav-map-wrap.fs #nav-map{height:100%;border-radius:0;border:none;}
.nav-map-wrap.fs .nav-fs-btn{top:calc(12px + env(safe-area-inset-top));
  right:calc(12px + env(safe-area-inset-right));width:46px;height:46px;font-size:20px;z-index:100000;
  background:#c0392b;color:#fff;border-color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.5);}

/* Tinte pergamino sobre los mosaicos del mapa real */
#nav-map .leaflet-tile-pane{
  filter:sepia(.55) saturate(.78) contrast(.96) brightness(1.03) hue-rotate(-8deg);
}
#nav-map .leaflet-control-attribution{font-size:9px;background:rgba(244,228,186,.85);}
#nav-map .leaflet-bar a{background:rgba(244,228,186,.95);color:#5a3a18;border-color:#6b4a23;}

/* Marca (waypoint) con emoji + número */
.wp-div{background:none;border:none;}
.wp-emoji{position:relative;width:34px;height:34px;border-radius:50%;
  background:rgba(244,228,186,.95);border:2px solid #c0392b;box-shadow:0 1px 5px rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;}
.wp-emoji-n{position:absolute;top:-5px;right:-5px;min-width:15px;height:15px;padding:0 3px;
  border-radius:8px;background:#c0392b;color:#fff;font-family:'Cinzel',serif;font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;border:1px solid #f4e4ba;}
/* Nombre de la marca en el mapa (a la derecha del emoji) */
.wp-mlabel{position:absolute;left:calc(100% + 3px);top:50%;transform:translateY(-50%);white-space:nowrap;
  background:rgba(5,24,40,.82);color:#f4e4ba;font-family:'Cinzel',serif;font-size:9px;font-weight:600;
  padding:2px 6px;border-radius:7px;border:1px solid rgba(244,228,186,.45);box-shadow:0 1px 3px rgba(0,0,0,.4);}
/* Nombre en la lista */
.wp-name{font-family:'Cinzel',serif;font-size:12px;color:var(--gold-light);margin-bottom:1px;}

/* Formulario de marca manual + selector de emoji */
.nav-add{background:rgba(5,24,40,.45);border:1px solid var(--border);border-radius:7px;
  padding:11px 12px;margin-bottom:14px;}
.nav-add-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;
  color:var(--gold);margin-bottom:9px;}
.nav-add-row{display:flex;gap:6px;margin-bottom:10px;}
.nav-add-row .fi{flex:1;min-width:0;}
.nav-add-row .nav-add-sel{flex:0 0 56px;}
.nav-emoji-label{font-size:10px;color:var(--muted);margin-bottom:6px;font-style:italic;}
.nav-emoji{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:11px;}
.nav-collapser{cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;}
.nav-chev{display:inline-block;font-size:.85em;opacity:.75;}
.nav-emoji.collapsed,#nav-wplist.collapsed{display:none;}
.emoji-opt{width:38px;height:38px;border:1px solid var(--border);border-radius:8px;cursor:pointer;
  background:rgba(10,37,64,.7);font-size:19px;line-height:1;transition:all .15s;-webkit-tap-highlight-color:transparent;}
.emoji-opt:hover{border-color:var(--gold);}
.emoji-opt.sel{border-color:var(--orange);background:rgba(232,98,42,.18);box-shadow:0 0 8px rgba(232,98,42,.35);transform:scale(1.05);}
.nav-add .btn{margin:0;}
.wp-row-emoji{margin-right:4px;font-size:14px;}

/* Marca de tu posición GPS */
.gps-div{background:none;border:none;}
.gps-badge{width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  font-size:20px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));}

.nav-status{text-align:center;font-size:12px;color:var(--muted);font-style:italic;
  margin:12px 0;min-height:18px;}

.nav-mode{display:flex;gap:8px;margin:12px 0 8px;}
.nav-mode-btn{flex:1;padding:10px 8px;border:1px solid var(--border);border-radius:7px;cursor:pointer;
  background:rgba(5,24,40,.5);color:var(--muted);font-family:'Cinzel',serif;font-size:11px;letter-spacing:.5px;
  transition:all .15s;-webkit-tap-highlight-color:transparent;}
.nav-mode-btn.active{border-color:var(--gold);background:rgba(212,168,67,.13);color:var(--gold-light);}

.nav-plans{display:flex;gap:6px;margin:0 0 8px;align-items:stretch;}
.nav-plans #nav-plan-select{flex:1;min-width:0;}
.nav-plan-btn{margin:0;flex:0 0 40px;padding:0;font-size:14px;}

.nav-toolbar{display:flex;gap:8px;margin:8px 0 12px;}
.nav-toolbar .btn{margin:0;flex:1;}

.nav-plan-summary{font-size:13px;color:var(--cream);margin-bottom:10px;line-height:1.5;}
.nav-plan-summary b{color:var(--gold-light);font-family:'Cinzel',serif;}
.nav-hint{color:var(--muted);font-style:italic;font-size:11px;}

#nav-wplist{margin-bottom:12px;}
.wp-row{display:flex;align-items:center;gap:9px;padding:7px 9px;margin-bottom:5px;
  background:rgba(10,37,64,.5);border:1px solid var(--border);border-radius:5px;}
.wp-num{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:#c0392b;color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:11px;}
.wp-info{flex:1;min-width:0;}
.wp-coord{font-size:12px;color:var(--cream);}
.wp-leg{display:block;font-size:11px;color:var(--gold);font-style:italic;margin-top:1px;}
.wp-x{flex-shrink:0;width:24px;height:24px;border:none;border-radius:5px;cursor:pointer;
  background:rgba(248,113,113,.14);color:#f87171;font-size:12px;}
.wp-x:hover{background:rgba(248,113,113,.28);}
.wp-actions{flex-shrink:0;display:flex;gap:5px;}
.wp-act{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;cursor:pointer;
  background:rgba(10,37,64,.7);color:var(--cream);font-size:13px;-webkit-tap-highlight-color:transparent;}
.wp-act:hover{border-color:var(--gold);}
.wp-act.wp-del{background:rgba(248,113,113,.14);border-color:rgba(248,113,113,.3);color:#f87171;}
.wp-act.wp-del:hover{background:rgba(248,113,113,.28);}

.nav-pos{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:9px;}
.nav-coord{background:rgba(10,37,64,.6);border:1px solid var(--border);
  border-left:3px solid var(--gold);border-radius:4px;padding:9px 11px;}
.nav-coord-l{font-size:9px;color:rgba(212,168,67,.7);font-family:'Cinzel',serif;
  letter-spacing:.5px;text-transform:uppercase;}
.nav-coord-v{font-family:'Cinzel',serif;font-size:14px;color:var(--gold-light);margin-top:2px;word-break:break-word;}

.nav-actions{display:flex;gap:8px;margin-top:12px;}
.nav-actions .btn{margin:0;flex:1;}
