
.servisi-toggler, .map-toggler, .contact-toggler { width: 40px; height: 40px; border: none; background: #e11e28; border-radius: 8px; color: #fff; cursor: pointer; transition: all 0.3s ease; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.servisi-toggler::before, .map-toggler::before, .contact-toggler::before { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.3); transform: translate(-50%, -50%); transition: width 0.3s, height 0.3s; }
.servisi-toggler:hover::before, .map-toggler:hover::before, .contact-toggler:hover::before { width: 150px; height: 150px; }
.servisi-toggler:hover, .map-toggler:hover, .contact-toggler:hover { background: #2a355e; transform: scale(1.1); }
.servisi-toggler i,.map-toggler i, .contact-toggler i { position: relative; z-index: 1; font-size: 18px; }
.servisi-toggler:focus, .map-toggler:focus, .contact-toggler:focus { outline: 3px solid #00d4ff; outline-offset: 2px; }

.modal-content { background: #f9fbfc; border-radius: 14px; box-shadow: 0 30px 80px rgba(15, 42, 68, 0.25); }
.modal-header { position: relative; border-bottom: 1px solid rgba(15, 42, 68, 0.1); padding: 30px; border-radius: 0; }
.modal-body { padding: 30px; overflow-y: auto; }
.modal-header .close { border-radius: 50%; padding: 0; width: 50px; height: 50px; background: #373d5a; font-size: 28px; line-height:26px; opacity: 1; color: #f8cf1c; text-shadow: 0 1px 0 #f8cf1c; position: absolute; top: 40px; right: 40px; cursor: pointer; border: 0; transition: all 0.35s ease; }
.modal-header .close:hover { background: #f8cf1c; color: #373d5a; text-shadow: 0 1px 0 #373d5a; opacity: 1; outline: 0; }
.modal-header .close:focus { outline: 3px solid #00d4ff; outline-offset: 2px; }

.modal-tekst { margin: 0; padding: 0 30px; }
.modal-header h3.form-title { padding-left: 0; }
.modal-header h3.form-title, .modal-tekst h3 { margin-bottom: 20px; color: #2a355e; font-size: 50px; font-weight: 900; line-height: 55px; }
.modal-tekst h4 { color: #555; font-size: 0.95rem; font-weight: 500; text-transform: uppercase; line-height: 1.1; margin-bottom:8px; border-top: 1px solid rgba(15,42,68,0.1); padding:10px 0; border-bottom: 1px solid rgba(15,42,68,0.1); }
.modal-tekst p { font-size: 18px; line-height: 28px; padding-top:0; }
.modal-disclamer { margin: 0; padding: 0 10px; }
.modal-disclamer p { font-size: 13px; line-height: 18px; padding-top:0; }

.modal .f-menuWrap { position: relative; overflow: hidden; padding: 0; text-align: center; margin-bottom: 10px; }
.modal .f-menu ul { display: inline-flex; margin: 0; padding: 0; list-style-type: none; }
.modal .f-menu ul li { vertical-align: baseline; letter-spacing: 0; }
.modal .f-menu ul li a { letter-spacing: 0; transition: 0.3s ease-out; font-size: 13px; font-weight: 500; color: #2a355e; text-transform: uppercase; }
.modal .f-menu ul li + li:before { content: ' '; display: inline-block; width: 0; height: .8em; margin: 0 1em; vertical-align: baseline; border-left: 1px solid #57C5CE; }
.modal .f-menu ul li a:hover { color: #2a355e; }

body.modal-open[style] { padding-right: 0 !important; }
.modal::-webkit-scrollbar { width: 0 !important; }
.modal-open .modal { padding-right: 0 !important; }
.modal { z-index: 9999999; padding: 0 !important; }
.modal .modal-dialog { margin: 0; }
.modal .modal-content { border: 0; border-radius: 0; }
.modal .modal-body { overflow-y: auto; }

.modal-fullscreen-custom { width: 100%; max-width: 100%; height: 100vh; margin: 0; }
.modal-fullscreen-custom .modal-content { height: 100%; border-radius: 0; }

.servisi-modal .modal-dialog { transform: translateY(100%); transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1); }
.servisi-modal.show .modal-dialog { transform: translateY(0); }
.servisi-modal .modal-content { background: #fff; position: relative; }
.servisi-modal .modal-content::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-image: url(../images/bg/bg_colorful.jpg); background-size: cover; background-position: top left; opacity: 0.05; pointer-events: none; z-index: 0; }
.servisi-header { position: relative; padding: 40px 30px 30px; border-bottom: 2px solid rgba(225, 30, 40, 0.1); background: transparent; z-index: 1; }
.servisi-header .sec-title { margin: 0; }
.servisi-header .animTitle { animation: fadeInUp 0.8s ease-out 0.3s both; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

.modal-title-servisi { font-weight: 900; font-size: 75px; text-transform: uppercase; color: #2a355e; padding: 0; text-shadow: 0 0 0 rgba(0, 114, 186, 0.2); margin: 0; line-height: 1.1; }
.modal-subtitle-servisi { display: block; font-size: 18px !important; color: #e11e28; line-height: 28px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; margin: 0; }

.close-servisi { position: absolute; border-radius: 50%; padding: 0; width: 50px; height: 50px; background: #373d5a; font-size: 28px; line-height: 26px; opacity: 1; color: #f8cf1c; text-shadow: 0 1px 0 #f8cf1c; top: 20px; right: 20px; cursor: pointer; border: 0; z-index: 9999999; transition: all 0.5s ease; display: flex; align-items: center; justify-content: center; }
.close-servisi:hover { background: #f8cf1c; color: #373d5a; text-shadow: 0 1px 0 #373d5a; opacity: 1; transform: rotate(90deg); }
.close-servisi:focus { outline: 3px solid #00d4ff; outline-offset: 2px; }
.close-servisi .puls { position: absolute; width: 100%; height: 100%; border-radius: 50%; border: 2px solid #f8cf1c; opacity: 0; animation: pulse 2s infinite; }
@keyframes pulse { 0% { transform: scale(1); opacity: 0.8; } 100% { transform: scale(1.5); opacity: 0; } }

.servisi-body { position: relative; z-index: 1; padding: 40px 30px 60px; }

.vazni-brojevi { height: 100%; position: relative; padding: 30px; border-radius: 20px; background: rgba(255,255,255,0.75); backdrop-filter: blur(6px); border:6px solid rgba(6,17,56,0.08); box-shadow: 0 10px 35px rgba(6,17,56,0.06); box-shadow: 9.48583px 11.5938px 54.1832px -7.88119px rgba(26, 26, 26, .39); }
.vazni-brojevi ul { margin: 0; padding: 0; background: transparent; border-radius:0; list-style: none;}
.vazni-brojevi li { padding: 12px 0; border-bottom: 1px solid rgba(198, 193, 177, 0.7); font-size: 15px; font-weight: 600; color: #2a355e; display: flex; align-items: center; transition: all 0.3s ease; }
.vazni-brojevi li:last-child { border: 0; padding-bottom: 0; }
.vazni-brojevi li:hover { padding-left: 10px; color: #e11e28; }
.vazni-brojevi li span { display: inline-block; margin-right: 15px; color: #fff; padding: 4px 12px; font-size: 13px; background: #e11e28; border-radius: 5px; min-width: 120px; text-align: center; font-weight: 700; flex-shrink: 0; }

.weather-icons { position: relative; z-index: 9; position: relative; padding: 30px; border-radius: 20px; background: rgba(255,255,255,0.75); backdrop-filter: blur(6px); border:6px solid rgba(6,17,56,0.08); box-shadow: 0 10px 35px rgba(6,17,56,0.06); }
.weather-icons ul { display: flex; flex-wrap: wrap; gap: 15px; padding: 0; list-style: none; margin: 0; }
.weather-icons ul li { flex: 0 0 calc(14% - 10px); min-width: 115px; min-height: 115px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; border-radius: 8px; background: #e11e28; border: 1px solid transparent; transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1); box-shadow:  inset 0 1px 0 hsla(0, 0%, 100%, 0.1), 0 0 0 1px rgba(225, 30, 40, 0.1), 0 2px 4px rgba(225, 30, 40, 0.1), 0 4px 8px rgba(225, 30, 40, 0.1); }
.weather-icons ul li a { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: 100%; padding: 20px; text-decoration: none; color: #fff; transition: all 0.3s ease; }
.weather-icons ul li a i { font-size: 40px; transition: all 0.3s ease; margin-bottom: 12px; }
.weather-icons ul li span { display: block; font-weight: 600; font-size: 12px; line-height: 16px; font-family: 'Poppins', sans-serif; text-transform: uppercase; letter-spacing: 0.5px; }
.weather-icons ul li:hover { transform: translateY(-8px) scale(1.05); box-shadow:  0 8px 16px rgba(225, 30, 40, 0.3), 0 16px 32px rgba(225, 30, 40, 0.2); background: #2a355e; }
.weather-icons ul li:hover a, .weather-icons ul li:hover a i, .weather-icons ul li:hover span { color: #f8cf1c; }
.weather-icons ul li a:focus { outline: 3px solid #00d4ff; outline-offset: 2px; }

.map-modal .modal-dialog { top: 0; right: 0; width: 70%; max-width: none; height: 100vh; margin: 0; position: fixed; transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1); }
.map-modal.show .modal-dialog { transform: translateX(0); }
.map-modal .modal-content { height: 100%; }
.map-modal .form-title { color: #2a355e; font-size: 50px; font-weight: 900; line-height: 55px; margin: 0; padding-right: 70px; }
.map-holder { position: relative; width: 100%; height: 600px; border-radius: 8px; overflow: hidden; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); }
.map { width: 100%; height: 100%; }
.leaflet-marker-icon.boat { background-image: url('../images/icons/boat.png'); background-size: contain; background-repeat: no-repeat; }
.leaflet-marker-icon.island { background-image: url('../images/icons/island.png'); background-size: contain; background-repeat: no-repeat; }
.leaflet-marker-icon.swim { background-image: url('../images/icons/swim.png'); background-size: contain; background-repeat: no-repeat; }
.leaflet-marker-icon.end { background-image: url('../images/icons/flag.png'); background-size: contain; background-repeat: no-repeat; }
.custom-svg-icon svg { width: 30px; height: 30px; fill: #e11e28; }
.staticMapWrap { position: relative; width: 100%; height: 600px; border-radius: 8px; overflow: hidden; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); }
.staticMapWrap::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-image: url(../images/bg/bg_colorful.jpg); background-size: cover; background-position: top left; opacity: 0.05; pointer-events: none; z-index: 0; }
#staticMap { position: relative; width: 100%; height: 650px; background-image: url('../images/maps/mb_torcida_map.png'); background-size: cover; background-position: top left; background-repeat: no-repeat;  }

/* Modal - Kontakt */
.contact-modal .modal-dialog { top: 0; right: 0; width: 70%; max-width: none; height: 100vh; margin: 0; position: fixed; transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1); }
.contact-modal.show .modal-dialog { transform: translateX(0); }
.contact-modal .modal-content { height: 100%; }
.contact-modal .form-title { color: #2a355e; font-size: 50px; font-weight: 900; line-height: 55px; margin: 0; padding-right: 70px; }

/* Kontakt ikone - modal i kontakt */
.contactIcoWrap { padding: 20px 0; }
.contactIcon { height: 100%; min-height: 160px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #2a355e; text-decoration: none; padding: 20px; border-radius: 20px; background: rgba(255,255,255,0.75); backdrop-filter: blur(6px); border:6px solid rgba(6,17,56,0.08);  cursor: pointer; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1); position: relative; overflow: hidden;  box-shadow: -3px 0 92px 12px rgba(0, 114, 186, 0.15), 0 4px 16px rgba(0, 0, 0, 0.08);  }
.contactIcon::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent); transition: left 0.5s ease; }
.contactIcon:hover::before { left: 100%; }
.contactIcon i { font-size: 3rem; margin-bottom: 1rem; transition: all 0.3s ease; }
.contactIcon span { font-size: 1rem; line-height: 18px; text-align: center; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 0.5rem; }
.contactIcon .contact-detail { font-size: 0.9rem; font-weight: 500; color: #666; margin-top: 0.5rem; border-bottom: 2px solid #e11e28;}
.contactIcon:hover { transform: translateY(-8px); box-shadow:  -3px 0 92px 12px rgba(0, 114, 186, 0.25), 0 12px 24px rgba(0, 0, 0, 0.15); }
.contactIcon:hover i { animation: shake 0.5s ease; /* transform: scale(1.1);*/ }
.contactIcon.email:hover { color: #2563eb; border-color: #2563eb; }
.contactIcon.phone:hover { color: #e11e28; border-color: #e11e28; }
.contactIcon.whatsapp:hover { color: #25D366; border-color: #25D366; }
.contactIcon.viber:hover { color: #666; border-color: #666; }
.contactIcon.mapIcon:hover { color: #f8cf1c; border-color: #f8cf1c; }
.contactIcon.servicesIcon:hover { color: #2a355e; border-color: #2a355e; }
@media (max-width: 991px) {button.servicesIcon, button.contactIcon, button.mapIcon { width: 100%; } } 
@keyframes shake { 0%, 100% { transform: rotate(0deg); } 25% { transform: rotate(-10deg); } 75% { transform: rotate(10deg); } }
@keyframes bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.contactIcon:focus { outline: 3px solid #00d4ff; outline-offset: 2px; }

/* Kontakt podatci - modal */
.additional-info { height: 100%; padding: 25px; border-radius: 20px; background: rgba(255,255,255,0.75); backdrop-filter: blur(6px); border:6px solid rgba(6,17,56,0.08); box-shadow: 0 10px 35px rgba(6,17,56,0.06); }
.additional-info h4 { color: #2a355e; font-size: 1.1rem; font-weight: 700; text-transform: uppercase; margin-bottom: 15px; padding-bottom: 10px; border-bottom: 2px solid rgba(225, 30, 40, 0.2); }
.additional-info p { display: flex; align-items: center; gap: 10px; font-size: 0.9rem; font-weight: 500; line-height: 1.8; color: #555; margin-bottom: 15px; }
.additional-info i { display: flex; align-items: center; justify-content: center; font-size: 1.1rem; width: 30px; height: 30px; background: #f8cf1c; color: #2a355e; border-radius: 8px; cursor: pointer;transition: all 0.3s ease; box-shadow: rgba(0, 0, 0, 0.55) 0px -1px 17px -5px; position: relative; overflow: hidden; margin-right: 10px; }
.additional-info p:hover { color:#e11e28; transition: all 0.3s ease; }
.additional-info p:hover i { transform: scale(1.12); transition: all 0.3s ease; }

#booking .modal-body { padding: 10px 30px 50px 30px; }

/* Modal switchs */
.modal-switch-btn { font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; padding: 12px 24px; border-radius: 8px; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1); border: none; position: relative; overflow: hidden; }
.modal-switch-btn::before { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.3); transform: translate(-50%, -50%); transition: width 0.3s, height 0.3s; }
.modal-switch-btn:hover::before { width: 300px; height: 300px; }
.modal-switch-btn i { position: relative; z-index: 1; }
.modal-switch-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15); }
.modal-switch-btn:active { transform: translateY(0); }
.modal-switch-btn:focus { outline: 3px solid #00d4ff; outline-offset: 2px; box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.3); }
.btn-primary.modal-switch-btn { background: linear-gradient(135deg, #e11e28 0%, #b81620 100%); }
.btn-primary.modal-switch-btn:hover { background: linear-gradient(135deg, #b81620 0%, #8f1118 100%); }
.btn-info.modal-switch-btn { background: linear-gradient(135deg, #2a355e 0%, #1a2340 100%); }
.btn-info.modal-switch-btn:hover { background: linear-gradient(135deg, #1a2340 0%, #0f1628 100%); }

@media (max-width: 991px) {
	.kontakt-grupa { gap: 16px; }
	#booking .modal-body { padding: 0 10px!important; }
	.modal-content { padding: 0 10px!important; }
	.booking-floating .number-stepper .form-control { width: 100%!important; }
	.modal-header h3.form-title, .modal-tekst h3 { margin-bottom: 0px; font-size: 23px; font-weight: 700; line-height: 25px; }
	.modal-tekst p { font-size: 15px; line-height: 23px;}
	.servisi-toggler, .map-toggler, .contact-toggler { width: 36px; height: 36px; }
	.servisi-toggler i, .map-toggler i, .contact-toggler i { font-size: 16px; }
	.modal-title-servisi { font-size: 45px; }
	.modal-subtitle-servisi { font-size: 14px !important; letter-spacing: 1px; }
	.servisi-body { padding: 30px 20px; }
	.weather-icons ul li { flex: 0 0 calc(33.333% - 10px); min-width: 120px; min-height: 120px; }
	.weather-icons ul li a i { font-size: 32px; }
	.map-modal .modal-dialog, .contact-modal .modal-dialog { width: 85%; }
	.map-modal .form-title, .contact-modal .form-title { font-size: 35px; line-height: 40px; }
	.map-holder { height: 450px; }
} 

@media (max-width: 767.98px) { .kontakt-grupa { gap: 12px; }
.servisi-toggler, .map-toggler, .contact-toggler { width: 32px; height: 32px; }
.servisi-toggler i, .map-toggler i, .contact-toggler i { font-size: 14px; } 
.modal-header, .modal-body { padding: 20px; }  
.modal-header .close, .close-servisi { width: 40px; height: 40px; font-size: 24px; line-height: 22px; top: 25px; right: 22px; } 
.servisi-header { padding: 25px 20px 20px; }
.modal-title-servisi { font-size: 32px; line-height: 1.2; }
.modal-subtitle-servisi { font-size: 12px !important; letter-spacing: 0.5px; line-height: 20px; }
.servisi-body { padding: 20px 15px 40px; } .vazni-brojevi { margin-bottom: 30px; }
.vazni-brojevi ul { padding: 15px; } 
.vazni-brojevi li { font-size: 13px; padding: 10px 0; flex-wrap: wrap; }
.vazni-brojevi li span { margin-right: 10px; margin-bottom: 5px; min-width: 100px; font-size: 12px; padding: 3px 8px; }
.weather-icons ul { gap: 10px; }
.weather-icons ul li { flex: 0 0 calc(50% - 5px); min-width: auto; min-height: 110px; }
.weather-icons ul li a { padding: 15px 10px; }  .weather-icons ul li a i { font-size: 28px; margin-bottom: 8px; }
.weather-icons ul li span { font-size: 10px; line-height: 13px; } 

 .map-modal .modal-dialog, .contact-modal .modal-dialog { width: 100%; max-width: 100%; }
 .map-modal .form-title, .contact-modal .form-title { font-size: 26px; line-height: 32px; padding-right: 50px; }
 .map-holder { height: 350px; } 
 .contactIcon { padding: 30px 20px; min-height: 160px; }
 .contactIcon i { font-size: 2.5rem; margin-bottom: 0.8rem; }
 .contactIcon span { font-size: 0.9rem; }
 .contactIcon .contact-detail { font-size: 0.85rem; }
 .additional-info { padding: 20px; }
 .additional-info h4 { font-size: 1rem; }
 .additional-info p { font-size: 0.9rem; }
 }
 
@media (max-width: 575.98px) {
	.modal-title-servisi { font-size: 28px; }
	.modal-subtitle-servisi { font-size: 11px !important; }
	.weather-icons ul li { flex: 0 0 100%; min-height: 100px; }
	.map-modal .form-title, .contact-modal .form-title { font-size: 22px; line-height: 28px; }
	.map-holder { height: 300px; }
}
@media (max-height: 600px) and (orientation: landscape) {
	.modal-title-servisi { font-size: 24px; }
	.modal-subtitle-servisi { font-size: 10px !important; line-height: 16px; }
	.servisi-header { padding: 15px 20px; }
	.servisi-body { padding: 15px; }
	.weather-icons ul li { min-height: 80px; }
	.weather-icons ul li a { padding: 10px; }
	.weather-icons ul li a i { font-size: 24px; margin-bottom: 5px; }
	.map-holder { height: 250px; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }  .servisi-modal .modal-dialog, .map-modal .modal-dialog, .contact-modal .modal-dialog { transition: none !important; }  .close-servisi .puls { animation: none !important; } }
@media (prefers-contrast: high) { .modal-content { border: 2px solid currentColor; }  .contactIcon, .weather-icons ul li { border: 2px solid currentColor; } }
*:focus-visible { outline: 3px solid #00d4ff; outline-offset: 2px; }
@media print { .modal, .modal-backdrop { display: none !important; } }