/**
 * Globalna dugmad — btn2 / btn3 stilovi sa referentnog sajta.
 */

.pp-btn {
	display: inline-block;
	border: 0;
	border-radius: 3px;
	cursor: pointer;
	text-decoration: none;
	font-family: var(--pp-font-body);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.3;
	padding: 15px 25px;
	text-align: center;
	color: #fff;
	background-color: var(--pp-color-brown);
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
	position: relative;
	overflow: hidden;
	z-index: 1;
	transition: box-shadow 0.3s ease;
}

.pp-btn span {
	position: relative;
	z-index: 1;
	color: #fff;
}

/* Dijagonalna "trakica" + klizeći sjaj — IDENTIČNO referenci (divi-child .btn2).
   Dva pseudo-sloja su u mirovanju blago vidljiva (rgba 0.08) i daju kosu trakicu
   na levoj strani; na hover prelaze preko dugmeta i posvetle (0.12).
   z-index:-1 radi jer .pp-btn ima position:relative + z-index:1 (svoj stacking
   context), pa se trakica crta IZNAD pozadine, a ISPOD teksta (span je z-index:1). */
.pp-btn::before,
.pp-btn::after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	height: 475%;
	width: 145%;
	background: rgba(255, 255, 255, 0.08);
	transform: translateX(-86%) translateY(-25%) rotate(45deg);
	transition: all 0.7s ease-in-out;
	pointer-events: none;
}

.pp-btn:hover::before,
.pp-btn:focus-visible::before {
	transform: translateX(-60%) translateY(-25%) rotate(45deg);
}

.pp-btn:hover::after,
.pp-btn:focus-visible::after {
	background: rgba(255, 255, 255, 0.12);
	transform: translateX(-9%) translateY(-25%) rotate(45deg);
}

.pp-btn:hover,
.pp-btn:focus-visible {
	box-shadow: 0 14px 22px -6px rgba(0, 0, 0, 0.35);
}

.pp-btn--cta {
	display: block;
	width: 240px;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.3;
	padding: 15px 20px;
	text-align: center;
	box-shadow: 0 12px 18px -6px rgba(0, 0, 0, 0.3);
}

.pp-btn--phone {
	display: block;
	font-size: 14px;
	font-weight: 300;
	line-height: 1.3em;
	padding: 10px 20px;
	max-width: 215px;
	min-width: 200px;
	width: 16vw;
	margin: 0 auto;
	text-align: center;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.pp-btn--read {
	display: block;
	width: 180px;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.3;
	padding: 15px 25px;
	text-align: center;
}

/* --service: outline varijanta u sekciji "Usluge" — bez trakice i sjaja. */
.pp-btn--service {
	display: inline-block;
	width: auto;
	max-width: 100%;
	background-color: transparent;
	background-image: none;
	border: 2px solid #fff;
	border-radius: 3px;
	box-shadow: none;
	color: #fff;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.pp-btn--service::before,
.pp-btn--service::after {
	display: none;
}

.pp-btn:hover,
.pp-btn:focus-visible {
	color: #fff;
}

.pp-btn--cta:hover,
.pp-btn--cta:focus-visible,
.pp-btn--read:hover,
.pp-btn--read:focus-visible {
	box-shadow: 0 14px 22px -6px rgba(0, 0, 0, 0.35);
}

.pp-btn--phone:hover,
.pp-btn--phone:focus-visible {
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}

.pp-btn--service:hover,
.pp-btn--service:focus-visible {
	color: #fff;
	background-color: rgba(255, 255, 255, 0.18);
	box-shadow: none;
}
