/* Pamconsulting Color Scheme */
:root {
  --pam-blue: #00A3DA;
  --pam-dark-blue: #005A87;
  --pam-green: #00C389;
  --pam-dark: #2D3E50;
  --pam-light: #F5F7FA;
  --pam-border: #E1E6EB;
  --pam-text: #2D3E50;
  --pam-text-light: #6B7C93;
}

/* Base container - Stile Pamconsulting */
.pam-lead-form-wrapper { 
  max-width: 1000px; 
  margin: 30px auto; 
  padding: 0 20px; 
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif; 
  color: var(--pam-text);
}

/* Header stile Pamconsulting */
.pam-step h2 { 
  margin: 0 0 15px 0; 
  font-size: 24px; 
  color: var(--pam-dark-blue);
  font-weight: 600;
  line-height: 1.3;
}

.pam-step h2 small {
  font-size: 18px;
  color: var(--pam-text-light);
  font-weight: 400;
}

.pam-step p { 
  margin: 0 0 20px 0; 
  color: var(--pam-text-light);
  font-size: 16px;
  line-height: 1.5;
}

/* Step card - Design moderno Pamconsulting */
.pam-step { 
  display: none; 
  background: white; 
  border: 2px solid var(--pam-border); 
  border-radius: 16px; 
  padding: 30px; 
  box-shadow: 0 4px 20px rgba(45, 62, 80, 0.08); 
  margin-bottom: 25px;
  position: relative;
}

.pam-step::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--pam-blue), var(--pam-green));
  border-radius: 16px 16px 0 0;
}

/* Field styles - Stile Pamconsulting */
.pam-field { 
  margin-bottom: 20px; 
}

.pam-field input[type="text"], 
.pam-field input[type="email"], 
.pam-field input[type="tel"], 
.pam-field select, 
.pam-field textarea {
  width: 100%; 
  padding: 14px 16px; 
  border-radius: 10px; 
  border: 2px solid var(--pam-border); 
  font-size: 16px; 
  box-sizing: border-box;
  transition: all 0.3s ease;
  background: white;
  color: var(--pam-text);
}

.pam-field input:focus, 
.pam-field select:focus, 
.pam-field textarea:focus {
  outline: none;
  border-color: var(--pam-blue);
  box-shadow: 0 0 0 4px rgba(0, 163, 218, 0.1);
  transform: translateY(-1px);
}

.pam-field label { 
  display: block; 
  font-size: 15px; 
  margin-bottom: 8px; 
  color: var(--pam-text);
  font-weight: 500;
}

.pam-privacy { 
  font-size: 14px; 
  color: var(--pam-text-light);
  line-height: 1.4;
}

/* Link privacy migliorato */
.pam-privacy a {
  color: var(--pam-blue) !important;
  text-decoration: underline !important;
  font-weight: 600;
}

.pam-privacy a:hover {
  color: var(--pam-dark-blue) !important;
  text-decoration: none !important;
}

/* Radio and checkbox groups */
.pam-radio-group label { 
  display: block; 
  margin-bottom: 12px; 
  cursor: pointer; 
  padding: 12px;
  border: 2px solid var(--pam-border);
  border-radius: 10px;
  transition: all 0.3s ease;
}

.pam-radio-group label:hover {
  border-color: var(--pam-blue);
  background: rgba(0, 163, 218, 0.03);
}

.pam-radio-group input[type="radio"] { 
  margin-right: 10px; 
  transform: scale(1.2);
}

/* Cards row (step 2) - Design Pamconsulting */
.pam-cards { 
  display: flex; 
  gap: 20px; 
  margin-bottom: 20px; 
  align-items: stretch; 
}

.pam-card { 
  flex: 1; 
  display: flex; 
  gap: 15px; 
  padding: 20px; 
  border-radius: 12px; 
  border: 2px solid var(--pam-border); 
  background: white; 
  align-items: flex-start;
  transition: all 0.3s ease;
  cursor: pointer;
}

.pam-card:hover, 
.pam-card:focus-within {
  border-color: var(--pam-blue);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 163, 218, 0.15);
}

.pam-card-icon { 
  width: 60px; 
  height: 60px; 
  border-radius: 12px; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 28px; 
  background: linear-gradient(135deg, var(--pam-blue), var(--pam-dark-blue));
  flex-shrink: 0;
  color: white;
}

/* Icona terreno con contrasto migliore */
.pam-card:nth-child(2) .pam-card-icon {
  background: linear-gradient(135deg, #00C389, #008060) !important;
}

.pam-card-body { 
  flex: 1; 
}

.pam-card-body strong { 
  display: block; 
  margin-bottom: 12px; 
  color: var(--pam-dark-blue);
  font-size: 18px;
  font-weight: 600;
}

.pam-card-body label { 
  display: block; 
  margin-top: 8px; 
  font-size: 14px; 
  color: var(--pam-text-light);
}

/* Buttons area - Stile Pamconsulting */
.pam-actions { 
  display: flex; 
  gap: 15px; 
  margin-top: 25px; 
}

.pam-btn { 
  flex: 1; 
  background: linear-gradient(135deg, var(--pam-blue), var(--pam-green)); 
  color: white; 
  padding: 16px 20px; 
  border: none; 
  border-radius: 12px; 
  font-weight: 600; 
  cursor: pointer; 
  transition: all 0.3s ease;
  font-size: 16px;
  position: relative;
  overflow: hidden;
}

.pam-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 163, 218, 0.3);
}

