#partners-map-container {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
} #partners-search-controls {
background: #f8f9fa;
padding: 20px;
border-radius: 8px;
margin-bottom: 20px;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
#partners-search-controls h3 {
margin-top: 0;
color: #2c3e50;
font-size: 1.4em;
}
.search-row {
display: flex;
gap: 10px;
align-items: center;
flex-wrap: wrap;
margin: 15px 0;
}
#search-address {
flex: 2;
min-width: 200px;
padding: 10px 15px;
border: 2px solid #e1e5e9;
border-radius: 5px;
font-size: 14px;
transition: border-color 0.3s ease;
}
#search-address:focus {
outline: none;
border-color: #0073aa;
box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.1);
}
#search-radius {
width: 100px;
padding: 10px;
border: 2px solid #e1e5e9;
border-radius: 5px;
font-size: 14px;
}
#search-radius:focus {
outline: none;
border-color: #0073aa;
}
.button {
padding: 10px 20px;
border: none;
border-radius: 5px;
cursor: pointer;
font-size: 14px;
font-weight: 500;
text-decoration: none;
transition: all 0.3s ease;
display: inline-block;
}
#search-partners-btn {
background: #0073aa;
color: white;
}
#search-partners-btn:hover {
background: #005a87;
transform: translateY(-1px);
}
#search-partners-btn:disabled {
background: #ccc;
cursor: not-allowed;
transform: none;
}
#clear-search-btn {
background: #6c757d;
color: white;
}
#clear-search-btn:hover {
background: #545b62;
transform: translateY(-1px);
}
#search-results-count {
color: #495057;
font-weight: 500;
margin-top: 10px;
} #partners-map {
border-radius: 8px;
box-shadow: 0 4px 6px rgba(0,0,0,0.1);
margin-bottom: 30px;
} .partner-popup {
max-width: 300px;
font-family: inherit;
}
.partner-popup h3 {
margin: 0 0 10px 0;
color: #2c3e50;
font-size: 1.2em;
border-bottom: 2px solid #0073aa;
padding-bottom: 5px;
}
.partner-popup p {
margin: 5px 0;
line-height: 1.4;
}
.partner-popup .partner-address,
.partner-popup .partner-contacts {
margin: 10px 0;
}
.partner-popup h4 {
margin: 10px 0 5px 0;
color: #34495e;
font-size: 0.9em;
font-weight: 600;
}
.partner-popup a {
color: #0073aa;
text-decoration: none;
}
.partner-popup a:hover {
text-decoration: underline;
}
.partner-distance {
background: #e3f2fd;
padding: 5px 10px;
border-radius: 4px;
font-weight: 500;
color: #1565c0;
margin-top: 10px !important;
} #partners-list {
margin-top: 30px;
}
#partners-list h3 {
color: #2c3e50;
border-bottom: 3px solid #0073aa;
padding-bottom: 10px;
margin-bottom: 20px;
}
#partners-count {
color: #0073aa;
font-weight: bold;
} #partners-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: 20px;
margin-top: 20px;
}
.partner-card {
background: white;
border: 1px solid #e1e5e9;
border-radius: 8px;
padding: 20px;
cursor: pointer;
transition: all 0.3s ease;
box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}
.partner-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
border-color: #0073aa;
}
.partner-card.highlighted {
border-color: #0073aa;
background: #f0f8ff;
box-shadow: 0 4px 12px rgba(0, 115, 170, 0.2);
}
.partner-card h4 {
margin: 0 0 10px 0;
color: #2c3e50;
font-size: 1.1em;
font-weight: 600;
}
.partner-code {
color: #6c757d;
font-size: 0.9em;
margin: 0 0 15px 0;
font-style: italic;
}
.partner-info {
margin: 15px 0;
}
.partner-address {
color: #495057;
line-height: 1.4;
margin-bottom: 10px;
}
.partner-contacts {
margin: 10px 0;
}
.partner-contacts p {
margin: 5px 0;
font-size: 0.9em;
}
.partner-contacts a {
color: #0073aa;
text-decoration: none;
font-weight: 500;
}
.partner-contacts a:hover {
text-decoration: underline;
}
.partner-distance {
background: #e8f5e8;
color: #2d5a2d;
padding: 4px 8px;
border-radius: 4px;
font-size: 0.85em;
font-weight: 500;
margin-top: 10px;
display: inline-block;
} .scrolling-to-map {
position: relative;
}
.scrolling-to-map::before {
content: '🎯 Visualizzazione sulla mappa...';
position: absolute;
top: 10px;
left: 50%;
transform: translateX(-50%);
background: rgba(0, 115, 170, 0.9);
color: white;
padding: 8px 16px;
border-radius: 20px;
font-size: 14px;
font-weight: 500;
z-index: 1000;
animation: fadeInOut 2s ease-in-out;
}
@keyframes fadeInOut {
0% { opacity: 0; transform: translateX(-50%) translateY(-10px); }
20%, 80% { opacity: 1; transform: translateX(-50%) translateY(0); }
100% { opacity: 0; transform: translateX(-50%) translateY(-10px); }
} .show-on-map-btn {
background: #28a745;
color: white;
border: none;
padding: 8px 16px;
border-radius: 4px;
font-size: 0.9em;
cursor: pointer;
transition: all 0.3s ease;
margin-top: 10px;
position: relative;
overflow: hidden;
}
.show-on-map-btn:hover {
background: #218838;
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
}
.show-on-map-btn:active {
transform: translateY(0);
}
.show-on-map-btn::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 0;
height: 0;
background: rgba(255, 255, 255, 0.3);
border-radius: 50%;
transform: translate(-50%, -50%);
transition: width 0.3s, height 0.3s;
}
.show-on-map-btn:active::after {
width: 100px;
height: 100px;
}
.no-partners {
text-align: center;
color: #6c757d;
font-style: italic;
padding: 40px 20px;
background: #f8f9fa;
border-radius: 8px;
grid-column: 1 / -1;
} #portfolio-geo-container {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
}
#portfolio-geo-map {
border-radius: 8px;
box-shadow: 0 4px 6px rgba(0,0,0,0.1);
margin-bottom: 20px;
}
#portfolio-geo-details {
background: white;
padding: 20px;
border-radius: 8px;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
} @media (max-width: 768px) {
#partners-map-container {
padding: 10px;
}
.search-row {
flex-direction: column;
align-items: stretch;
}
#search-address,
#search-radius {
width: 100%;
margin-bottom: 10px;
}
.button {
width: 100%;
margin-bottom: 5px;
}
#partners-grid {
grid-template-columns: 1fr;
gap: 15px;
}
.partner-card {
padding: 15px;
}
#partners-map {
height: 300px !important;
}
}
@media (max-width: 480px) {
#partners-search-controls {
padding: 15px;
}
#partners-search-controls h3 {
font-size: 1.2em;
}
.partner-popup {
max-width: 250px;
}
.partner-popup h3 {
font-size: 1.1em;
}
} @keyframes fadeIn {
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.partner-card {
animation: fadeIn 0.3s ease-out;
} .gm-style-iw {
padding: 0;
}
.gm-style-iw > div > div {
overflow: visible !important;
} .partner-card:focus,
.button:focus {
outline: 2px solid #0073aa;
outline-offset: 2px;
} @media (prefers-contrast: high) {
.partner-card {
border-width: 2px;
}
.partner-card:hover,
.partner-card.highlighted {
border-width: 3px;
}
.button {
border: 2px solid transparent;
}
#search-partners-btn {
border-color: #0073aa;
}
#clear-search-btn {
border-color: #6c757d;
}
} @media (prefers-reduced-motion: reduce) {
.partner-card,
.button,
#search-address,
#search-radius {
transition: none;
}
.partner-card:hover {
transform: none;
}
.button:hover {
transform: none;
}
}.wpcf7 .screen-reader-response {
position: absolute;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
word-wrap: normal !important;
}
.wpcf7 .hidden-fields-container {
display: none;
}
.wpcf7 form .wpcf7-response-output {
margin: 2em 0.5em 1em;
padding: 0.2em 1em;
border: 2px solid #00a0d2; }
.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
display: none;
}
.wpcf7 form.sent .wpcf7-response-output {
border-color: #46b450; }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
border-color: #dc3232; }
.wpcf7 form.spam .wpcf7-response-output {
border-color: #f56e28; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
border-color: #ffb900; }
.wpcf7-form-control-wrap {
position: relative;
}
.wpcf7-not-valid-tip {
color: #dc3232; font-size: 1em;
font-weight: normal;
display: block;
}
.use-floating-validation-tip .wpcf7-not-valid-tip {
position: relative;
top: -2ex;
left: 1em;
z-index: 100;
border: 1px solid #dc3232;
background: #fff;
padding: .2em .8em;
width: 24em;
}
.wpcf7-list-item {
display: inline-block;
margin: 0 0 0 1em;
}
.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
content: " ";
}
.wpcf7-spinner {
visibility: hidden;
display: inline-block;
background-color: #23282d; opacity: 0.75;
width: 24px;
height: 24px;
border: none;
border-radius: 100%;
padding: 0;
margin: 0 24px;
position: relative;
}
form.submitting .wpcf7-spinner {
visibility: visible;
}
.wpcf7-spinner::before {
content: '';
position: absolute;
background-color: #fbfbfc; top: 4px;
left: 4px;
width: 6px;
height: 6px;
border: none;
border-radius: 100%;
transform-origin: 8px 8px;
animation-name: spin;
animation-duration: 1000ms;
animation-timing-function: linear;
animation-iteration-count: infinite;
}
@media (prefers-reduced-motion: reduce) {
.wpcf7-spinner::before {
animation-name: blink;
animation-duration: 2000ms;
}
}
@keyframes spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@keyframes blink {
from {
opacity: 0;
}
50% {
opacity: 1;
}
to {
opacity: 0;
}
}
.wpcf7 [inert] {
opacity: 0.5;
}
.wpcf7 input[type="file"] {
cursor: pointer;
}
.wpcf7 input[type="file"]:disabled {
cursor: default;
}
.wpcf7 .wpcf7-submit:disabled {
cursor: not-allowed;
}
.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
direction: ltr;
}
.wpcf7-reflection > output {
display: list-item;
list-style: none;
}
.wpcf7-reflection > output[hidden] {
display: none;
}