/* Stili base */
body{font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; margin:0;color:#222}
/* fixed header */
:root{--header-h:72px}
header{position:fixed;top:0;left:0;right:0;height:var(--header-h);display:flex;align-items:center;padding:12px 20px;background:linear-gradient(180deg,#ffffff,#f5f7fa);border-bottom:1px solid #e6e9ee;box-shadow:0 1px 4px rgba(16,24,40,0.05);z-index:1000}
#map{width:100%;height:100%}
/* body content pushed below header */
main{padding-top:var(--header-h)}
#map{width:100%;height:70vh}
button{padding:8px 12px;border-radius:4px;border:1px solid #ccc;background:white;cursor:pointer}
#app{display:flex;height:calc(100vh - var(--header-h))}
#left{flex:1}
#right{width:360px;overflow:hidden;border-left:1px solid #e6e6e6;padding:12px;background:#fafafa}
#listHeader{display:flex;justify-content:space-between;align-items:center}
.point-list{list-style:none;padding:0;margin:6px 0}
#pointsList{list-style:none;padding:0;margin:6px 0}
.point-item{padding:6px 8px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;gap:10px}
.point-main{display:flex;flex-direction:column;min-width:0}
.point-title{display:flex;align-items:center;gap:8px}
.point-title strong{font-size:14px}
.point-title .time{font-size:12px;color:#6b7280;font-weight:600}
.point-sub{font-size:15px;color:#9ca3af;margin-top:6px}
.point-address{font-size:13px;color:#6b7280;margin-top:4px}
.point-actions button{margin-left:6px}
.point-actions button{display:inline-flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;border:1px solid #e6e6e6;background:#fff;font-size:13px}
.point-actions button i{width:14px;height:14px}
/* ensure feather svg icons inside buttons are constrained (override inline svg attrs) */
.point-actions button svg{width:14px !important;height:14px !important;display:block}

/* legacy selector: some list items may still use .created; force it below the title */
.point-item .created, .point-item .created .time{display:block;font-size:12px;color:#9ca3af;margin-top:8px}
.time{display:block;font-size:13px;color:#9ca3af;margin-top:3px}
#navPanel{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;background:rgba(255,255,255,0.95);padding:8px 12px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.15);display:flex;gap:12px;align-items:center;z-index:10030}
#navPanel.hidden{display:none}
#navInfo{display:flex;flex-direction:column;margin-right:8px}
#distance{font-weight:700}

/* mobile: mostra tab (solo mappa o solo lista) */
@media(max-width:768px){
	#app{flex-direction:column}
	#right{width:100%;border-left:none;border-top:1px solid #e6e6e6}
	.mobile-only{display:block}
	/* inizialmente mostra solo mappa */
	#app.show-list #left{display:none}
	#app.show-list #right{display:block}
	#app.show-map #right{display:none}
}
@media(min-width:769px){
	.mobile-only{display:none}
}

/* label modal styles */
#labelModal.hidden{display:none}
#infoModal.hidden{display:none}
#infoModal{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;z-index:10003}
#labelModal{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center}
#categoryManagerModal{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;z-index:10003}
#categoryManagerModal.hidden{display:none}
.modal-content.small{min-width:260px;padding:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}

/* compass */
#compass{margin-top:8px}
#arrow{display:inline-block;transform-origin:center center;transition:transform 200ms ease}

/* orientation button */
#orientationControl{margin-left:8px}
#requestOrientation{padding:6px 8px;font-size:13px}
#modal.hidden{display:none}
.modal-backdrop{position:fixed;left:0;top:0;right:0;bottom:0}
#modal{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center}
#infoModal .modal-content{background:white;padding:16px;border-radius:8px;min-width:320px;position:relative}
/* ensure modals overlay Leaflet map controls */
#labelModal{z-index:10001}
#modal{z-index:10002}
.modal-content{background:white;padding:16px;border-radius:8px;min-width:260px;position:relative}
.modal-content button#closeModal{position:absolute;right:8px;top:6px;border-radius:50%;padding:4px 8px}
form input{display:block;width:100%;margin:8px 0;padding:8px}

/* improved form modal styles */
.form-modal{min-width:320px;max-width:420px;padding:14px 18px}
.form-modal .form-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.form-header-icon{width:28px;height:28px;color:#2563eb}
.form-modal .field{margin-bottom:10px}
.input-with-icon{display:flex;align-items:center;gap:8px;border:1px solid #e6e6e6;padding:6px 8px;border-radius:8px;background:#fff}
.input-with-icon i{width:18px;height:18px;color:#6b7280}
.input-with-icon input, .input-with-icon select{border:0;outline:none;flex:1;background:transparent;font-size:14px;padding:6px}
.input-with-icon select{appearance:none}
.close-btn{position:absolute;right:8px;top:8px;border-radius:6px;padding:6px;border:0;background:transparent}
.close-btn svg{width:16px;height:16px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.modal-actions .primary{background:#2563eb;color:#fff;border-color:#1e40af}
.modal-actions button{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;border:1px solid #e6e6e6;background:#fff;font-size:14px}
.modal-actions button svg{width:16px;height:16px}

/* prevent inputs from overflowing and make modal responsive */
.form-modal { box-sizing: border-box; overflow: hidden; }
.form-modal .input-with-icon { min-width: 0; }
.form-modal input, .form-modal select { min-width: 0; max-width: 100%; }

/* header styles */
.brand h1{font-size:20px;margin:0;font-weight:700;letter-spacing:-0.5px}
.header-controls{display:flex;align-items:center;gap:10px;margin-left:auto;}
.user-area{display:flex;align-items:center;gap:8px}
.welcome{font-size:14px;color:#333}
.icon-btn{background:#fff;border:1px solid #e3e6ee;padding:8px 10px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.icon-btn svg{display:block}
.icon-btn:hover{box-shadow:0 4px 12px rgba(16,24,40,0.08)}

/* demo badge */
.badge-demo{display:inline-block;background:#fff3cd;color:#8a6d00;border:1px solid #ffeeba;padding:3px 8px;border-radius:12px;margin-left:8px;font-size:12px;font-weight:700}

.point-actions button{display:inline-flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;border:1px solid #e6e6e6;background:#fff;font-size:13px}
.point-actions button i{width:14px;height:14px}

#info modal tweaks */
#infoModal .modal-content{max-width:520px}
/* Make info modal responsive: limit height and allow internal scrolling on small viewports.
	 This ensures the close button remains accessible and content doesn't overflow the screen. */
#infoModal .modal-content{
	max-width:520px;
	width: calc(100% - 32px);
	max-height: calc(100vh - 48px);
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	box-sizing: border-box;
	position: relative;
	padding-bottom: 18px;
}

/* Ensure the info modal close button is positioned and visible on small screens */
#infoModal .modal-content > button#closeInfoModal{
	position: absolute;
	right: 8px;
	top: 8px;
	border-radius: 6px;
	padding: 6px;
	border: 0;
	background: transparent;
	font-size: 18px;
	cursor: pointer;
}
#infoModal p, #infoModal ul{font-size:14px;color:#333}

/* ensure map controls remain visible under header area */
.leaflet-control-container{z-index:900}

/* mobile adjustments */
@media(max-width:768px){
	.brand h1{font-size:18px}
	#right{width:100%;border-left:none;border-top:1px solid #e6e6e6}
	.icon-btn{padding:6px 8px}
}

/* Mobile: force header controls inline and compact */
/* Apply compact header layout for small screens and tablets */
@media(max-width:768px){
	header{padding:8px 10px}
	.header-controls{gap:6px}
	.header-controls{display:flex;align-items:center;flex-wrap:nowrap}
	.header-controls > *{flex:0 0 auto;margin:0}
	.icon-btn{padding:6px;min-width:36px;min-height:36px;border-radius:8px}
	#categoryWrapper{display:flex;align-items:center;gap:6px}
	/* make select compact and not overflow */
	#categoryFilter{padding:6px 8px;border-radius:8px;border:1px solid #e6e6e6;background:#fff;font-size:13px;min-width:64px;max-width:140px}
	#addCategoryBtn{padding:6px;border-radius:8px}
	/* shrink welcome area to avoid pushing controls */
	.user-area .welcome{display:none}
	.badge-demo{margin-left:4px;padding:3px 6px}
	/* make header controls scrollable if overflow */
	.header-controls{overflow-x:auto;-webkit-overflow-scrolling:touch}
}

	/* DB alert banner shown when backend DB is unreachable */
	.db-alert{
		background:#c62828; /* red */
		color: #fff;
		padding:8px 12px;
		text-align:center;
		font-weight:600;
	}
	.db-alert small{display:block;font-weight:400;opacity:0.95}

/* ensure html/body take full height so calc works reliably and map fills remaining space */
html, body { height: 100%; overflow: hidden; overscroll-behavior: none; -webkit-overflow-scrolling: auto; }
/* prevent page scroll: app and main are sized to viewport and overflow is hidden so only map interactions apply */
main{min-height:calc(100vh - var(--header-h)); overflow: hidden}
#app{min-height:calc(100vh - var(--header-h)); overflow: hidden}
#map{height:100%;min-height: calc(100vh - var(--header-h));}

/* instruction bar at bottom */
.instruction-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:12px;background:rgba(255,255,255,0.95);padding:10px 14px;border-radius:999px;box-shadow:0 6px 18px rgba(16,24,40,0.12);z-index:10005;display:flex;gap:10px;align-items:center;font-size:14px}
.instruction-bar .dot{width:10px;height:10px;border-radius:50%;background:#3b82f6}
.instruction-bar .text{color:#0f172a}
.instruction-bar .info-link{background:transparent;border:0;color:#2563eb;cursor:pointer;padding:6px}

/* small category buttons overlay on map (top-right) */
.map-categories{position:absolute;top:12px;right:12px;display:flex;gap:6px;flex-direction:column;max-height:60vh;overflow:auto;padding:6px;z-index:10010}
.map-cat-btn{background:rgba(255,255,255,0.95);border:1px solid rgba(0,0,0,0.08);padding:8px 10px;border-radius:8px;font-size:13px;cursor:pointer;box-shadow:0 4px 10px rgba(2,6,23,0.06);text-align:left}
.map-cat-btn.active{background:#2563eb;color:#fff;border-color:#1e40af}
.map-cat-btn:disabled{opacity:0.5;cursor:not-allowed}

/* make sure overlay doesn't get clipped inside map container */
#map{position:relative}

/* map loader overlay (covers map while tiles load) */
.map-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,255,255,0.9));z-index:10020}
.map-loader.hidden{display:none}
.map-loader .spinner{width:44px;height:44px;border-radius:50%;border:4px solid rgba(0,0,0,0.08);border-top-color:#2563eb;animation:spin 1s linear infinite}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Utility to prevent page scroll while loader is visible (mobile) */
.no-scroll{overflow:hidden;height:100vh}

/* loader label */
.map-loader .loader-label{margin-top:10px;font-size:14px;color:#374151;font-weight:600}
.map-loader .loader-label[aria-live]{font-weight:600}

#categoryFilter{padding:10px;border:1px solid #ddd;border-radius:6px}
#categoryWrapper{display:flex;justify-content:center;align-items:center;gap:4px}
#addCategoryBtn{padding:6px;font-weight: bold; display:flex;justify-content:center;align-items:center;color:green;font-size:24px;border:1px solid #ddd;border-radius:6px;width:38px;height: 38px;text-align: center;margin-top:4px}
.loginForm{width:90%;}
.loginForm label{font-size:12px;color:#555}
#closeModal{font-weight:bold;font-size:16px}