.pam-btn:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(0, 163, 218, 0.3);
}

.pam-btn:active {
  transform: translateY(0);
}

.pam-btn:disabled {
  background: #ccc;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.pam-prev { 
  background: white;
  color: var(--pam-text);
  border: 2px solid var(--pam-border);
}

.pam-prev:hover {
  background: var(--pam-light);
  border-color: var(--pam-blue);
}

.pam-submit { 
  background: linear-gradient(135deg, var(--pam-dark-blue), var(--pam-blue));
  font-size: 17px;
  font-weight: 700;
}

/* Map container - Fix dimensioni */
.pam-map-container {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  border: 2px solid var(--pam-border);
  margin-top: 10px;
}

.pam-map { 
  width: 100%; 
  height: 400px; 
  border-radius: 0;
}

/* CORREZIONE DEFINITIVA: Pulsanti mappa con icone visibili */
.leaflet-control-zoom a {
  background: white !important;
  color: #2D3E50 !important;
  border: 2px solid #E1E6EB !important;
  font-weight: bold !important;
  width: 30px !important;
  height: 30px !important;
  line-height: 28px !important;
  font-size: 18px !important;
  text-decoration: none !important;
  display: block !important;
  text-align: center !important;
}

.leaflet-control-zoom a:hover {
  background: #00A3DA !important;
  color: white !important;
  text-decoration: none !important;
}

.leaflet-control-zoom-in {
  font-size: 22px !important;
  font-weight: bold !important;
}

.leaflet-control-zoom-out {
  font-size: 24px !important;
  font-weight: bold !important;
}

/* PULSANTI DISEGNO MAPPA - CORREZIONE COMPLETA */
.leaflet-draw-toolbar a {
  background: white !important;
  border: 2px solid #E1E6EB !important;
  color: #2D3E50 !important;
  font-weight: bold !important;
  background-image: none !important;
  width: 30px !important;
  height: 30px !important;
  line-height: 30px !important;
  font-size: 18px !important;
  text-decoration: none !important;
  display: block !important;
  text-align: center !important;
  position: relative !important;
}

.leaflet-draw-toolbar a:hover {
  background: #00A3DA !important;
  color: white !important;
  text-decoration: none !important;
}

/* Icone personalizzate per i pulsanti di disegno */
.leaflet-draw-toolbar a.leaflet-draw-draw-polygon:before {
  content: "⬟" !important;
  font-size: 18px !important;
}

.leaflet-draw-toolbar a.leaflet-draw-draw-rectangle:before {
  content: "⬛" !important;
  font-size: 16px !important;
}

.leaflet-draw-toolbar a.leaflet-draw-edit-edit:before {
  content: "✎" !important;
  font-size: 16px !important;
}

.leaflet-draw-toolbar a.leaflet-draw-edit-remove:before {
  content: "🗑" !important;
  font-size: 14px !important;
}

.leaflet-draw-toolbar a span {
  display: none !important;
}

.leaflet-draw-toolbar-top {
  margin-top: 10px !important;
}

.leaflet-draw-toolbar-top .leaflet-draw-toolbar {
  border-bottom: none !important;
}

.leaflet-bar {
  box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}

.leaflet-bar a {
  border-bottom: 1px solid #E1E6EB !important;
}

.leaflet-bar a:last-child {
  border-bottom: none !important;
}

.leaflet-bar a.leaflet-disabled {
  background: #f8f9fa !important;
  color: #adb5bd !important;
  cursor: not-allowed !important;
}

/* Pulsante geolocalizzazione */
.pam-geolocate-btn button {
  background: white !important;
  color: #2D3E50 !important;
  border: 2px solid #E1E6EB !important;
  font-weight: bold !important;
  padding: 6px 8px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  font-size: 16px !important;
  margin-bottom: 10px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
}

.pam-geolocate-btn button:hover {
  background: #00A3DA !important;
  color: white !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important;
}

/* Tooltip per i pulsanti mappa */
.leaflet-draw-toolbar a[data-tooltip] {
  position: relative;
}

.leaflet-draw-toolbar a[data-tooltip]:hover:after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: -35px;
  left: 50%;
  transform: translateX(-50%);
  background: #2D3E50;
  color: white;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  white-space: nowrap;
  z-index: 1000;
  pointer-events: none;
  animation: fadeIn 0.3s ease;
}

