/**
 * ECOSMART · address-picker.css
 * Estilos del componente de selección de dirección
 * Compatible con temas claro (marketplace) y oscuro (delivery/transport)
 */

.ap-wrap{position:relative;}

/* Input row */
.ap-input-row{position:relative;}
.ap-input-wrap{position:relative;display:flex;align-items:center;}
.ap-input-icon{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:#999;font-size:.95rem;z-index:1;pointer-events:none;
  width:16px;text-align:center;
}
.ap-input{
  width:100%;padding:10px 44px 10px 40px;
  border:1px solid var(--border-2, #ddd);border-radius:10px;
  background:var(--dark-3, #f5f5f5);color:var(--txt-1, #333);
  font-family:inherit;font-size:.88rem;
  transition:border-color .2s;
}
.ap-input:focus{outline:none;border-color:var(--orange, #e67e22);box-shadow:0 0 0 3px rgba(230,126,34,.1);}
.ap-input::placeholder{color:var(--txt-4, #aaa);}

/* Dropdown de Google Places Autocomplete — DEBE flotar arriba de cualquier modal.
   Por defecto tiene z-index:1000 lo que lo deja oculto detrás del CheckoutMarketplace
   (z-index:99999). Forzamos un z-index mayor + estilos que combinen con la app. */
.pac-container{
  z-index:100001 !important;
  border-radius:10px;
  border:1px solid var(--border-2, #ddd);
  box-shadow:0 8px 24px rgba(0,0,0,.18);
  font-family:inherit;
  margin-top:2px;
}
.pac-item{padding:8px 12px;cursor:pointer;font-size:.85rem;color:#1f2937;}
.pac-item:hover{background:#f3f4f6;}
.pac-item-query{font-weight:600;}
.pac-icon{margin-right:8px;}
.ap-gps-btn{
  position:absolute;right:4px;
  width:32px;height:32px;border:none;border-radius:8px;
  background:rgba(52,152,219,.1);color:#3498db;
  cursor:pointer;font-size:.85rem;
  display:flex;align-items:center;justify-content:center;
  transition:.2s;
}
.ap-gps-btn:hover{background:rgba(52,152,219,.2);}

/* Lista de direcciones guardadas */
.ap-saved{
  margin-top:.4rem;
  border:1px solid var(--border-2, #eee);border-radius:10px;
  background:var(--dark-2, #fff);
  overflow:hidden;
  max-height:250px;overflow-y:auto;
  display:none;  /* se muestra al hacer focus */
}
.ap-item{
  display:flex;align-items:center;gap:.6rem;
  padding:.55rem .7rem;
  cursor:pointer;transition:background .15s;
  border-bottom:1px solid var(--border-1, #f0f0f0);
}
.ap-item:last-child{border-bottom:none;}
.ap-item:hover{background:var(--dark-3, #f8f8f8);}
.ap-item-icon{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
  background:var(--dark-4, #f0f0f0);color:var(--txt-3, #999);
}
.ap-item-info{flex:1;min-width:0;}
.ap-item-label{font-size:.8rem;font-weight:700;color:var(--txt-1, #333);}
.ap-item-addr{font-size:.72rem;color:var(--txt-3, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ap-item-del{
  width:24px;height:24px;border:none;border-radius:50%;
  background:transparent;color:var(--txt-4, #ccc);
  cursor:pointer;font-size:.65rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ap-item-del:hover{background:rgba(231,76,60,.1);color:#e74c3c;}

.ap-divider{
  padding:.3rem .7rem;
  font-size:.65rem;font-weight:700;color:var(--txt-4, #aaa);
  text-transform:uppercase;letter-spacing:.3px;
  background:var(--dark-3, #f5f5f5);
}

/* Confirmación: layout vertical para que los campos estructurados
   (ciudad/dpto/barrio/indicaciones) y los botones de acción quepan
   en mobile sin desbordar. */
.ap-confirm{
  display:flex;flex-direction:column;gap:.5rem;
  margin-top:.4rem;padding:.7rem .8rem;
  background:rgba(39,174,96,.08);border:1px solid rgba(39,174,96,.2);
  border-radius:8px;
}
.ap-confirm-addr{
  font-size:.82rem;color:var(--txt-2, #555);font-weight:600;
  word-break:break-word;
}
.ap-confirm-actions{
  display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap;
  margin-top:.2rem;
}
.ap-save-btn,.ap-change-btn{
  padding:6px 12px;border:none;border-radius:8px;
  font-size:.78rem;font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;gap:.3rem;
  font-family:inherit;transition:.15s;
}
.ap-save-btn{background:rgba(230,126,34,.1);color:#e67e22;}
.ap-save-btn:hover{background:rgba(230,126,34,.2);}
.ap-change-btn{background:var(--dark-3, #f0f0f0);color:var(--txt-3, #888);}
.ap-change-btn:hover{background:var(--dark-4, #e5e5e5);}

/* Mini mapa */
.ap-map{
  margin-top:.5rem;height:140px;
  border-radius:10px;overflow:hidden;
  border:1px solid var(--border-2, #ddd);
}

/* Modal guardar */
.ap-modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  z-index:3000;padding:1rem;
}
.ap-modal{
  background:var(--dark-2, #fff);border-radius:14px;
  padding:1.2rem;width:100%;max-width:320px;
  box-shadow:0 16px 48px rgba(0,0,0,.3);
}
.ap-modal h4{font-size:.95rem;margin:0;}
.ap-tag-btn{
  flex:1;padding:.5rem;border:1px solid var(--border-2, #ddd);border-radius:8px;
  background:var(--dark-3, #f8f8f8);color:var(--txt-1, #333);
  font-size:.78rem;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.3rem;
  font-family:inherit;transition:.15s;
}
.ap-tag-btn:hover{border-color:var(--orange, #e67e22);color:var(--orange, #e67e22);}