/* Pulsante cancella area */
.pam-clear-btn {
  background: #ff6b6b !important;
  color: white !important;
  border: none !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  margin-top: 8px !important;
  font-size: 12px !important;
  font-weight: bold !important;
  transition: all 0.3s ease !important;
}

.pam-clear-btn:hover {
  background: #ff5252 !important;
  transform: translateY(-1px);
}

/* Result box */
.pam-result { 
  display: none; 
  padding: 30px; 
  margin-top: 20px; 
  border-radius: 12px; 
  background: linear-gradient(135deg, #e8f6ef, #f0f9ff);
  border: 2px solid #cfe8d8; 
  color: #1f6f3b; 
  text-align: center; 
  font-size: 18px;
}

.pam-success-message {
  color: var(--pam-dark-blue);
}

/* small text */
.pam-small { 
  font-size: 14px; 
  color: var(--pam-text-light); 
  margin-top: 10px; 
  line-height: 1.4;
}

/* Loading state */
.pam-loading {
  position: relative;
  color: transparent !important;
}

.pam-loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid transparent;
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Animazioni per i popup */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

/* STILI PER GEOLOCALIZZAZIONE E OTTIMIZZAZIONI MOBILE */

/* Container pulsanti geolocalizzazione */
.pam-geolocation-buttons {
  margin-bottom: 20px;
}

.pam-geo-buttons-container {
  display: flex;
  gap: 10px;
  margin-top: 15px;
}

.pam-geo-buttons-container .pam-btn {
  flex: 1;
  padding: 12px 16px;
  font-size: 14px;
}

/* Spazio in alto per i pulsanti su desktop */
@media (min-width: 769px) {
  .pam-geo-buttons-container {
    margin-top: 20px;
  }
}

/* Ottimizzazioni mobile per step 2 */
@media (max-width: 768px) {
  .pam-card-body label {
    text-align: left !important;
    display: flex !important;
    align-items: center !important;
    margin-top: 10px !important;
    padding-left: 0 !important;
  }
  
  .pam-card-body input[type="radio"] {
    margin-right: 10px !important;
  }
  
  .pam-card {
    flex-direction: row !important;
    text-align: left !important;
  }
  
  .pam-geo-buttons-container {
    flex-direction: column;
  }
}

/* Miglioramenti per schermi molto piccoli */
@media (max-width: 480px) {
  .pam-card {
    flex-direction: column !important;
    text-align: center !important;
  }
  
  .pam-card-body label {
    justify-content: center !important;
    text-align: center !important;
  }
  
  .pam-geo-buttons-container .pam-btn {
    padding: 14px 12px;
    font-size: 14px;
  }
}

/* Stili per informazioni posizione */
#pam-location-info {
  background: linear-gradient(135deg, #f0f9ff, #e8f6ef);
  border: 2px solid #cfe8d8;
  border-radius: 8px;
  padding: 12px 15px;
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.4;
  color: var(--pam-dark-blue);
}

#pam-location-info strong {
  color: var(--pam-dark-blue);
}

#pam-location-info small {
  color: var(--pam-text-light);
  font-size: 12px;
}

/* Marker utente personalizzato */
.pam-user-marker {
  font-size: 24px !important;
  text-align: center;
  background: none !important;
  border: none !important;
}

/* Responsive adjustments */
@media (max-width: 968px) {
  .pam-lead-form-wrapper { 
    padding: 0 15px;
    margin: 20px auto;
  }
  
  .pam-step { 
    padding: 25px; 
  }
  
  .pam-step h2 { 
    font-size: 22px; 
  }
}

@media (max-width: 768px) {
  .pam-cards { 
    flex-direction: column; 
  }
  
  .pam-step { 
    padding: 20px; 
    margin: 15px 0; 
  }
  
  .pam-step h2 { 
    font-size: 20px; 
  }
  
  .pam-actions { 
    flex-direction: column; 
    gap: 10px; 
  }
  
  .pam-btn { 
    padding: 14px; 
  }
  
  .pam-map { 
    height: 350px; 
  }
}

@media (max-width: 480px) {
  .pam-lead-form-wrapper { 
    padding: 0 10px; 
  }
  
  .pam-step { 
    padding: 15px; 
    border-radius: 12px;
  }
  
  .pam-step h2 { 
    font-size: 18px; 
  }
  
  .pam-field input, 
  .pam-field select { 
    padding: 12px; 
    font-size: 16px; 
  }
  
  .pam-card {
    flex-direction: column;
    text-align: center;
    gap: 15px;
  }
  
  .pam-card-icon {
    align-self: center;
  }
  
  .pam-map {
    height: 300px;
  }
  
  /* Miglioramenti mobile per i controlli mappa */
  .leaflet-control-zoom a {
    width: 35px !important;
    height: 35px !important;
    line-height: 33px !important;
    font-size: 20px !important;
  }
  
  .leaflet-draw-toolbar a {
    width: 35px !important;
    height: 35px !important;
    line-height: 35px !important;
    font-size: 20px !important;
  }
}