/* =====   AVISOS DO INDEX   ===== */

/* .ui-widget-content {
	background: #bd0ae3!important;
} */



.hide{
	display: none;
}
.show {
	display: block!important;
}
.chat-melhoria{
	z-index: 99;
	position: fixed;
	bottom: 0px;
	right: 0px;
	cursor: pointer;
	overflow: hidden;
	width: 270px;
	border-radius: 5px;
	cursor: pointer !important;
	animation: magnify-open 1.5s forwards !important;
	padding: 20px ;
}
.chat-melhoria h5{
	font-weight: bold;
	font-size: 18px;
}
.chat-melhoria p{
	font-size: 14px;
	color: silver;
	line-height: 14px;
}
.chat-melhoria img{
	width: 61px !important;
	float: right;
}
.chat-whats{
	z-index: 99;
	position: fixed;
	bottom: 0px;
	right: 0px;
	cursor: pointer;
	overflow: hidden;
	width: 300px;
	border-radius: 5px;
	cursor: pointer !important;
	animation: magnify-open 1.5s forwards !important;
	padding: 20px ;
}
.chat-whats h5{
	font-weight: bold;
	font-size: 18px;
}
.chat-whats p{
	font-size: 14px;
	color: silver;
	line-height: 14px;
}
.chat-whats img{
	width: 61px !important;
	float: right;
}
.texto-cookies a:hover{
	color: #000;
}
.show{
	display: block;
}
.aceitar-cookies{
	color: white;
	background-color: #000;
	text-align: center;
	margin: 9px 5px 0px 10px;
	padding: 10px 5px;
	border-radius: 3px;
	cursor: pointer;
}
.texto-cookies{
	color: #000;
	padding: 5px 5px;
	margin: 0px;
}
.aviso-cookies{
	color: black;
	z-index: 999;
	position: fixed;
	bottom: 5px;
	left: 15%;
	width: 70%;    
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15) !important;
	border-radius: 3px;
	background: #fff;
	padding: 10px 10px;
}
@media (max-width: 768px) {
	.aviso-cookies{
		z-index: 999;
		bottom: 0px !important;
		margin-bottom: 0px !important;
		left: 0px;
		width: 100% !important;     
		border-radius: 0px;
		padding: 20px;
	}
}
/* =====   FIM AVISOS DO INDEX   ===== */



.w-200{
	width: 157px;
	margin-top: 5px;
}

.cliente-topbar {
	position: relative;
	z-index: 40;
	width: 100%;
	padding: 12px 4%;
	border-bottom: 1px solid #ece8f6;
	background: #ffffff;
	box-shadow: 0 8px 24px rgba(26, 41, 89, .06);
}

.cliente-topbar .navbar {
	min-height: 54px;
	padding: 0;
}

.cliente-topbar__brand {
	display: inline-flex;
	align-items: center;
}

.cliente-topbar .navbar-toggler {
	margin-left: auto;
	border-color: rgba(91, 50, 180, .2);
}

.cliente-topbar #ca-navbar {
	background: #ffffff;
}

.cliente-topbar__logout,
.cliente-topbar__logout:hover,
.cliente-topbar__logout:focus {
	min-height: 42px;
	padding: 9px 16px;
	border: 1px solid #5b32b4;
	border-radius: 999px;
	background: #5b32b4 !important;
	color: #ffffff !important;
	font-weight: 800;
	box-shadow: none;
}

.cliente-topbar__logout--mobile {
	width: 100%;
	margin-top: 12px;
	text-align: left;
}

.cliente-topbar + #home {
	padding-top: 0;
}

.formulario{
	font-size: 18px;
	padding: 15px 15px;
	border-radius: 25px 25px 25px 0;
}

.special_description_content{
	margin-top: 135px;
}

.get-start-area .email {
	background: #ffffff !important;
}

.auth-panel {
	width: min(100%, 440px);
	padding: 24px;
	border: 1px solid rgba(255, 255, 255, .22);
	border-radius: 8px;
	background: rgba(255, 255, 255, .12);
	box-shadow: 0 18px 38px rgba(26, 41, 89, .18);
	backdrop-filter: blur(8px);
}

.auth-form .form-group {
	margin-bottom: 14px;
}

.auth-form label {
	display: block;
	margin: 0 0 6px;
	color: #fff;
	font-size: 13px;
	font-weight: 700;
}

.auth-input,
.get-start-area .auth-input {
	width: 100%;
	min-height: 48px;
	margin: 0;
	padding: 12px 16px !important;
	border: 1px solid rgba(255, 255, 255, .72) !important;
	border-radius: 8px !important;
	background: #fff !important;
	color: #1f2633;
	font-size: 16px;
	box-shadow: none;
}

.auth-input:focus,
.get-start-area .auth-input:focus {
	border-color: #fb397d !important;
	box-shadow: 0 0 0 3px rgba(251, 57, 125, .2);
	outline: 0;
}

.auth-url-field {
	display: flex;
	align-items: stretch;
	width: 100%;
	border-radius: 8px;
	overflow: hidden;
}

.auth-url-field span {
	display: inline-flex;
	align-items: center;
	padding: 0 12px;
	background: #f1eef8;
	color: #5b32b4;
	font-weight: 700;
	white-space: nowrap;
}

.auth-url-field .auth-input {
	border-radius: 0 !important;
}

.auth-panel .comment_button {
	margin-top: 6px;
}

.auth-panel .submit {
	width: 100%;
	min-height: 48px;
	border-radius: 8px !important;
	font-weight: 700;
}

.titulo{
	font-size: 55px !important;
	line-height: 55px;
}

.fs-20{
	font-size: 20px;
}

#scrollUp{
	display: none !important;
}

.text-purple{
	color: #5b32b4;
}

.input-cliente{
	width: 100% !important;
	min-height: 42px;
	margin-bottom: .9em !important;
	border-radius: 8px !important;
	padding: 9px 12px !important;
	border: 1px solid #d8dbe3 !important;
	background: #fff;
	color: #1f2633;
	box-shadow: none;
}

.input-cliente:focus{
	border-color: #5b32b4 !important;
	box-shadow: 0 0 0 3px rgba(91, 50, 180, .13);
	outline: 0;
}

.input-cliente-url{
	min-height: 42px;
	margin-bottom: .9em;
	border: 1px solid #d8dbe3;
	border-radius: 8px;
	padding: 9px 12px;
}

.input-cliente-color{
	width: 50px;
	height: 50px;
	margin-bottom: .7em;
	border-radius: 10px;
	padding: 3px;
}

.pt-100{
	padding-top: 100px;
}

label{
	margin-bottom: 0px;
}

.tema{
	width: 170px;
	height: 100%;
	margin-bottom:  20px;
	padding: 10px;
}

.celular-iframe{
	position: absolute;
	z-index: 5;
	width: 332px;
	top: 8px;
	height: 686px;
	left: 24px;
	border-radius: 51px;
}

.celular-iframemobile {
	position: absolute;
	z-index: 5;
	width: 326px;
	top: 8px;
	height: 678px;
	left: 24px;
	border-radius: 51px;
}


@media (min-width: 992px){
	.celular-iframe{
		position: absolute;
		z-index: 5;
		width: 332px;
		top: 8px;
		height: 686px;
		left: 24px;
		border-radius: 51px;
	}
}

#dot-smartphone{
	position: absolute;
	z-index: 6;
	top: 0px;
	left: 0px;
}

.btn-excluir {
	background-color: red;
	padding: 7px;
	height: 33px;
	width: 77px;
	border-radius: 6px;
}

.titulo-url{
	margin-top: 7px;
	margin-right: 5px;
}

.border-select{
	border: 4px solid transparent;
}

input[type="radio"]:checked+label {
	border: 4px solid #5b32b4;
}

.br-10{
	border-radius: 10px;
}
.br-25{
	border-radius: 25px;
}

input[type="radio"]{
	display: none;
}

.hide{
	display: none;
}

.url{
	width: 157px;
}

.w-header{
	min-height: 73px;
}

.mt-15{
	margin-top: 15px;
}

.fa-trash{
	color: red;
	padding: 4px;
}

.text-white{
	color: white !important;
}

.cursor-pointer{
	cursor: pointer;
}

.fa-times{
	color:#F27474
}

.fa-check{
	color: #3da53a;
}

.btn-link:hover {
	text-decoration: none;
}

.texto-borrado{
	text-shadow: 0px 0px 6px #000;
	color: transparent;
}

.text-esmaecido{
	color: #8e8e8e;
}

.vantagens tr{
	border-style: solid;
	border-bottom-width: 1px;
	border-top-width: 0;
	border-right-width: 0;
	border-left-width: 0;
	line-height: 32px;
}



.iframe-celular{
	position: absolute;
	z-index: 5;
	width: 332px;
	top: 8px;
	height: 686px;
	left: 24px;
	border-radius: 51px;
}

#frame {
	-ms-zoom: 0.55;
	-moz-transform: scale(0.55);
	-moz-transform-origin: 0 0;
	-o-transform: scale(0.55);
	-o-transform-origin: 0 0;
	-webkit-transform: scale(0.55);
	-webkit-transform-origin: 0 0;
}

@media (min-width: 992px){
	.iframe-celular {
		position: absolute;
		z-index: 5;
		top: 14px;
		height: 96.5%;
		width: 92.3%;
		left: 15px;
		border-radius: 52px;
	}
}

.dot-celular{
	position: absolute;
	z-index: 6;
	left: 0px;
}

.input-url-cartaoplus{
	width: 154px;
	border-radius: 28px 0px 0px 28px;
	margin-left: 13px;
	height: 65px;
	padding-top: 12px;
	font-size: 27px;
	border-right: none;
}

.input-url-seunome{
	border-left: none;
	border-radius: 0px 28px 28px 0px;
	padding: 0px;
	height: 65px;
	font-size: 27px;
	max-width: 281px;
	width: 280px;
}

.p-10{
	padding: 10px;
}

.fs-24{
	font-size: 24px;
}

.fs-18{
	font-size: 18px;
}

.purple-light{
	color: #5b32b4;
}

.mascara-cartao-home{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0px;
	z-index: 999;
}

.w-270{
	width: 270px;
}

html{
	scroll-behavior: smooth;
}

.emoji-picker-icon {
	right: 24px;
	top: 40px;
}

.input-url-cartaoplusmobile {
	width: 100px;
	border-radius: 28px 0px 0px 28px;
	margin-left: 13px;
	height: 53px;
	padding-top: 12px;
	font-size: 17px;
	border-right: none;
}
.input-url-seunomemobile {
	border-left: none;
	border-radius: 0px 28px 28px 0px;
	padding: 0px;
	height: 53px;
	font-size: 17px;
	max-width: 281px;
	width: 217px;
}


.btn-green{
	background-color: #1aa835; 
	color: white;
}

.icone-link{
	width: 40px;
	height: 40px;
	background-color: #cc0deb;
	border-radius: 50%;
	text-align: center;
}

.icone-link-fa {
	color: white;
	margin-top: 8px;
	font-size: 24px !important;
}

.ui-progressbar .ui-progressbar-value {
	margin: 0px !important;
	height: 100%;
	background: #5b32b4;
}
.ui-progressbar {
	position: relative;
}
.progress-label {
	position: absolute;
	width: 100%;
	text-align: center;
	top: 4px;
	font-weight: bold;
	color: white;
}


.shake-link{
	animation: 3s linear 0s infinite normal none running shake;
}
@-webkit-keyframes shake{0%{-webkit-transform:translateX(3px) rotate(1deg);-ms-transform:translateX(3px) rotate(1deg);transform:translateX(3px) rotate(1deg);}2.5%{-webkit-transform:translateX(-3px) rotate(-1deg);-ms-transform:translateX(-3px) rotate(-1deg);transform:translateX(-3px) rotate(-1deg);}5%{-webkit-transform:translateX(3px) rotate(1deg);-ms-transform:translateX(3px) rotate(1deg);transform:translateX(3px) rotate(1deg);}7.5%{-webkit-transform:translateX(-3px) rotate(-1deg);-ms-transform:translateX(-3px) rotate(-1deg);transform:translateX(-3px) rotate(-1deg);}10%{-webkit-transform:translateX(2px) rotate(1deg);-ms-transform:translateX(2px) rotate(1deg);transform:translateX(2px) rotate(1deg);}12.5%{-webkit-transform:translateX(-2px) rotate(-1deg);-ms-transform:translateX(-2px) rotate(-1deg);transform:translateX(-2px) rotate(-1deg);}15%{-webkit-transform:translateX(2px) rotate(1deg);-ms-transform:translateX(2px) rotate(1deg);transform:translateX(2px) rotate(1deg);}17.5%{-webkit-transform:translateX(-2px) rotate(-1deg);-ms-transform:translateX(-2px) rotate(-1deg);transform:translateX(-2px) rotate(-1deg);}20%{-webkit-transform:translateX(1px) rotate(1deg);-ms-transform:translateX(1px) rotate(1deg);transform:translateX(1px) rotate(1deg);}22.5%{-webkit-transform:translateX(-1px) rotate(-1deg);-ms-transform:translateX(-1px) rotate(-1deg);transform:translateX(-1px) rotate(-1deg);}25%{-webkit-transform:translateX(0px) rotate(0);-ms-transform:translateX(0px) rotate(0);transform:translateX(0px) rotate(0);}}
@keyframes shake{0%{-webkit-transform:translateX(3px) rotate(1deg);-ms-transform:translateX(3px) rotate(1deg);transform:translateX(3px) rotate(1deg);}2.5%{-webkit-transform:translateX(-3px) rotate(-1deg);-ms-transform:translateX(-3px) rotate(-1deg);transform:translateX(-3px) rotate(-1deg);}5%{-webkit-transform:translateX(3px) rotate(1deg);-ms-transform:translateX(3px) rotate(1deg);transform:translateX(3px) rotate(1deg);}7.5%{-webkit-transform:translateX(-3px) rotate(-1deg);-ms-transform:translateX(-3px) rotate(-1deg);transform:translateX(-3px) rotate(-1deg);}10%{-webkit-transform:translateX(2px) rotate(1deg);-ms-transform:translateX(2px) rotate(1deg);transform:translateX(2px) rotate(1deg);}12.5%{-webkit-transform:translateX(-2px) rotate(-1deg);-ms-transform:translateX(-2px) rotate(-1deg);transform:translateX(-2px) rotate(-1deg);}15%{-webkit-transform:translateX(2px) rotate(1deg);-ms-transform:translateX(2px) rotate(1deg);transform:translateX(2px) rotate(1deg);}17.5%{-webkit-transform:translateX(-2px) rotate(-1deg);-ms-transform:translateX(-2px) rotate(-1deg);transform:translateX(-2px) rotate(-1deg);}20%{-webkit-transform:translateX(1px) rotate(1deg);-ms-transform:translateX(1px) rotate(1deg);transform:translateX(1px) rotate(1deg);}22.5%{-webkit-transform:translateX(-1px) rotate(-1deg);-ms-transform:translateX(-1px) rotate(-1deg);transform:translateX(-1px) rotate(-1deg);}25%{-webkit-transform:translateX(0px) rotate(0);-ms-transform:translateX(0px) rotate(0);transform:translateX(0px) rotate(0);}}


.btn-destaque{
	border-radius: 25px;
}

.btn-destaque input[type="checkbox"] {
  display: none;
   border-radius: 5px;
}

.btn-destaque label {
	border: 4px solid white;
   padding: 4px;
   border-radius: .5rem;
}

.btn-destaque input:checked + label {
	border: 4px solid #5b32b4;
  padding: 4px;
  border-radius: .5rem;
}

.link-com-img{
	height: 50px;
}
.img-link{
	position: absolute;
	width: 40px;
	left: 22px;
    top: 15px;
}

.btn-editar-contato{
	padding: 0rem 0rem;
}

.card-header-link {
    padding: 1.55rem 1.30rem;
}

#home {
	background: #f7f7fb;
}

.area-cliente-shell {
	max-width: 1220px;
}

.cliente-hero {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	gap: 22px;
	margin-top: 28px;
	padding: 30px;
	border: 1px solid rgba(91, 50, 180, .12);
	border-radius: 18px;
	background:
		radial-gradient(circle at top right, rgba(174, 21, 230, .10), transparent 34%),
		linear-gradient(135deg, #ffffff 0%, #fbf9ff 100%);
	box-shadow: 0 22px 60px rgba(26, 41, 89, .10);
}

.cliente-hero__main {
	max-width: 620px;
}

.cliente-eyebrow {
	display: block;
	margin-bottom: 7px;
	color: #5b32b4;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0;
}

.cliente-hero h1 {
	margin-bottom: 8px;
	color: #1f2633;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.15;
}

.cliente-hero p,
.cliente-onboarding p {
	margin-bottom: 0;
	color: #5b6472;
}

.cliente-hero__actions {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-end;
	gap: 10px;
	min-width: 270px;
}

.cliente-link-chip {
	display: flex;
	align-items: center;
	gap: 8px;
	max-width: 100%;
	padding: 10px 12px;
	border: 1px solid #e1dcec;
	border-radius: 12px;
	color: #312a42;
	background: #faf9fd;
	font-size: 14px;
}

.cliente-link-chip span {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cliente-copy-btn,
.cliente-action {
	border: 0;
	border-radius: 14px;
	background: #5b32b4;
	color: #fff;
	cursor: pointer;
}

.cliente-copy-btn {
	padding: 10px 14px;
	font-weight: 700;
}

.cliente-copy-btn.copied {
	background: #24835f;
}

.cliente-tour-start {
	border: 1px solid #e1dcec;
	border-radius: 12px;
	background: #fff;
	color: #43207f;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 14px;
	font-weight: 700;
	box-shadow: 0 10px 20px rgba(26, 41, 89, .08);
}

.cliente-tour-start:hover {
	background: #f4f0fb;
}

.cliente-dashboard {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
	margin: 18px 0;
}

.cliente-stat {
	position: relative;
	padding: 18px;
	border: 1px solid rgba(91, 50, 180, .10);
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 14px 34px rgba(26, 41, 89, .06);
	overflow: hidden;
}

.cliente-stat__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	margin-bottom: 12px;
	border-radius: 12px;
	background: #f1eafd;
	color: #5b32b4;
}

.cliente-stat__label {
	display: block;
	margin-bottom: 4px;
	color: #6b7280;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
}

.cliente-stat strong {
	display: block;
	color: #1f2633;
	font-size: 22px;
	line-height: 1.1;
}

.cliente-stat small {
	display: block;
	margin-top: 6px;
	color: #697386;
	font-size: 13px;
}

.cliente-onboarding {
	margin: 16px 0;
	padding: 24px;
	border: 1px solid #e7e4f2;
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(26, 41, 89, .06);
}

.cliente-onboarding__header {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 20px;
}

.cliente-onboarding h2 {
	margin-bottom: 0;
	color: #1f2633;
	font-size: 24px;
	font-weight: 700;
}

.cliente-progress {
	min-width: 180px;
	text-align: right;
}

.cliente-progress__number {
	color: #5b32b4;
	font-size: 26px;
	font-weight: 800;
	line-height: 1;
}

.cliente-progress__bar {
	height: 8px;
	margin-top: 10px;
	overflow: hidden;
	border-radius: 999px;
	background: #ece8f6;
}

.cliente-progress__bar span {
	display: block;
	height: 100%;
	border-radius: 999px;
	background: #5b32b4;
}

.cliente-progress__status {
	margin-bottom: 8px;
	color: #5b6472;
	font-size: 13px;
}

.cliente-progress__status strong {
	color: #43207f;
}

.cliente-incomplete-alert,
.cliente-value-callout,
.cliente-next-action {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 16px 0;
	padding: 18px;
	border: 1px solid #f1d48a;
	border-radius: 16px;
	background: #fff8e6;
	box-shadow: 0 12px 28px rgba(120, 78, 0, .08);
}

.cliente-incomplete-alert strong,
.cliente-value-callout strong,
.cliente-next-action strong {
	display: block;
	color: #1f2633;
	font-weight: 800;
}

.cliente-incomplete-alert span,
.cliente-value-callout span,
.cliente-next-action small {
	display: block;
	margin-top: 4px;
	color: #6b6472;
	line-height: 1.45;
}

.cliente-incomplete-alert__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-end;
}

.cliente-mini-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 9px 13px;
	border: 1px solid #ded8ec;
	border-radius: 999px;
	background: #fff;
	color: #43207f;
	cursor: pointer;
	font-size: 13px;
	font-weight: 800;
	text-decoration: none !important;
	white-space: nowrap;
}

.cliente-mini-btn:hover,
.cliente-mini-btn:focus {
	border-color: #5b32b4;
	color: #43207f;
	text-decoration: none !important;
}

.cliente-mini-btn--primary {
	border-color: #5b32b4;
	background: #5b32b4;
	color: #fff !important;
}

.upgrade-pro-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 10px 16px;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, #5b32b4, #8b22e6);
	color: #fff !important;
	font-size: 14px;
	font-weight: 900;
	text-decoration: none !important;
	box-shadow: 0 12px 26px rgba(91, 50, 180, .24);
}

.upgrade-pro-btn:hover,
.upgrade-pro-btn:focus {
	color: #fff !important;
	transform: translateY(-1px);
	box-shadow: 0 16px 34px rgba(91, 50, 180, .28);
}

.cliente-next-action {
	border-color: #ded8ec;
	background: linear-gradient(135deg, #f8f5ff, #ffffff);
	box-shadow: none;
}

.cliente-admin-mode-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 14px 0;
	padding: 16px;
	border: 1px solid #c7bdf0;
	border-radius: 16px;
	background: linear-gradient(135deg, #f6f2ff, #ffffff);
	box-shadow: 0 12px 28px rgba(67, 32, 127, .08);
}

.cliente-admin-mode-bar span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #43207f;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.cliente-admin-mode-bar p {
	margin: 4px 0 0;
	color: #5b6472;
}

.cliente-admin-mode-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-end;
}

.cliente-admin-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 38px;
	padding: 9px 13px;
	border: 1px solid #5b32b4;
	border-radius: 999px;
	background: #5b32b4;
	color: #fff !important;
	font-size: 13px;
	font-weight: 800;
	text-decoration: none !important;
	white-space: nowrap;
}

.cliente-admin-btn--ghost {
	background: #fff;
	color: #43207f !important;
}

.cliente-admin-btn--secondary {
	background: #f4f0fc;
	border-color: #d8cef5;
	color: #5b32b4 !important;
}

.cliente-admin-logout-form {
	margin: 0;
}

/* ── Admin contas page layout ── */
.cliente-admin-page {
	max-width: 1100px;
	margin: 0 auto;
}

.cliente-admin-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}

.cliente-admin-header span {
	display: block;
	font-size: 12px;
	font-weight: 700;
	color: #5b32b4;
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-bottom: 4px;
}

.cliente-admin-header h1 {
	font-size: 28px;
	color: #1f2430;
	margin: 0 0 4px;
}

.cliente-admin-header p {
	font-size: 14px;
	color: #697386;
	margin: 0;
}

.cliente-admin-filters {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 20px;
	padding: 16px 18px;
	background: #f8f6fd;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
}

.cliente-admin-filters label {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 12px;
	font-weight: 700;
	color: #5b32b4;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.cliente-admin-filters input[type="text"],
.cliente-admin-filters input[type="search"],
.cliente-admin-filters select {
	min-width: 200px;
	height: 38px;
	padding: 0 12px;
	border: 1px solid #d8cef5;
	border-radius: 10px;
	background: #fff;
	font-size: 14px;
	color: #1f2430;
	outline: none;
	-webkit-appearance: none;
	appearance: none;
	box-shadow: none;
}

.cliente-admin-filters input[type="text"]:focus,
.cliente-admin-filters input[type="search"]:focus,
.cliente-admin-filters select:focus {
	border-color: #5b32b4;
	box-shadow: 0 0 0 3px rgba(91,50,180,.1);
}

.cliente-admin-filter-actions {
	display: flex;
	gap: 8px;
}

.cliente-admin-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 40px 20px;
	text-align: center;
	color: #697386;
	border: 1px dashed #d8cef5;
	border-radius: 14px;
}

.cliente-admin-empty strong {
	font-size: 16px;
	color: #1f2430;
}

/* ── Admin contas table ── */
.admin-contas-table {
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 4px 18px rgba(26,41,89,.05);
}

.admin-contas-table thead th {
	padding: 11px 14px;
	background: #f4f0fc;
	border-bottom: 1px solid #e7e4f2;
	color: #5b32b4;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .05em;
	white-space: nowrap;
}

.admin-contas-table thead th:first-child { border-radius: 14px 0 0 0; }
.admin-contas-table thead th:last-child  { border-radius: 0 14px 0 0; }

.admin-contas-table tbody tr {
	transition: background .1s;
}

.admin-contas-table tbody tr:hover {
	background: #faf8ff;
}

.admin-contas-table tbody td {
	padding: 11px 14px;
	border-bottom: 1px solid #f0eef8;
	vertical-align: middle;
	font-size: 14px;
	color: #1f2430;
}

.admin-contas-table tbody tr:last-child td {
	border-bottom: 0;
}

.adm-col-nome strong {
	display: block;
	font-size: 14px;
	color: #1f2430;
}

.adm-col-nome small {
	display: block;
	font-size: 12px;
	color: #697386;
	margin-top: 2px;
}

.adm-col-url a {
	font-size: 13px;
	color: #5b32b4;
	text-decoration: none;
}

.adm-col-url a:hover {
	text-decoration: underline;
}

.adm-col-data small,
.adm-col-acesso small {
	font-size: 12px;
	color: #697386;
}

.adm-col-acoes {
	white-space: nowrap;
}

.adm-col-acoes .cliente-admin-btn {
	margin-right: 6px;
	padding: 6px 11px;
	min-height: 32px;
	font-size: 12px;
}

.adm-col-acoes .cliente-admin-btn:last-child {
	margin-right: 0;
}

.cliente-admin-plan {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.cliente-admin-plan--free {
	background: #f0f0f0;
	color: #555;
}

.cliente-admin-plan--pro {
	background: #ede6ff;
	color: #5b32b4;
}

.cliente-admin-plan--store {
	background: #e6f4ea;
	color: #1e7e45;
}

.admin-contas-count {
	margin-bottom: 10px;
	font-size: 13px;
	color: #697386;
}

@media (max-width: 768px) {
	.admin-contas-table .adm-col-data,
	.admin-contas-table .adm-col-acesso { display: none; }
	.adm-col-acoes .cliente-admin-btn span { display: none; }
}

.link-whatsapp-message-field textarea.input-cliente {
	min-height: 92px;
	padding-top: 12px;
	line-height: 1.45;
	resize: vertical;
}

.sweet-alert,
.jconfirm .jconfirm-box {
	border-radius: 18px !important;
	box-shadow: 0 24px 70px rgba(15, 23, 42, .24) !important;
}

.sweet-alert h2,
.jconfirm .jconfirm-title {
	color: #1f2633 !important;
	font-weight: 900 !important;
}

@media (max-width: 768px) {
	.cliente-admin-mode-bar {
		align-items: flex-start;
		flex-direction: column;
	}

	.cliente-admin-mode-actions,
	.cliente-admin-btn {
		width: 100%;
	}
}

.cliente-next-action > div span {
	display: block;
	margin-bottom: 3px;
	color: #5b32b4;
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
}

.cliente-checklist {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.cliente-check-item {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr) auto;
	gap: 12px;
	align-items: center;
	padding: 14px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
}

.cliente-check-item__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: #f1eafd;
	color: #5b32b4;
	font-size: 17px;
}

.cliente-check-item strong,
.cliente-check-item small {
	display: block;
}

.cliente-check-item strong {
	color: #1f2633;
	font-size: 14px;
}

.cliente-check-item small {
	margin-top: 3px;
	color: #697386;
	font-size: 12px;
	line-height: 1.35;
}

.cliente-check-item--done {
	border-color: #bce4ce;
	background: #f3fbf7;
}

.cliente-check-item--done .cliente-check-item__icon {
	background: #24835f;
	color: #fff;
}

.cliente-achievements {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 16px;
}

.cliente-achievements span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 10px;
	border-radius: 999px;
	background: #f2f3f7;
	color: #7a8191;
	font-size: 12px;
	font-weight: 800;
}

.cliente-achievements span.is-earned {
	background: #f1eafd;
	color: #5b32b4;
}

.cliente-value-callout {
	border-color: #ded8ec;
	background: #fff;
	box-shadow: 0 10px 24px rgba(26, 41, 89, .06);
}

.cliente-modern-callout {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 16px 0;
	padding: 18px;
	border: 1px solid rgba(91, 50, 180, .16);
	border-radius: 16px;
	background: linear-gradient(135deg, #120c2c, #5b32b4);
	color: #fff;
	box-shadow: 0 16px 34px rgba(91, 50, 180, .18);
}

.cliente-modern-callout strong,
.cliente-modern-callout span {
	display: block;
}

.cliente-modern-callout strong {
	font-size: 17px;
}

.cliente-modern-callout span {
	margin-top: 4px;
	color: rgba(255,255,255,.78);
}

.cliente-layout-models {
	margin: 10px 0 22px;
	padding: 20px;
	border: 1px solid #e7e4f2;
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(26, 41, 89, .06);
}

.cliente-layout-models__header h5 {
	margin: 0 0 5px;
	color: #1f2633;
	font-weight: 800;
}

.cliente-layout-models__header p {
	margin: 0 0 16px;
	color: #697386;
}

.cliente-layout-model-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}

.cliente-layout-model {
	display: grid;
	grid-template-columns: 64px minmax(0, 1fr);
	gap: 12px;
	align-items: center;
	min-height: 148px;
	padding: 12px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
	color: #263041;
	cursor: pointer;
	text-align: left;
	transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.cliente-layout-model:hover {
	border-color: #5b32b4;
	box-shadow: 0 14px 28px rgba(91, 50, 180, .12);
	transform: translateY(-2px);
}

.cliente-layout-model.is-selected {
	border-color: #5b32b4;
	background: #fff;
	box-shadow: 0 16px 32px rgba(91, 50, 180, .14);
}

.cliente-layout-model.is-selected:after {
	content: "Selecionado";
	justify-self: flex-start;
	grid-column: 2;
	display: inline-flex;
	width: max-content;
	margin-top: -4px;
	padding: 4px 8px;
	border-radius: 999px;
	background: rgba(91, 50, 180, .1);
	color: #5b32b4;
	font-size: 11px;
	font-weight: 800;
}

.modelo-mini {
	position: relative;
	display: block;
	width: 64px;
	height: 112px;
	overflow: hidden;
	border-radius: 16px;
	background: linear-gradient(135deg, #5b32b4, #c400ff);
	box-shadow: inset 0 -62px 0 rgba(255,255,255,.88);
}

.modelo-mini i {
	position: absolute;
	top: 31px;
	left: 17px;
	width: 30px;
	height: 30px;
	border: 3px solid #fff;
	border-radius: 50%;
	background: #32135f;
}

.modelo-mini b,
.modelo-mini em,
.modelo-mini strong {
	position: absolute;
	left: 16px;
	right: 16px;
	display: block;
	height: 6px;
	border-radius: 999px;
	background: #dcd6ea;
}

.modelo-mini b { top: 70px; }
.modelo-mini em:nth-of-type(1) { top: 84px; }
.modelo-mini em:nth-of-type(2) { top: 96px; }
.modelo-mini strong { top: 46px; left: 44px; right: 8px; background: rgba(255,255,255,.72); }
.modelo-mini--dark { background: linear-gradient(135deg, #0f0b24, #5b32b4); box-shadow: inset 0 -62px 0 rgba(17,24,39,.92); }
.modelo-mini--business { background: linear-gradient(135deg, #f7f7fb, #dfe7ff); box-shadow: inset 0 -62px 0 #fff; }
.modelo-mini--store { background: linear-gradient(135deg, #ff7a18, #af002d); }
.modelo-mini--creator { background: linear-gradient(135deg, #c400ff, #f97316); }
.modelo-mini--local { background: linear-gradient(135deg, #166534, #84cc16); }
.modelo-mini--aurora { background: linear-gradient(135deg, #14002e, #00d4ff); }
.modelo-mini--gold { background: linear-gradient(135deg, #111111, #c9a227); box-shadow: inset 0 -62px 0 #fff8e7; }
.modelo-mini--health { background: linear-gradient(135deg, #dff7f3, #7dd3c7); box-shadow: inset 0 -62px 0 #fff; }
.modelo-mini--sunset { background: linear-gradient(135deg, #ff7a59, #7c3aed); }
.modelo-mini--nature { background: linear-gradient(135deg, #064e3b, #22c55e); box-shadow: inset 0 -62px 0 #f7fff9; }

.modelo-copy strong,
.modelo-copy small {
	display: block;
}

.modelo-copy strong {
	color: #1f2633;
	font-size: 14px;
}

.modelo-copy strong small {
	display: inline-flex;
	margin-left: 5px;
	padding: 3px 6px;
	border-radius: 999px;
	background: #16a34a;
	color: #fff;
	font-size: 10px;
}

.modelo-copy > small {
	margin-top: 4px;
	color: #697386;
	font-size: 12px;
	line-height: 1.35;
}

.cliente-fast-config .modal-content,
.cliente-fast-config {
	border: 0;
	border-radius: 18px;
	overflow: hidden;
}

.cliente-fast-config-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
}

.cliente-fast-step {
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 16px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
	color: #263041;
	cursor: pointer;
	text-align: left;
}

.cliente-fast-step:hover {
	border-color: #5b32b4;
	background: #fff;
}

.cliente-fast-step span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #5b32b4;
	color: #fff;
	font-weight: 900;
}

.cliente-fast-step strong,
.cliente-fast-step small {
	display: block;
}

.cliente-fast-step small {
	color: #697386;
	line-height: 1.35;
}

.cliente-steps {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
}

.cliente-step {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	width: 100%;
	min-height: 132px;
	padding: 14px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
	color: #263041;
	text-align: left;
	cursor: pointer;
}

.cliente-step:hover {
	border-color: #5b32b4;
	color: #263041;
	text-decoration: none;
}

.cliente-step__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 30px;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: #5b32b4;
	color: #fff;
	font-weight: 800;
}

.cliente-step strong,
.cliente-step small {
	display: block;
}

.cliente-step small {
	margin-top: 5px;
	color: #687386;
	font-size: 12px;
	line-height: 1.35;
}

.cliente-step--done {
	background: #f3fbf7;
	border-color: #bce4ce;
}

.cliente-step--done .cliente-step__icon {
	background: #24835f;
}

.cliente-quick-actions {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
	margin: 18px 0 12px;
}

.cliente-action {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
	min-height: 92px;
	padding: 16px;
	background: #fff;
	color: #263041;
	border: 1px solid rgba(91, 50, 180, .10);
	box-shadow: 0 12px 28px rgba(26, 41, 89, .06);
	text-align: left;
	transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.cliente-action > i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 42px;
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: #f1eafd;
	color: #5b32b4;
	font-size: 18px;
}

.cliente-action span {
	display: grid;
	gap: 3px;
}

.cliente-action strong,
.cliente-action small {
	display: block;
}

.cliente-action strong {
	color: #1f2633;
	font-size: 15px;
}

.cliente-action small {
	color: #697386;
	font-size: 12px;
	line-height: 1.35;
}

.cliente-action:hover,
.cliente-copy-btn:hover {
	background: #fff;
	border-color: #5b32b4;
	box-shadow: 0 18px 38px rgba(91, 50, 180, .14);
	transform: translateY(-2px);
}

.cliente-workspace {
	padding: 22px;
	border: 1px solid #e7e4f2;
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 12px 28px rgba(26, 41, 89, .07);
}

.cliente-tabs {
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	border-bottom: 0;
	overflow-x: auto;
	padding: 6px;
	margin-bottom: 18px;
	border-radius: 14px;
	background: #f4f2fa;
}

.cliente-tabs .nav-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border: 0;
	border-radius: 11px;
	font-weight: 700;
	white-space: nowrap;
	color: #4a3c72 !important;
}

.cliente-tabs .nav-link.active {
	background: #5b32b4;
	color: #fff !important;
	box-shadow: 0 10px 24px rgba(91, 50, 180, .22);
}

.cliente-tab-pending {
	position: relative;
}

.cliente-tab-pending:after {
	content: "";
	position: absolute;
	top: 8px;
	right: 8px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #f4b740;
	box-shadow: 0 0 0 3px rgba(244, 183, 64, .18);
}

.cliente-field-help {
	margin: 6px 0 0;
	color: #6b7280;
	font-size: 12px;
	line-height: 1.4;
}

.cliente-preview-tips {
	display: grid;
	gap: 8px;
	margin-top: 14px;
	padding: 14px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(26, 41, 89, .06);
}

.cliente-preview-tips strong {
	display: flex;
	gap: 8px;
	align-items: center;
	color: #1f2633;
	font-size: 14px;
}

.cliente-preview-tips button {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	align-items: center;
	width: 100%;
	padding: 9px 10px;
	border: 1px solid #ede9f5;
	border-radius: 10px;
	background: #faf9fd;
	color: #4a3c72;
	cursor: pointer;
	font-size: 12px;
	font-weight: 700;
	text-align: left;
}

.cliente-links-starter {
	margin-bottom: 16px;
	padding: 18px;
	border: 1px solid #e7e4f2;
	border-radius: 16px;
	background: linear-gradient(135deg, #ffffff, #fbf9ff);
	box-shadow: 0 10px 24px rgba(26, 41, 89, .05);
}

.cliente-links-starter h3 {
	margin: 0 0 6px;
	color: #1f2633;
	font-size: 20px;
	font-weight: 800;
}

.cliente-links-starter p {
	margin: 0 0 14px;
	color: #697386;
}

.cliente-suggestion-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
}

.cliente-suggestion-card {
	display: grid;
	gap: 6px;
	min-height: 118px;
	padding: 12px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #fff;
	color: #263041;
	cursor: pointer;
	text-align: left;
	transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.cliente-suggestion-card:hover {
	border-color: #5b32b4;
	box-shadow: 0 12px 26px rgba(91, 50, 180, .12);
	transform: translateY(-2px);
}

.cliente-suggestion-card i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 11px;
	background: #f1eafd;
	color: #5b32b4;
}

.cliente-suggestion-card strong,
.cliente-suggestion-card small {
	display: block;
}

.cliente-suggestion-card small {
	color: #697386;
	font-size: 11px;
	line-height: 1.35;
}

.cliente-empty-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 14px;
}

.cliente-empty-actions button {
	min-height: 36px;
	padding: 8px 12px;
	border: 1px solid #ded8ec;
	border-radius: 999px;
	background: #fff;
	color: #43207f;
	cursor: pointer;
	font-size: 12px;
	font-weight: 800;
}

.cliente-preview-column {
	position: sticky;
	top: 18px;
	align-self: flex-start;
}

.cliente-preview-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 12px;
	padding: 0 6px;
	color: #4b5563;
	font-size: 13px;
	font-weight: 800;
}

.cliente-preview-toolbar a {
	color: #5b32b4;
	font-weight: 800;
}

.cliente-phone-preview {
	position: relative;
	width: min(100%, 360px);
	aspect-ratio: 9 / 18.5;
	margin: 0 auto;
	padding: 12px;
	border-radius: 34px;
	background: #111827;
	box-shadow: 0 22px 60px rgba(13, 18, 32, .28);
}

.cliente-phone-preview:before {
	content: "";
	position: absolute;
	top: 8px;
	left: 50%;
	width: 72px;
	height: 6px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .22);
	transform: translateX(-50%);
	z-index: 2;
}

.cliente-phone-preview .celular-iframe,
.cliente-phone-preview .celular-iframemobile {
	position: relative;
	top: auto;
	left: auto;
	z-index: 1;
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: 24px;
	background: #fff;
}

.cliente-link-card {
	border: 0;
	border-radius: 14px;
	margin-bottom: 10px;
	box-shadow: 0 10px 26px rgba(26, 41, 89, .06);
	overflow: hidden;
}

.cliente-sort-hint {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 14px;
	padding: 12px 14px;
	border: 1px dashed #cfc6ef;
	border-radius: 14px;
	background: #fbfaff;
	color: #5f6880;
	font-size: 13px;
	line-height: 1.4;
}

.cliente-sort-hint i {
	color: #5b32b4;
	font-size: 18px;
}

.cliente-link-sort-placeholder {
	min-height: 76px;
	margin-bottom: 10px;
	border: 2px dashed #5b32b4;
	border-radius: 14px;
	background: #f4efff;
}

.cliente-link-card.ui-sortable-helper {
	box-shadow: 0 18px 42px rgba(91, 50, 180, .22);
}

.cliente-link-card--dragging {
	opacity: .68;
	box-shadow: 0 18px 42px rgba(91, 50, 180, .18);
}

.cliente-link-section-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 18px 0 10px;
	padding: 10px 12px;
	border: 1px solid #e7e4f2;
	border-radius: 12px;
	background: #f8f6fd;
	color: #253047;
	cursor: default;
}

.cliente-link-section-title span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 900;
}

.cliente-link-section-title i {
	color: #5b32b4;
}

.cliente-link-section-title small {
	color: #697386;
	font-size: 12px;
	line-height: 1.35;
	text-align: right;
}

.cliente-link-card .card-header {
	padding: 0;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #fff;
}

.cliente-link-row {
	width: 100%;
	min-height: 76px;
	display: grid;
	grid-template-columns: 34px 46px minmax(0, 1fr) auto 34px;
	align-items: center;
	gap: 12px;
	padding: 14px;
	color: #263041;
	text-align: left;
}

.cliente-link-row__drag {
	width: 34px;
	height: 46px;
	border: 1px solid #e7e4f2;
	border-radius: 12px;
	background: #faf9fd;
	color: #5b32b4;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 17px;
	cursor: grab;
	touch-action: none;
	user-select: none;
}

.cliente-link-row__drag:active {
	cursor: grabbing;
}

.cliente-link-row__drag:hover {
	background: #f1eafd;
	border-color: #d7c8f8;
}

.cliente-link-row__icon {
	width: 46px;
	height: 46px;
	border-radius: 14px;
	background: #f1eafd;
	color: #5b32b4;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
}

.cliente-link-row__content {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.cliente-link-row__content strong,
.cliente-link-row__content small {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cliente-link-row__content strong {
	color: #1f2633;
	font-size: 15px;
}

.cliente-link-row__content small {
	color: #697386;
	font-size: 12px;
}

.cliente-link-row__meta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.cliente-soft-badge,
.cliente-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	border-radius: 999px;
	padding: 6px 10px;
	font-size: 12px;
	font-weight: 800;
}

.cliente-soft-badge {
	background: #f4f2fa;
	color: #5b32b4;
}

.cliente-soft-badge--locked {
	color: #fff;
	background: #5b32b4;
}

.cliente-status-badge {
	background: #e8f8ef;
	color: #24835f;
}

.cliente-link-row__action {
	width: 34px;
	height: 34px;
	border: 0;
	border-radius: 10px;
	background: transparent;
	color: #8a92a6;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.cliente-link-row__action:hover,
.cliente-link-row__action:focus {
	background: #f1eafd;
	color: #5b32b4;
	outline: 0;
}

.cliente-link-card--inactive {
	opacity: .72;
}

.cliente-link-card--inactive .cliente-link-row {
	grid-template-columns: 46px minmax(0, 1fr) auto;
}

.cliente-link-restore {
	justify-self: end;
	width: auto;
	max-width: max-content;
	border: 0;
	border-radius: 999px;
	background: #f1eafd;
	color: #5b32b4;
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	min-height: 32px;
	padding: 0 12px;
	cursor: pointer;
	white-space: nowrap;
}

/* ── Links table ── */
.cliente-links-table {
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 4px 18px rgba(26, 41, 89, .05);
	margin-bottom: 10px;
}

.cliente-sort-guide {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 10px;
	padding: 8px 12px;
	border: 1px solid #e8ddff;
	border-radius: 10px;
	background: #f7f2ff;
	color: #5b32b4;
	font-size: 12px;
	font-weight: 700;
}

.cliente-sort-guide i {
	font-size: 14px;
}

.cliente-links-table__head th {
	padding: 10px 12px;
	background: #f8f6fd;
	border-bottom: 1px solid #e7e4f2;
	color: #5b32b4;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	white-space: nowrap;
}

.cliente-links-table__head th:first-child { border-radius: 14px 0 0 0; }
.cliente-links-table__head th:last-child  { border-radius: 0 14px 0 0; }

.cliente-links-table tbody tr.cliente-link-card {
	transition: background .12s;
}

.cliente-links-table tbody tr.cliente-link-card:hover {
	background: #faf8ff;
}

.cliente-links-table tbody tr.cliente-link-card td,
.cliente-links-table tbody tr.cliente-link-card--inactive td {
	padding: 10px 12px;
	border-bottom: 1px solid #f0eef8;
	vertical-align: middle;
}

.cliente-links-table tbody tr:last-child td {
	border-bottom: 0;
}

.cliente-link-section-tr td {
	padding: 8px 12px !important;
	background: #f4f0fc;
	color: #5b32b4;
	font-size: 12px;
	font-weight: 800;
	border-bottom: 1px solid #e7e4f2 !important;
}

.cliente-link-section-tr td i {
	margin-right: 5px;
}

.cliente-link-section-tr td small {
	color: #8a72c8;
	font-weight: 400;
}

.clt-drag  { width: 38px; text-align: center; }
.clt-icon  { width: 48px; text-align: center; }
.clt-title strong { font-size: 14px; color: #1f2633; }
.clt-type small,
.clt-format small { font-size: 12px; color: #697386; }
.clt-views { white-space: nowrap; }
.clt-status { white-space: nowrap; }
.clt-action { width: 40px; text-align: center; }

.cliente-status-badge--inactive {
	background: #f5f5f5;
	color: #8a92a6;
}

@media (max-width: 600px) {
	.clt-type, .clt-format { display: none; }
}

.cliente-empty-state {
	border: 1px dashed #cdd3e1;
	border-radius: 16px;
	background: #fbfcff;
	padding: 28px;
	margin-bottom: 12px;
	text-align: center;
	color: #697386;
	display: grid;
	justify-items: center;
	gap: 8px;
}

.cliente-empty-state i {
	width: 44px;
	height: 44px;
	border-radius: 14px;
	background: #f1eafd;
	color: #5b32b4;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
}

.cliente-empty-state strong {
	color: #1f2633;
	font-size: 16px;
}

#nav-conta #accordion {
	display: grid;
	gap: 14px;
}

#nav-conta .card,
#nav-template .card {
	border: 1px solid #e7e4f2;
	border-radius: 16px;
	box-shadow: 0 10px 26px rgba(26, 41, 89, .05);
	overflow: hidden;
}

#nav-conta .card-header {
	background: #fff;
	border-bottom: 1px solid #edf0f7;
	padding: 0;
}

#nav-conta .btn-link {
	width: 100%;
	padding: 18px 20px;
	text-align: left;
	color: #1f2633;
	font-weight: 800;
	text-decoration: none;
}

#nav-conta .card-body {
	padding: 20px;
	color: #263041;
}

.profile-editor {
	display: grid;
	gap: 18px;
}

.profile-editor__header {
	padding: 22px 24px;
	border: 1px solid #e7e3f2;
	border-radius: 18px;
	background:
		radial-gradient(circle at top right, rgba(91, 50, 180, .10), transparent 32%),
		linear-gradient(135deg, #ffffff 0%, #fbfaff 100%);
	box-shadow: 0 16px 36px rgba(26, 41, 89, .07);
}

.profile-editor__header h3 {
	margin: 0 0 6px;
	color: #202638;
	font-size: 24px;
	font-weight: 800;
	line-height: 1.2;
}

.profile-editor__header p {
	margin: 0;
	max-width: 680px;
	color: #657085;
	font-size: 15px;
	line-height: 1.45;
}

.profile-editor-card,
.profile-actions-card {
	padding: 22px;
	border: 1px solid #e7e3f2;
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 14px 32px rgba(26, 41, 89, .06);
}

.profile-editor-card + .profile-editor-card {
	margin-top: 16px;
}

.profile-editor-card__head {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 20px;
}

.profile-editor-card__head > i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 42px;
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: #f0e9ff;
	color: #5b32b4;
	font-size: 17px;
}

.profile-editor-card__head h4 {
	margin: 0 0 4px;
	color: #202638;
	font-size: 18px;
	font-weight: 800;
	line-height: 1.25;
}

.profile-editor-card__head p {
	margin: 0;
	color: #657085;
	font-size: 14px;
	line-height: 1.45;
}

.profile-fields-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.profile-field {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.profile-field--full {
	grid-column: 1 / -1;
}

.profile-field span {
	color: #202638;
	font-size: 14px;
	font-weight: 800;
}

.profile-field small {
	color: #6d778b;
	font-size: 12px;
	line-height: 1.4;
}

.profile-field .input-cliente {
	margin-bottom: 0 !important;
	min-height: 50px;
	border-radius: 14px !important;
	background: #fff;
}

.profile-upload-row {
	display: grid;
	grid-template-columns: 126px minmax(0, 1fr);
	align-items: center;
	gap: 18px;
	padding: 16px;
	border: 1px dashed #cfc7e8;
	border-radius: 16px;
	background: #fbfaff;
}

.profile-avatar-preview {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 126px;
	height: 126px;
	border: 4px solid #fff;
	border-radius: 32px;
	background: linear-gradient(135deg, #eee7ff, #fbfaff);
	background-position: center;
	background-size: cover;
	color: #5b32b4;
	font-size: 38px;
	box-shadow: 0 14px 28px rgba(30, 22, 63, .14);
}

.profile-upload-copy,
.profile-vcard-box > div {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.profile-upload-copy strong,
.profile-vcard-box strong {
	color: #202638;
	font-size: 16px;
	font-weight: 800;
}

.profile-upload-copy span,
.profile-vcard-box span {
	color: #657085;
	font-size: 14px;
	line-height: 1.45;
}

.profile-upload-copy small,
.profile-vcard-box small {
	color: #7a8496;
	font-size: 12px;
	font-weight: 700;
	word-break: break-word;
}

.profile-upload-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: max-content;
	max-width: 100%;
	min-height: 40px;
	margin: 4px 0 0;
	padding: 9px 14px;
	border: 1px solid #ded8ec;
	border-radius: 999px;
	background: #fff;
	color: #4f28a5 !important;
	cursor: pointer;
	font-size: 13px;
	font-weight: 800;
	text-decoration: none !important;
	transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.profile-upload-btn:hover,
.profile-upload-btn:focus {
	border-color: #5b32b4;
	box-shadow: 0 10px 20px rgba(91, 50, 180, .12);
	transform: translateY(-1px);
}

.profile-vcard-box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px;
	border: 1px solid #e1dcec;
	border-radius: 16px;
	background: #fbfaff;
}

.profile-vcard-box--locked {
	border-color: #eadff9;
	background: linear-gradient(135deg, #fbf8ff, #ffffff);
}

.profile-actions-card {
	position: sticky;
	bottom: 14px;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-top: 18px;
	box-shadow: 0 18px 42px rgba(26, 41, 89, .12);
}

.profile-actions-card > span {
	color: #6d778b;
	font-size: 13px;
	font-weight: 700;
}

.profile-actions-card.is-dirty > span {
	color: #4f28a5;
}

.profile-actions-card > div {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
}

.profile-actions-card .submit-btn {
	min-height: 42px;
	padding: 10px 16px;
	border-radius: 999px;
	font-weight: 800;
}

.profile-actions-card .submit-btn:disabled {
	cursor: wait;
	opacity: .78;
}

.input-cliente,
.input-cliente-link,
.link-editor-select {
	border: 1px solid #d8dce6 !important;
	border-radius: 12px !important;
	min-height: 46px;
	padding: 0 14px;
	transition: border-color .16s ease, box-shadow .16s ease;
}

.input-cliente:focus,
.input-cliente-link:focus,
.link-editor-select:focus {
	border-color: #5b32b4 !important;
	box-shadow: 0 0 0 4px rgba(91, 50, 180, .12);
	outline: 0;
}

.cliente-tour-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(13, 18, 32, .42);
	z-index: 1990;
	opacity: 0;
	pointer-events: none;
	transition: opacity .22s ease;
}

.cliente-tour-backdrop.is-visible {
	opacity: 1;
	pointer-events: auto;
}

.cliente-tour-card {
	position: fixed;
	width: min(360px, calc(100vw - 24px));
	z-index: 2010;
	opacity: 0;
	pointer-events: none;
	transform: translateY(10px);
	transition: opacity .22s ease, transform .22s ease;
	background: #fff;
	border: 1px solid #e7e4f2;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(13, 18, 32, .24);
	padding: 16px;
}

.cliente-tour-card.is-visible {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.cliente-tour-card__top,
.cliente-tour-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.cliente-tour-card__top span {
	color: #5b32b4;
	font-size: 13px;
	font-weight: 800;
}

.cliente-tour-card__top button {
	border: 0;
	background: transparent;
	color: #6c647d;
	cursor: pointer;
	font-size: 16px;
}

.cliente-tour-card h3 {
	margin: 12px 0 6px;
	color: #1f2433;
	font-size: 20px;
}

.cliente-tour-card p {
	color: #52596b;
	font-size: 14px;
	line-height: 1.45;
}

.cliente-tour-check {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #52596b;
	font-size: 13px;
	margin: 12px 0;
}

.cliente-tour-actions button {
	border: 0;
	border-radius: 8px;
	min-height: 40px;
	padding: 0 14px;
	font-weight: 700;
	cursor: pointer;
}

#clienteTourPrev {
	background: #f1eef7;
	color: #43207f;
}

#clienteTourPrev:disabled {
	opacity: .45;
	cursor: not-allowed;
}

#clienteTourNext {
	background: #5b32b4;
	color: #fff;
}

.cliente-tour-highlight {
	position: relative;
	z-index: 2000;
	border-radius: 8px;
	box-shadow: 0 0 0 4px rgba(255, 255, 255, .95), 0 0 0 8px rgba(91, 50, 180, .55) !important;
	animation: cliente-tour-pulse 1.4s ease-in-out infinite;
}

@keyframes cliente-tour-pulse {
	0%, 100% {
		box-shadow: 0 0 0 4px rgba(255, 255, 255, .95), 0 0 0 8px rgba(91, 50, 180, .45);
	}
	50% {
		box-shadow: 0 0 0 4px rgba(255, 255, 255, .95), 0 0 0 12px rgba(91, 50, 180, .18);
	}
}

.tema-card {
	height: 150px;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid #e4e7ef;
	box-shadow: 0 10px 22px rgba(26, 41, 89, .08);
}

.tema-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tema-card--gradient {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 16px;
}

.tema-card--gradient span {
	width: 100%;
	border-radius: 999px;
	padding: 9px 12px;
	font-weight: 800;
	text-align: center;
	box-shadow: 0 8px 20px rgba(13, 18, 32, .14);
}

.tema-card__title {
	display: block;
	margin-top: 8px;
	color: #2b3040;
	font-size: 14px;
	text-align: center;
}

@media (max-width: 991px) {
	.cliente-hero,
	.cliente-onboarding__header {
		flex-direction: column;
	}

	.cliente-hero__actions {
		align-items: stretch;
		min-width: 0;
	}

	.cliente-dashboard,
	.cliente-quick-actions,
	.cliente-checklist {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cliente-suggestion-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cliente-fast-config-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cliente-incomplete-alert,
	.cliente-value-callout,
	.cliente-next-action,
	.cliente-modern-callout {
		align-items: flex-start;
		flex-direction: column;
	}

	.cliente-layout-model-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cliente-preview-column {
		position: static;
		order: 2;
	}

	.cliente-steps {
		grid-template-columns: 1fr;
	}

	.cliente-step {
		min-height: auto;
	}

	.cliente-progress {
		text-align: left;
	}
}

@media (max-width: 575px) {
	.cliente-hero,
	.cliente-onboarding,
	.cliente-workspace {
		padding: 16px;
	}

	.cliente-hero h1 {
		font-size: 26px;
	}

	.cliente-dashboard,
	.cliente-quick-actions,
	.cliente-checklist,
	.cliente-suggestion-grid,
	.cliente-fast-config-grid {
		grid-template-columns: 1fr;
	}

	.cliente-check-item {
		grid-template-columns: 42px minmax(0, 1fr);
	}

	.cliente-check-item .cliente-mini-btn {
		grid-column: 1 / -1;
	}

	.cliente-link-row {
		grid-template-columns: 34px 42px minmax(0, 1fr);
	}

	.cliente-link-row__meta,
	.cliente-link-row__action {
		grid-column: 3;
	}

	.cliente-link-card--inactive .cliente-link-row {
		grid-template-columns: 42px minmax(0, 1fr);
	}

	.cliente-link-card--inactive .cliente-link-restore {
		grid-column: 2;
		justify-self: start;
		margin-top: 4px;
	}

	.cliente-link-section-title,
	.cliente-sort-hint {
		align-items: flex-start;
		flex-direction: column;
	}

	.cliente-link-section-title small {
		text-align: left;
	}

	.cliente-phone-preview {
		width: min(100%, 330px);
	}

	.cliente-tabs .nav-link {
		width: auto;
		border-radius: 8px;
	}
}

.img-tipo-link{
	width: 100px;
    height: 37px;
}
.img-tipo-social{
	width: 37px;
	height: 37px;
}
@media (min-width: 992px){
	.img-tipo-link{
		height: 50px;
		width: 175px;
	}
	.img-tipo-social{
		height: 50px;
		width: 50px;
	}
}

.bg-video {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    overflow: hidden; 
}
.bg-video > video {
    width: 100%;
}















/* store */
.card-produto{
	box-shadow: 3px 3px 7px rgb(0 0 0 / 56%);
	    min-height: 315px;
}
.btn-editar-produto{
	position: absolute;
    bottom: 3px;
    right: 3px;
}

.select2-container--default .select2-selection--multiple {
    background-color: white !important;
    border: 1px solid #151515 !important;
    border-radius: 10px !important;
    cursor: text;
}
.loading-backdrop {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1040;
    background-color: rgba(0,0,0,0.5);
    z-index: 99999;
}
.classImagemLoad{
    position: fixed;
    text-align: center;
    width: 300px;
    height: 130px;
    margin-top: 100px;
    margin-left: 50%;
    left: -150px;
    z-index: 99999;
    background-color: white;
}

.classImagemLoad span{
    position: relative;
    float: left;
    width: 100%;
    font-size: 20px;
    font-weight: bold;
    color: #004C70;
}

.classLoadPercenutal{
    height: 20px;
    width: 300px;
    /*background-color: greenyellow;*/
    position: relative;
    float: left;
    margin-top: 10px;
}




.upload-drop-zone {
  height: 200px;
  border-width: 2px;
  margin-bottom: 20px;
}

/* skin.css Style*/
.upload-drop-zone {
  color: #ccc;
  border-style: dashed;
  border-color: #ccc;
  line-height: 200px;
  text-align: center
}
.upload-drop-zone.drop {
  color: #222;
  border-color: #222;
}


.hll { background-color: #ffffcc; }

.c { color: #408080; font-style: italic; }

/* Comment */
.err { border: 1px solid #FF0000; }

/* Error */
.k { color: #008000; font-weight: bold; }

/* Keyword */
.o { color: #666666; }

/* Operator */
.cm { color: #9AA5AD; font-style: italic; }

/* Comment.Multiline */
.cp { color: #BC7A00; }

/* Comment.Preproc */
.c1 { color: #9AA5AD; font-style: italic; }

/* Comment.Single */
.cs { color: #408080; font-style: italic; }

/* Comment.Special */
.gd { color: #A00000; }

/* Generic.Deleted */
.ge { font-style: italic; }

/* Generic.Emph */
.gr { color: #FF0000; }

/* Generic.Error */
.gh { color: #000080; font-weight: bold; }

/* Generic.Heading */
.gi { color: #00A000; }

/* Generic.Inserted */
.go { color: #808080; }

/* Generic.Output */
.gp { color: #000080; font-weight: bold; }

/* Generic.Prompt */
.gs { font-weight: bold; }

/* Generic.Strong */
.gu { color: #800080; font-weight: bold; }

/* Generic.Subheading */
.gt { color: #0040D0; }

/* Generic.Traceback */
.kc { color: #008000; font-weight: bold; }

/* Keyword.Constant */
.kd { color: #229EFF; font-weight: bold; }

/* Keyword.Declaration */
.kn { color: #008000; font-weight: bold; }

/* Keyword.Namespace */
.kp { color: #008000; }

/* Keyword.Pseudo */
.kr { color: #008000; font-weight: bold; }

/* Keyword.Reserved */
.kt { color: #B00040; }

/* Keyword.Type */
.m { color: #666666; }

/* Literal.Number */
.s { color: #CB0C6A; }

/* Literal.String */
.na { color: #C38D00; }

/* Name.Attribute */
.nb { color: #008000; }

/* Name.Builtin */
.nc { color: #0000FF; font-weight: bold; }

/* Name.Class */
.no { color: #880000; }

/* Name.Constant */
.nd { color: #AA22FF; }

/* Name.Decorator */
.ni { color: #999999; font-weight: bold; }

/* Name.Entity */
.ne { color: #D2413A; font-weight: bold; }

/* Name.Exception */
.nf { color: #0000FF; }

/* Name.Function */
.nl { color: #A0A000; }

/* Name.Label */
.nn { color: #0000FF; font-weight: bold; }

/* Name.Namespace */
.nt { color: #0081E5; font-weight: bold; }

/* Name.Tag */
.nv { color: #19177C; }

/* Name.Variable */
.ow { color: #AA22FF; font-weight: bold; }

/* Operator.Word */
.w { color: #bbbbbb; }

/* Text.Whitespace */
.mf { color: #666666; }

/* Literal.Number.Float */
.mh { color: #666666; }

/* Literal.Number.Hex */
.mi { color: #666666; }

/* Literal.Number.Integer */
.mo { color: #666666; }

/* Literal.Number.Oct */
.sb { color: #BA2121; }

/* Literal.String.Backtick */
.sc { color: #BA2121; }

/* Literal.String.Char */
.sd { color: #BA2121; font-style: italic; }

/* Literal.String.Doc */
.s2 { color: #D50069; }

/* Literal.String.Double */
.se { color: #BB6622; font-weight: bold; }

/* Literal.String.Escape */
.sh { color: #BA2121; }

/* Literal.String.Heredoc */
.si { color: #BB6688; font-weight: bold; }

/* Literal.String.Interpol */
.sx { color: #008000; }

/* Literal.String.Other */
.sr { color: #BB6688; }

/* Literal.String.Regex */
.s1 { color: #BA2121; }

/* Literal.String.Single */
.ss { color: #19177C; }

/* Literal.String.Symbol */
.bp { color: #008000; }

/* Name.Builtin.Pseudo */
.vc { color: #19177C; }

/* Name.Variable.Class */
.vg { color: #19177C; }

/* Name.Variable.Global */
.vi { color: #19177C; }

/* Name.Variable.Instance */
.il { color: #666666; }

/* Literal.Number.Integer.Long */
.nx { color: #4C556B; }

#dropzone { margin-bottom: 3rem; }

.dropzone { border: 2px dashed #0087F7; border-radius: 5px; background: white; }
.dropzone .dz-message { font-weight: 400; }
.dropzone .dz-message .note { font-size: 0.8em; font-weight: 200; display: block; margin-top: 1.4rem; }


@-webkit-keyframes passing-through {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30%, 70% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
    100% {
        opacity: 0;
        -webkit-transform: translateY(-40px);
        -moz-transform: translateY(-40px);
        -ms-transform: translateY(-40px);
        -o-transform: translateY(-40px);
        transform: translateY(-40px);
    }
}
@-moz-keyframes passing-through {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30%, 70% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
    100% {
        opacity: 0;
        -webkit-transform: translateY(-40px);
        -moz-transform: translateY(-40px);
        -ms-transform: translateY(-40px);
        -o-transform: translateY(-40px);
        transform: translateY(-40px);
    }
}
@keyframes passing-through {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30%, 70% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
    100% {
        opacity: 0;
        -webkit-transform: translateY(-40px);
        -moz-transform: translateY(-40px);
        -ms-transform: translateY(-40px);
        -o-transform: translateY(-40px);
        transform: translateY(-40px);
    }
}
@-webkit-keyframes slide-in {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
}
@-moz-keyframes slide-in {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
}
@keyframes slide-in {
    0% {
        opacity: 0;
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        -o-transform: translateY(40px);
        transform: translateY(40px);
    }
    30% {
        opacity: 1;
        -webkit-transform: translateY(0px);
        -moz-transform: translateY(0px);
        -ms-transform: translateY(0px);
        -o-transform: translateY(0px);
        transform: translateY(0px);
    }
}
@-webkit-keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
    10% {
        -webkit-transform: scale(1.1);
        -moz-transform: scale(1.1);
        -ms-transform: scale(1.1);
        -o-transform: scale(1.1);
        transform: scale(1.1);
    }
    20% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
}
@-moz-keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
    10% {
        -webkit-transform: scale(1.1);
        -moz-transform: scale(1.1);
        -ms-transform: scale(1.1);
        -o-transform: scale(1.1);
        transform: scale(1.1);
    }
    20% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
}
@keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
    10% {
        -webkit-transform: scale(1.1);
        -moz-transform: scale(1.1);
        -ms-transform: scale(1.1);
        -o-transform: scale(1.1);
        transform: scale(1.1);
    }
    20% {
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
}
.dropzone, .dropzone * {
    box-sizing: border-box;
}
.dropzone {
    min-height: 150px;
    border: 2px solid rgba(0, 0, 0, 0.3);
    background: white;
    padding: 54px 54px;
}
.dropzone.dz-clickable {
    cursor: pointer;
}
.dropzone.dz-clickable * {
    cursor: default;
}
.dropzone.dz-clickable .dz-message, .dropzone.dz-clickable .dz-message * {
    cursor: pointer;
}
.dropzone.dz-started .dz-message {
    display: none;
}
.dropzone.dz-drag-hover {
    border-style: solid;
}
.dropzone.dz-drag-hover .dz-message {
    opacity: 0.5;
}
.dropzone .dz-message {
    text-align: center;
    margin: 2em 0;
}
.dropzone .dz-preview {
    position: relative;
    display: inline-block;
    vertical-align: top;
    margin: 16px;
    min-height: 100px;
}
.dropzone .dz-preview:hover {
    z-index: 1000;
}
.dropzone .dz-preview:hover .dz-details {
    opacity: 1;
}
.dropzone .dz-preview.dz-file-preview .dz-image {
    border-radius: 20px;
    background: #999;
    background: linear-gradient(to bottom, #eee, #ddd);
}
.dropzone .dz-preview.dz-file-preview .dz-details {
    opacity: 1;
}
.dropzone .dz-preview.dz-image-preview {
    background: white;
}
.dropzone .dz-preview.dz-image-preview .dz-details {
    -webkit-transition: opacity 0.2s linear;
    -moz-transition: opacity 0.2s linear;
    -ms-transition: opacity 0.2s linear;
    -o-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
}
.dropzone .dz-preview .dz-remove {
    font-size: 14px;
    text-align: center;
    display: block;
    cursor: pointer;
    border: none;
}
.dropzone .dz-preview .dz-remove:hover {
    text-decoration: underline;
}
.dropzone .dz-preview:hover .dz-details {
    opacity: 1;
}
.dropzone .dz-preview .dz-details {
    z-index: 20;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    font-size: 13px;
    min-width: 100%;
    max-width: 100%;
    padding: 2em 1em;
    text-align: center;
    color: rgba(0, 0, 0, 0.9);
    line-height: 150%;
}
.dropzone .dz-preview .dz-details .dz-size {
    margin-bottom: 1em;
    font-size: 16px;
}
.dropzone .dz-preview .dz-details .dz-filename {
    white-space: nowrap;
}
.dropzone .dz-preview .dz-details .dz-filename:hover span {
    border: 1px solid rgba(200, 200, 200, 0.8);
    background-color: rgba(255, 255, 255, 0.8);
}
.dropzone .dz-preview .dz-details .dz-filename:not(:hover) {
    overflow: hidden;
    text-overflow: ellipsis;
}
.dropzone .dz-preview .dz-details .dz-filename:not(:hover) span {
    border: 1px solid transparent;
}
.dropzone .dz-preview .dz-details .dz-filename span, .dropzone .dz-preview .dz-details .dz-size span {
    background-color: rgba(255, 255, 255, 0.4);
    padding: 0 0.4em;
    border-radius: 3px;
}
.dropzone .dz-preview:hover .dz-image img {
    -webkit-transform: scale(1.05, 1.05);
    -moz-transform: scale(1.05, 1.05);
    -ms-transform: scale(1.05, 1.05);
    -o-transform: scale(1.05, 1.05);
    transform: scale(1.05, 1.05);
    -webkit-filter: blur(8px);
    filter: blur(8px);
}
.dropzone .dz-preview .dz-image {
    border-radius: 20px;
    overflow: hidden;
    width: 120px;
    height: 120px;
    position: relative;
    display: block;
    z-index: 10;
}
.dropzone .dz-preview .dz-image img {
    display: block;
}
.dropzone .dz-preview.dz-success .dz-success-mark {
    -webkit-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
    -moz-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
    -ms-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
    -o-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
    animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
}
.dropzone .dz-preview.dz-error .dz-error-mark {
    opacity: 1;
    -webkit-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
    -moz-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
    -ms-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
    -o-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
    animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
}
.dropzone .dz-preview .dz-success-mark, .dropzone .dz-preview .dz-error-mark {
    pointer-events: none;
    opacity: 0;
    z-index: 500;
    position: absolute;
    display: block;
    top: 50%;
    left: 50%;
    margin-left: -27px;
    margin-top: -27px;
}
.dropzone .dz-preview .dz-success-mark svg, .dropzone .dz-preview .dz-error-mark svg {
    display: block;
    width: 54px;
    height: 54px;
}
.dropzone .dz-preview.dz-processing .dz-progress {
    opacity: 1;
    -webkit-transition: all 0.2s linear;
    -moz-transition: all 0.2s linear;
    -ms-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    transition: all 0.2s linear;
}
.dropzone .dz-preview.dz-complete .dz-progress {
    opacity: 0;
    -webkit-transition: opacity 0.4s ease-in;
    -moz-transition: opacity 0.4s ease-in;
    -ms-transition: opacity 0.4s ease-in;
    -o-transition: opacity 0.4s ease-in;
    transition: opacity 0.4s ease-in;
}
.dropzone .dz-preview:not(.dz-processing) .dz-progress {
    -webkit-animation: pulse 6s ease infinite;
    -moz-animation: pulse 6s ease infinite;
    -ms-animation: pulse 6s ease infinite;
    -o-animation: pulse 6s ease infinite;
    animation: pulse 6s ease infinite;
}
.dropzone .dz-preview .dz-progress {
    opacity: 1;
    z-index: 1000;
    pointer-events: none;
    position: absolute;
    height: 16px;
    left: 50%;
    top: 50%;
    margin-top: -8px;
    width: 80px;
    margin-left: -40px;
    background: rgba(255, 255, 255, 0.9);
    -webkit-transform: scale(1);
    border-radius: 8px;
    overflow: hidden;
}
.dropzone .dz-preview .dz-progress .dz-upload {
    background: #333;
    background: linear-gradient(to bottom, #666, #444);
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 0;
    -webkit-transition: width 300ms ease-in-out;
    -moz-transition: width 300ms ease-in-out;
    -ms-transition: width 300ms ease-in-out;
    -o-transition: width 300ms ease-in-out;
    transition: width 300ms ease-in-out;
}
.dropzone .dz-preview.dz-error .dz-error-message {
    display: block;
}
.dropzone .dz-preview.dz-error:hover .dz-error-message {
    opacity: 1;
    pointer-events: auto;
}

.ui-state-default-placeholder{
    background: #fff4b5 !important;

    min-width: 12.5%;
}

.dropzone .dz-preview .dz-error-message {
    pointer-events: none;
    z-index: 1000;
    position: absolute;
    display: block;
    display: none;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -ms-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    border-radius: 8px;
    font-size: 13px;
    top: 130px;
    left: -10px;
    width: 140px;
    background: #be2626;
    background: linear-gradient(to bottom, #be2626, #a92222);
    padding: 0.5em 1.2em;
    color: white;
}
.dropzone .dz-preview .dz-error-message:after {
    content:'';
    position: absolute;
    top: -6px;
    left: 64px;
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 6px solid #be2626;
}


.btn-excluir-galeria{
	position: absolute;
}
.destaque-galeria{
	position: absolute;
	background-color: #0000ff6b;
	width: 86px;
	z-index: 0;
	height: 101px;
	top: -15px;
	border-radius: 7px;
	text-align: center;
}
.z-9{
	z-index: 9;
}


.checkbox-pagamento:checked+label {
    border: 2px solid #5b32b4;
    border-radius: 7px;
}
.label-pagamento{
	border: 2px solid transparent;
}
.img-pagamento{
	width: 50px;
}


.select-plano{
	width: 100%;
    background: #ae15e6;
    height: 90px;
    padding-top: 13px;
    font-size: 21px;
    color: white;
}

.select-plano:checked+label {
    border: 8px solid #5b32b4 !important;
}

.link-editor-select {
    min-height: 46px;
    border-radius: 8px;
    border: 1px solid #d8dce6;
    background-color: #fff;
    color: #253047;
    font-size: 15px;
    padding: 0 14px;
}

.legacy-icon-grid {
    display: none !important;
}

.link-icon-select-field {
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.link-icon-select-field .link-editor-icon-select {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.link-icon-preview {
    width: 46px;
    height: 46px;
    border: 1px solid #d8dce6;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fc;
    color: #5b32b4;
    font-size: 20px;
}

.link-icon-choice-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
    gap: 8px;
    max-height: 260px;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 4px 4px 8px;
    scrollbar-color: #c9bbef #f5f2fb;
}

.link-icon-choice {
    border: 1px solid #d8dce6;
    background: #fff;
    border-radius: 12px;
    min-height: 64px;
    padding: 9px 8px;
    display: grid;
    justify-items: center;
    align-items: center;
    gap: 5px;
    color: #253047;
    cursor: pointer;
    text-align: center;
    transition: border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.link-icon-choice i {
    color: #5b32b4;
    font-size: 20px;
    text-align: center;
}

.link-icon-choice span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 12px;
    font-weight: 700;
}

.link-icon-choice:hover,
.link-icon-choice.is-selected {
    border-color: #5b32b4;
    background: #f6f2ff;
    box-shadow: 0 8px 18px rgba(91, 50, 180, .12);
}

.link-icon-choice.is-selected {
    font-weight: 700;
}

.link-image-field {
    display: grid;
    gap: 10px;
}

.link-image-upload {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    width: 100%;
    min-height: 86px;
    border: 1px dashed #bfc7d7;
    border-radius: 8px;
    background: #fbfcff;
    padding: 10px;
    cursor: pointer;
    transition: border-color .16s ease, background .16s ease;
}

.link-image-upload--banner {
    grid-template-columns: 150px minmax(0, 1fr);
    align-items: center;
    min-height: 82px;
}

.link-image-upload:hover {
    border-color: #5b32b4;
    background: #f7f3ff;
}

.link-image-preview {
    width: 72px;
    height: 72px;
    border-radius: 8px;
    background-color: #eef1f7;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #5b32b4;
    font-size: 24px;
    overflow: hidden;
}

.link-image-preview--banner {
    width: 150px;
    height: 58px;
    border-radius: 9px;
}

.link-image-copy {
    display: grid;
    gap: 3px;
    color: #253047;
}

.link-image-copy strong {
    font-size: 15px;
}

.link-image-copy small,
.link-image-copy em {
    color: #6b7280;
    font-size: 13px;
    font-style: normal;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.link-image-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
}

.link-image-remove {
    border: 0 !important;
    border-radius: 6px !important;
    background: #dc3545 !important;
    color: #fff !important;
    min-height: 24px !important;
    padding: 0 7px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1;
    cursor: pointer;
}

.link-image-remove i {
    font-size: 10px !important;
}

.link-image-remove--compact {
    width: auto !important;
    max-width: max-content !important;
}

.link-image-remove.is-loading {
    opacity: .75;
    cursor: wait;
}

.layout-editor-stack {
    display: grid;
    gap: 18px;
}

.layout-editor-card {
    padding: 20px;
    border: 1px solid #e7e4f2;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(26, 41, 89, .06);
}

.layout-editor-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.layout-editor-card__head h5 {
    margin: 0 0 6px;
    color: #1f2633;
    font-size: 20px;
    font-weight: 900;
}

.layout-editor-card__head p {
    max-width: 720px;
    margin: 0;
    color: #697386;
    line-height: 1.55;
}

.layout-secondary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 9px 13px;
    border: 1px solid #e7e4f2;
    border-radius: 12px;
    background: #fff;
    color: #5b32b4;
    font-weight: 800;
    cursor: pointer;
}

.layout-danger-btn {
    color: #dc3545;
}

.layout-palette-block {
    display: grid;
    gap: 10px;
    margin-bottom: 16px;
}

.layout-palette-block > strong {
    color: #253047;
    font-size: 14px;
}

.layout-palette-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.layout-palette-chip {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 10px;
    min-height: 94px;
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid #e7e4f2;
    border-radius: 14px;
    background: #faf9fd;
    color: #253047;
    cursor: pointer;
    font-weight: 800;
    text-align: left;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.layout-palette-chip span {
    flex: 0 0 auto;
    width: 100%;
    min-height: 34px;
    overflow-wrap: anywhere;
    word-break: normal;
    white-space: normal;
    line-height: 1.25;
}

.layout-palette-chip:hover,
.layout-palette-chip:focus {
    border-color: #5b32b4;
    box-shadow: 0 12px 24px rgba(91, 50, 180, .12);
    transform: translateY(-1px);
}

.layout-palette-chip.is-selected {
    border-color: #5b32b4;
    background: #ffffff;
    box-shadow: 0 14px 28px rgba(91, 50, 180, .14);
}

.layout-palette-chip em {
    display: flex;
    width: 100%;
    flex: 0 0 auto;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-start;
    font-style: normal;
}

.layout-palette-chip i {
    width: 12px;
    height: 12px;
    flex: 0 0 auto;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 999px;
}

.layout-palette-chip small {
    color: #697386;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
}

.layout-palette-chip.is-selected small {
    color: #5b32b4;
    font-weight: 800;
}

.layout-section-subtitle {
    margin: 18px 0 10px;
    color: #253047;
    font-size: 14px;
    font-weight: 900;
}

.layout-color-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
}

.layout-color-card {
    display: grid;
    gap: 10px;
    min-height: 106px;
    margin: 0;
    padding: 13px;
    border: 1px solid #e7e4f2;
    border-radius: 14px;
    background: #faf9fd;
    cursor: pointer;
}

.layout-color-card > span {
    color: #253047;
    font-size: 13px;
    font-weight: 900;
}

.layout-color-card > small {
    min-height: 18px;
    color: #6f7788;
    font-size: 12px;
    line-height: 1.35;
}

.layout-color-card div {
    display: grid;
    grid-template-columns: 42px minmax(72px, 1fr) 34px;
    gap: 8px;
    align-items: center;
    min-width: 0;
}

.layout-color-card input[type="color"] {
    width: 42px;
    height: 42px;
    padding: 0;
    border: 0;
    border-radius: 12px;
    background: transparent;
    cursor: pointer;
}

.layout-color-card strong {
    color: #1f2633;
    font-size: 13px;
    letter-spacing: 0;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.layout-color-card button {
    width: 34px;
    height: 34px;
    border: 1px solid #e7e4f2;
    border-radius: 10px;
    background: #fff;
    color: #5b32b4;
    cursor: pointer;
}

.layout-contrast-alert {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-top: 14px;
    padding: 10px 12px;
    border: 1px solid #fde68a;
    border-radius: 12px;
    background: #fffbeb;
    color: #92400e;
    font-size: 13px;
    font-weight: 700;
}

.layout-upload-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 240px;
    gap: 16px;
    align-items: stretch;
}

.layout-cover-controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
}

.layout-cover-controls label {
    display: grid;
    gap: 7px;
    margin: 0;
    padding: 13px;
    border: 1px solid #e7e4f2;
    border-radius: 14px;
    background: #faf9fd;
}

.layout-cover-controls label span {
    color: #253047;
    font-size: 13px;
    font-weight: 900;
}

.layout-cover-controls select {
    min-height: 42px;
}

.layout-upload-drop {
    display: grid;
    gap: 12px;
    min-height: 180px;
    padding: 18px;
    border: 1px dashed #c9cedb;
    border-radius: 16px;
    background: #faf9fd;
}

.layout-upload-drop label {
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    min-height: 108px;
    margin: 0;
    border-radius: 14px;
    background: #fff;
    color: #5b32b4;
    cursor: pointer;
}

.layout-upload-drop label i {
    font-size: 30px;
}

.layout-upload-drop label strong {
    color: #1f2633;
    font-size: 16px;
}

.layout-upload-drop label span,
.layout-upload-drop small {
    color: #697386;
    text-align: center;
}

.layout-background-panel,
.layout-background-actions {
    display: none;
}

.btn-purple {
    background: #5b32b4;
    border-color: #5b32b4;
    color: #fff !important;
}

.btn-purple:hover,
.btn-purple:focus {
    background: #492890;
    border-color: #492890;
    color: #fff !important;
}

.layout-background-preview {
    min-height: 180px;
    border-radius: 16px;
    border: 1px dashed #c9cedb;
    background-color: #f4f6fb;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #7a8191;
    font-size: 14px;
    overflow: hidden;
}

.layout-cover-preview {
    min-height: 132px;
    color: rgba(255,255,255,.92);
    font-weight: 800;
    text-shadow: 0 1px 8px rgba(0,0,0,.28);
}

.layout-style-grid,
.layout-photo-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.layout-style-card,
.layout-photo-card {
    position: relative;
    display: grid;
    gap: 12px;
    align-content: start;
    min-height: 152px;
    padding: 14px;
    border: 1px solid #e7e4f2;
    border-radius: 16px;
    background: #faf9fd;
    color: #253047;
    text-align: left;
    cursor: pointer;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.layout-style-card:hover,
.layout-style-card:focus,
.layout-photo-card:hover,
.layout-photo-card:focus {
    border-color: #5b32b4;
    box-shadow: 0 14px 28px rgba(91, 50, 180, .12);
    transform: translateY(-1px);
}

.layout-style-card.is-selected,
.layout-photo-card.is-selected {
    border-color: #5b32b4;
    background: #fff;
    box-shadow: 0 16px 32px rgba(91, 50, 180, .14);
}

.layout-style-card.is-selected:after,
.layout-photo-card.is-selected:after {
    content: "\f00c";
    position: absolute;
    top: 10px;
    right: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #5b32b4;
    color: #fff;
    font-family: "Font Awesome 5 Free";
    font-size: 11px;
    font-weight: 900;
}

.layout-style-card > strong,
.layout-photo-card > strong {
    color: #1f2633;
    font-size: 14px;
}

.layout-style-card > small,
.layout-photo-card > small {
    color: #697386;
    font-size: 12px;
}

.layout-button-preview {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 14px;
    font-weight: 900;
    pointer-events: none;
}

.layout-social-preview {
    display: flex;
    gap: 8px;
    align-items: center;
}

.layout-social-preview i {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin: 0;
    pointer-events: none;
}

.layout-photo-card {
    text-align: center;
    place-items: center;
}

.layout-photo-card img {
    width: 82px;
    height: 82px;
    object-fit: cover;
}

.layout-legacy-hidden {
    display: none !important;
}

.layout-save-bar {
    position: sticky;
    bottom: 14px;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 18px 0 0;
    padding: 12px 14px;
    border: 1px solid rgba(91, 50, 180, .18);
    border-radius: 16px;
    background: rgba(15, 11, 36, .95);
    color: #fff;
    box-shadow: 0 18px 40px rgba(15, 11, 36, .22);
}

.layout-save-bar button {
    border: 0;
    border-radius: 999px;
    background: #fff;
    color: #5b32b4;
    padding: 9px 13px;
    font-weight: 900;
}

.cliente-preview-column {
    position: sticky;
    top: 92px;
    align-self: flex-start;
}

.emojionearea .emojionearea-picker {
    z-index: 2050;
}

.link-editor-dialog {
    max-width: 920px;
    margin: 24px auto;
    height: calc(100vh - 48px);
    display: flex;
    align-items: stretch;
}

.link-editor-modal {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    max-height: calc(100vh - 48px);
    overflow: hidden;
    border: 0;
    border-radius: 18px;
    box-shadow: 0 28px 80px rgba(15, 11, 36, .28);
}

.link-editor-modal > [id^="content-modal-"] {
    display: flex;
    flex: 1 1 auto;
    min-height: 0;
    flex-direction: column;
}

.link-editor-modal__header {
    flex: 0 0 auto;
    align-items: flex-start;
    gap: 14px;
    padding: 20px 24px;
    border-bottom: 1px solid #ece8f6;
    background: linear-gradient(135deg, #ffffff 0%, #fbfaff 100%);
}

.link-editor-modal__header h5 {
    margin: 0 0 4px;
    color: #1f2633;
    font-size: 22px;
    font-weight: 900;
}

.link-editor-modal__header p {
    margin: 0;
    color: #697386;
    font-size: 14px;
}

.link-editor-body {
    flex: 1 1 auto;
    max-height: none;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 20px 24px;
    background: #f7f7fb;
}

.link-editor-intro,
.link-button-preview-card,
.link-performance-card {
    margin-bottom: 14px;
    padding: 16px;
    border: 1px solid #e7e4f2;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(26, 41, 89, .05);
}

.link-editor-intro h4 {
    margin: 0 0 4px;
    color: #1f2633;
    font-size: 20px;
    font-weight: 900;
}

.link-editor-intro p,
.link-field-help {
    margin: 4px 0 0;
    color: #697386;
    font-size: 13px;
    line-height: 1.45;
}

.link-editor-form {
    display: block;
}

.link-editor-grid > [class*="col-"] {
    margin-bottom: 12px;
    padding: 16px;
    border: 1px solid #e7e4f2;
    border-radius: 16px;
    background: #fff;
}

.link-editor-grid > .col-md-4 {
    flex: 0 0 100%;
    max-width: 100%;
}

.modal-body form[id^="formLink-"] .row,
#formAddNew .row {
    margin-left: 0;
    margin-right: 0;
    row-gap: 8px;
}

.modal-body form[id^="formLink-"] label,
#formAddNew label {
    color: #253047;
    font-size: 14px;
    font-weight: 600;
}

.link-layout-choice-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}

.link-layout-choice input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.link-layout-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 156px;
	margin: 0;
	padding: 12px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
	cursor: pointer;
	transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.link-icon-toolbar {
	display: grid;
	gap: 10px;
	margin: 10px 0;
}

.link-icon-search {
	width: 100%;
	min-height: 42px;
	padding: 9px 12px;
	border: 1px solid #d8dce6;
	border-radius: 12px;
	background: #fff;
	color: #253047;
}

.link-icon-search:focus {
	border-color: #5b32b4;
	box-shadow: 0 0 0 4px rgba(91, 50, 180, .12);
	outline: 0;
}

.link-icon-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.link-icon-filter button {
	min-height: 34px;
	padding: 7px 10px;
	border: 1px solid #e7e4f2;
	border-radius: 999px;
	background: #fff;
	color: #4d5870;
	cursor: pointer;
	font-size: 12px;
	font-weight: 800;
}

.link-icon-filter button.is-active {
	border-color: #5b32b4;
	background: #f1eafd;
	color: #4b2599;
}

.link-button-preview-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
	align-items: center;
	gap: 16px;
}

.link-button-preview-card strong,
.link-performance-card strong {
	color: #1f2633;
	font-weight: 900;
}

.link-button-preview-card small,
.link-performance-card small {
	display: block;
	color: #697386;
	font-size: 12px;
}

.link-button-preview {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	align-items: center;
	gap: 10px;
	min-height: 56px;
	padding: 10px 12px;
	border: 1px solid #e7e4f2;
	border-radius: 16px;
	background: #5b32b4;
	color: #fff;
	box-shadow: 0 12px 28px rgba(91, 50, 180, .16);
}

.link-button-preview span {
	grid-row: 1 / span 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: rgba(255,255,255,.18);
}

.link-button-preview strong,
.link-button-preview small {
	color: inherit;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.link-button-preview.is-round {
	display: inline-grid;
	grid-template-columns: 52px minmax(0, 1fr);
	background: #fff;
	color: #1f2633;
	box-shadow: none;
}

.link-button-preview.is-round span {
	width: 52px;
	height: 52px;
	border-radius: 18px;
	background: #f1eafd;
	color: #5b32b4;
}

.link-button-preview.is-featured {
	animation: cardPlusPulse 3.8s ease-in-out infinite;
}

.link-button-preview.is-banner {
	min-height: 112px;
	align-content: end;
	background: linear-gradient(135deg, #111827, #5b32b4);
	background-position: center;
	background-size: cover;
}

.link-performance-card__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}

.link-performance-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: flex-end;
}

.link-performance-filters button {
	display: inline-flex;
	padding: 6px 10px;
	border: 1px solid #e7e4f2;
	border-radius: 999px;
	background: #fff;
	color: #5b32b4;
	cursor: pointer;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.link-performance-filters button.is-active {
	border-color: #5b32b4;
	background: #f1eafd;
}

.link-performance-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
	margin-bottom: 14px;
}

.link-performance-grid div {
	padding: 12px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
}

.link-performance-grid div strong {
	display: block;
	margin-top: 4px;
	font-size: 17px;
}

.link-performance-bars {
	display: grid;
	gap: 8px;
}

.link-performance-bar {
	display: grid;
	grid-template-columns: 48px minmax(0, 1fr) 34px;
	align-items: center;
	gap: 8px;
	color: #697386;
	font-size: 12px;
}

.link-performance-bar i {
	display: block;
	height: 9px;
	border-radius: 999px;
	background: #eee9f8;
	overflow: hidden;
}

.link-performance-bar b {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: #5b32b4;
}

.link-performance-empty {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	padding: 12px;
	border: 1px dashed #d8d1ea;
	border-radius: 14px;
	background: #fbfaff;
	color: #697386;
	font-weight: 800;
}

.link-performance-empty a {
	color: #5b32b4;
}

.link-legacy-access-row {
	display: none;
}

.btn-admin-primary,
.btn-admin-secondary,
.btn-admin-danger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 10px 14px;
	border-radius: 999px;
	cursor: pointer;
	font-size: 14px;
	font-weight: 900;
	text-decoration: none !important;
}

.btn-admin-primary {
	border: 1px solid #5b32b4;
	background: #5b32b4;
	color: #fff !important;
}

.btn-admin-secondary {
	border: 1px solid #ded8ec;
	background: #fff;
	color: #43207f !important;
}

.btn-admin-danger {
	border: 1px solid #fecaca;
	background: #fff5f5;
	color: #dc2626 !important;
}

.link-editor-footer {
	position: relative;
	bottom: auto;
    flex: 0 0 auto;
	z-index: 4;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 24px;
	border-top: 1px solid #ece8f6;
	background: rgba(255,255,255,.96);
	backdrop-filter: blur(10px);
}

.link-editor-footer > div {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
}

.link-layout-card:hover {
	border-color: #5b32b4;
	box-shadow: 0 12px 24px rgba(91, 50, 180, .12);
	transform: translateY(-1px);
}

.link-layout-choice input:checked + .link-layout-card {
	border-color: #5b32b4;
	background: #fff;
	box-shadow: 0 16px 32px rgba(91, 50, 180, .14);
}

.link-layout-choice input:checked + .link-layout-card:after {
	content: "\f00c";
	position: absolute;
	top: 9px;
	right: 9px;
	display: grid;
	place-items: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #5b32b4;
	color: #fff;
	font-family: "Font Awesome 5 Free";
	font-size: 11px;
	font-weight: 900;
}

.link-layout-card strong {
	color: #20283a;
	font-size: 14px;
}

.link-layout-card strong small {
	display: inline-flex;
	margin-left: 4px;
	padding: 2px 6px;
	border-radius: 999px;
	background: #16a34a;
	color: #fff;
	font-size: 10px;
}

.link-layout-card > small {
	color: #697386;
	font-size: 12px;
	line-height: 1.35;
}

.link-layout-preview {
	display: grid;
	gap: 6px;
	place-items: center;
	min-height: 54px;
	border-radius: 12px;
	background: #fff;
}

.link-layout-preview i,
.link-layout-preview b,
.link-layout-preview em {
	display: block;
	background: #5b32b4;
}

.link-layout-card--round .link-layout-preview i {
	width: 42px;
	height: 42px;
	border-radius: 50%;
}

.link-layout-card--rect .link-layout-preview b,
.link-layout-card--featured .link-layout-preview b {
	width: 78%;
	height: 30px;
	border-radius: 8px;
}

.link-layout-card--featured .link-layout-preview b {
	box-shadow: 0 10px 20px rgba(91, 50, 180, .22);
	animation: cardPlusPulse 3.8s ease-in-out infinite;
}

.link-layout-card--banner .link-layout-preview {
	align-content: end;
	padding: 8px;
	background: linear-gradient(135deg, #111827, #5b32b4);
}

.link-layout-card--banner .link-layout-preview b,
.link-layout-card--banner .link-layout-preview em {
	width: 72%;
	height: 7px;
	border-radius: 999px;
	background: rgba(255,255,255,.86);
}

.link-layout-banner-mini {
	display: grid;
	place-items: center;
	min-height: 66px;
	color: #5b32b4;
	font-size: 26px;
}

.link-banner-field,
.link-banner-background-field {
	display: none;
}

form:has(input[name="Formato"][value="Banner"]:checked) .link-banner-field,
form:has(input[name="Formato"][value="Banner"]:checked) .link-banner-background-field {
	display: block;
}

.link-premium-colors {
	position: relative;
	display: grid;
	gap: 12px;
	margin-top: 8px;
	padding: 14px;
	border: 1px solid #e7e4f2;
	border-radius: 14px;
	background: #faf9fd;
}

.link-premium-colors strong,
.link-premium-colors small {
	display: block;
}

.link-premium-colors small {
	margin-top: 3px;
	color: #697386;
}

.link-color-mode {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.link-color-mode label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 38px;
	margin: 0;
	padding: 8px 11px;
	border: 1px solid #e7e4f2;
	border-radius: 999px;
	background: #fff;
	color: #253047;
	font-size: 13px;
	font-weight: 800;
	cursor: pointer;
}

.link-color-mode input {
	margin: 0;
	accent-color: #5b32b4;
}

.link-color-mode label:has(input:checked) {
	border-color: #5b32b4;
	background: #f1eafd;
	color: #4b2599;
}

.link-premium-color-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.link-premium-color-grid label {
	display: grid;
	gap: 6px;
	margin: 0;
}

.link-premium-color-grid input {
	width: 100%;
	height: 42px;
	padding: 4px;
	border: 1px solid #dfe3ef;
	border-radius: 12px;
	background: #fff;
}

.link-premium-colors.is-locked .link-premium-color-grid {
	opacity: .35;
	pointer-events: none;
}

.link-premium-lock {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	padding: 10px 12px;
	border-radius: 12px;
	background: #fff;
	color: #253047;
	font-weight: 800;
}

.link-premium-lock i {
	color: #5b32b4;
}

.link-premium-lock a {
	margin-left: auto;
	color: #5b32b4;
}

/* Public landing */
.public-header {
    position: sticky;
    top: 0;
    z-index: 1030;
    background: rgba(15, 11, 36, 0.92);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(16px);
}

.public-nav {
    min-height: 76px;
    padding: 12px 0;
}

.public-brand img,
.public-footer img {
    width: 176px;
    height: auto;
}

.public-toggler {
    border-color: rgba(255, 255, 255, 0.25);
    background: rgba(255, 255, 255, 0.08);
}

.public-toggler .navbar-toggler-icon {
    filter: invert(1);
}

.public-menu .nav-link {
    color: rgba(255, 255, 255, 0.82) !important;
    font-size: 15px;
    font-weight: 700;
    padding: 10px 14px !important;
}

.public-menu .nav-link:hover,
.public-menu .nav-link:focus {
    color: #ffffff !important;
}

.public-nav-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-left: 16px;
}

.btn-public {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 11px 18px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.1;
    text-decoration: none !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.btn-public:hover,
.btn-public:focus {
    transform: translateY(-1px);
    text-decoration: none !important;
}

.btn-public-primary {
    background: linear-gradient(135deg, #5b2ec6, #a100ff);
    box-shadow: 0 16px 34px rgba(91, 46, 198, 0.28);
    color: #ffffff !important;
}

.btn-public-primary:hover,
.btn-public-primary:focus {
    box-shadow: 0 20px 42px rgba(91, 46, 198, 0.36);
}

.btn-public-secondary {
    background: #ffffff;
    border-color: #e6e2f5;
    color: #5b2ec6 !important;
    box-shadow: 0 12px 26px rgba(31, 36, 48, 0.08);
}

.btn-public-ghost {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.18);
    color: #ffffff !important;
}

.btn-public-lg {
    min-height: 52px;
    padding: 15px 24px;
}

.public-landing {
    overflow: hidden;
    background: #f7f7fb;
    color: #1f2430;
}

.public-hero {
    position: relative;
    isolation: isolate;
    min-height: calc(100vh - 76px);
    padding: 82px 0 72px;
    background:
        radial-gradient(circle at 82% 18%, rgba(196, 0, 255, 0.24), transparent 32%),
        radial-gradient(circle at 24% 6%, rgba(83, 83, 255, 0.22), transparent 30%),
        linear-gradient(135deg, #0f0b24 0%, #23115b 48%, #5b2ec6 100%);
    color: #ffffff;
}

.public-hero:before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(circle at 78% 22%, rgba(196, 0, 255, 0.36), transparent 30%),
        radial-gradient(circle at 18% 12%, rgba(88, 80, 236, 0.34), transparent 34%),
        linear-gradient(135deg, #0f0b24 0%, #24114f 48%, #5b2ec6 100%);
}

.public-hero:after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(90deg, rgba(15, 11, 36, .9) 0%, rgba(24, 13, 62, .78) 44%, rgba(91, 46, 198, .25) 100%),
        radial-gradient(circle at 88% 72%, rgba(255, 255, 255, .12), transparent 28%);
}

.public-hero > .container {
    position: relative;
    z-index: 1;
}

.public-hero-copy {
    max-width: 680px;
}

.public-eyebrow,
.public-section-heading span {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 16px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(91, 46, 198, 0.1);
    color: #5b2ec6;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.public-hero .public-eyebrow {
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
}

.public-hero h1 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(40px, 7vw, 72px);
    font-weight: 900;
    line-height: 0.98;
    letter-spacing: 0;
}

.public-lead {
    max-width: 590px;
    margin: 22px 0 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: 20px;
    line-height: 1.6;
}

.public-positioning {
    margin: 18px 0 0;
    color: #ffffff;
    font-size: 16px;
    font-weight: 800;
}

.public-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.public-hero-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}

.public-hero-pills span {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    padding: 9px 13px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    font-weight: 800;
}

.public-hero-visual {
    position: relative;
    display: flex;
    justify-content: center;
    margin-top: 42px;
}

.public-phone {
    width: min(330px, 80vw);
    padding: 13px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 42px;
    background: linear-gradient(160deg, rgba(255,255,255,0.22), rgba(255,255,255,0.06));
    box-shadow: 0 34px 80px rgba(0, 0, 0, 0.36);
}

.public-phone-screen {
    overflow: hidden;
    min-height: 560px;
    padding: 24px 20px;
    border-radius: 32px;
    background:
        radial-gradient(circle at top, rgba(255,255,255,0.75), transparent 25%),
        linear-gradient(180deg, #fefcff 0%, #f3edff 100%);
    color: #1f2430;
    text-align: center;
}

.phone-cover {
    height: 112px;
    margin: -24px -20px 0;
    background: linear-gradient(135deg, #5b2ec6, #c400ff);
}

.phone-avatar {
    width: 92px;
    height: 92px;
    margin: -42px auto 14px;
    border: 5px solid #ffffff;
    border-radius: 30px;
    background:
        radial-gradient(circle at 35% 30%, #ffffff 0 10%, transparent 11%),
        linear-gradient(135deg, #19122f, #aa42ff);
    box-shadow: 0 12px 24px rgba(91, 46, 198, 0.24);
}

.public-phone-screen strong {
    display: block;
    font-size: 24px;
    font-weight: 900;
}

.public-phone-screen > span {
    display: block;
    margin-top: 4px;
    color: #6b7280;
    font-size: 14px;
}

.phone-socials {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin: 18px 0;
}

.phone-socials i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #ffffff;
    color: #5b2ec6;
    box-shadow: 0 10px 18px rgba(91, 46, 198, 0.14);
}

.phone-link {
    margin: 10px 0;
    padding: 13px 14px;
    border: 1px solid #ece8f7;
    border-radius: 16px;
    background: #ffffff;
    color: #1f2430;
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 10px 20px rgba(31, 36, 48, 0.06);
}

.phone-link-primary {
    background: #17c964;
    color: #ffffff;
}

.phone-store {
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 12px;
    align-items: center;
    margin-top: 18px;
    padding: 12px;
    border-radius: 18px;
    background: #111827;
    color: #ffffff;
    text-align: left;
}

.phone-store div:first-child {
    height: 58px;
    border-radius: 14px;
    background: linear-gradient(135deg, #ffc857, #c400ff);
}

.phone-store b,
.phone-store small {
    display: block;
}

.phone-store small {
    color: rgba(255,255,255,0.7);
}

.public-floating-card {
    position: absolute;
    display: inline-flex;
    gap: 8px;
    align-items: center;
    padding: 12px 14px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.92);
    color: #1f2430;
    font-weight: 900;
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.18);
}

.public-floating-card i {
    color: #5b2ec6;
}

.public-floating-card-qr {
    top: 12%;
    left: 2%;
}

.public-floating-card-wa {
    right: 0;
    bottom: 14%;
}

.public-section {
    padding: 88px 0;
    background: #f7f7fb;
}

.public-section-white {
    background: #ffffff;
}

.public-section-heading {
    max-width: 760px;
    margin: 0 auto 38px;
    text-align: center;
}

.public-section-heading.text-left {
    margin-left: 0;
    margin-right: 0;
}

.public-section-heading h2 {
    margin: 0;
    color: #1f2430;
    font-size: clamp(30px, 4vw, 48px);
    font-weight: 900;
    line-height: 1.08;
}

.public-section-heading p {
    margin: 14px 0 0;
    color: #6b7280;
    font-size: 18px;
    line-height: 1.65;
}

.public-grid {
    display: grid;
    gap: 18px;
}

.public-grid-3,
.public-grid-4 {
    grid-template-columns: 1fr;
}

.public-card,
.public-feature-card,
.public-step-card,
.public-demo-card,
.public-price-card,
.public-dark-card {
    height: 100%;
    border: 1px solid #e9e7f3;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 14px 32px rgba(31, 36, 48, 0.07);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.public-card:hover,
.public-feature-card:hover,
.public-step-card:hover,
.public-demo-card:hover,
.public-price-card:hover {
    border-color: rgba(91, 46, 198, 0.22);
    box-shadow: 0 20px 44px rgba(31, 36, 48, 0.11);
    transform: translateY(-3px);
}

.public-step-card {
    position: relative;
    padding: 30px;
    margin-bottom: 18px;
}

.public-step-card b {
    position: absolute;
    top: 22px;
    right: 24px;
    color: rgba(91, 46, 198, 0.12);
    font-size: 56px;
    line-height: 1;
}

.public-step-card i,
.public-card i,
.public-feature-card i,
.public-dark-card i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    margin-bottom: 20px;
    border-radius: 16px;
    background: rgba(91, 46, 198, 0.1);
    color: #5b2ec6;
    font-size: 20px;
}

.public-step-card h3,
.public-card h3,
.public-feature-card h3,
.public-dark-card h3,
.public-demo-card h3,
.public-price-card h3 {
    margin: 0 0 10px;
    color: #1f2430;
    font-size: 20px;
    font-weight: 900;
}

.public-step-card p,
.public-card p,
.public-feature-card p,
.public-dark-card p,
.public-demo-card p,
.public-price-card p {
    margin: 0;
    color: #6b7280;
    line-height: 1.6;
}

.public-card,
.public-feature-card {
    padding: 24px;
}

.public-store-section {
    background:
        radial-gradient(circle at 16% 16%, rgba(161, 0, 255, 0.12), transparent 28%),
        linear-gradient(180deg, #f7f7fb, #ffffff);
}

.public-check-list {
    display: grid;
    gap: 12px;
    margin: 0 0 28px;
    padding: 0;
    list-style: none;
}

.public-check-list li {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    color: #1f2430;
    font-weight: 700;
}

.public-check-list i {
    color: #17c964;
    margin-top: 4px;
}

.public-store-preview {
    margin-top: 34px;
    padding: 24px;
    border-radius: 30px;
    background: #0f0b24;
    color: #ffffff;
    box-shadow: 0 26px 70px rgba(15, 11, 36, 0.28);
}

.store-preview-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 18px;
    font-size: 18px;
    font-weight: 900;
}

.store-preview-header i {
    color: #17c964;
}

.store-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.store-product {
    padding: 12px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.08);
}

.store-product div {
    height: 86px;
    margin-bottom: 10px;
    border-radius: 14px;
    background: linear-gradient(135deg, #ffffff, #c400ff);
}

.store-product b,
.store-product small {
    display: block;
}

.store-product small {
    color: rgba(255,255,255,0.7);
}

.public-store-preview button {
    width: 100%;
    min-height: 48px;
    margin-top: 16px;
    border: 0;
    border-radius: 999px;
    background: #17c964;
    color: #ffffff;
    font-weight: 900;
}

.public-demo-card {
    position: relative;
    overflow: hidden;
    padding: 24px;
    min-height: 260px;
    color: #ffffff;
}

.public-demo-card h3,
.public-demo-card p {
    position: relative;
    color: #ffffff;
}

.demo-mini-phone {
    position: relative;
    width: 112px;
    height: 172px;
    margin-bottom: 20px;
    padding: 16px;
    border: 6px solid rgba(255,255,255,0.35);
    border-radius: 24px;
    background: rgba(255,255,255,0.22);
}

.demo-mini-phone span,
.demo-mini-phone strong,
.demo-mini-phone i {
    display: block;
    border-radius: 999px;
    background: rgba(255,255,255,0.86);
}

.demo-mini-phone span {
    width: 38px;
    height: 38px;
    margin: 0 auto 16px;
}

.demo-mini-phone strong,
.demo-mini-phone i {
    height: 10px;
    margin-bottom: 10px;
}

.demo-mini-phone i:nth-child(4) {
    width: 75%;
}

.demo-mini-phone i:nth-child(5) {
    width: 58%;
}

.demo-profissional { background: linear-gradient(135deg, #5b2ec6, #111827); }
.demo-loja { background: linear-gradient(135deg, #ff7a18, #af002d); }
.demo-restaurante { background: linear-gradient(135deg, #166534, #84cc16); }
.demo-advocacia { background: linear-gradient(135deg, #111827, #6b5b2c); }
.demo-clinica { background: linear-gradient(135deg, #0ea5e9, #a100ff); }
.demo-criador { background: linear-gradient(135deg, #c400ff, #f97316); }

.public-qr-section {
    background: linear-gradient(135deg, #f7f7fb, #efe7ff);
}

.public-qr-card {
    max-width: 340px;
    margin: 0 auto 34px;
    padding: 28px;
    border-radius: 30px;
    background: #ffffff;
    text-align: center;
    box-shadow: 0 22px 50px rgba(91, 46, 198, 0.15);
}

.qr-code-art {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 8px;
    width: 220px;
    height: 220px;
    margin: 0 auto 18px;
    padding: 14px;
    border-radius: 22px;
    background: #f7f7fb;
}

.qr-code-art span {
    border-radius: 6px;
    background: #0f0b24;
}

.qr-code-art span:nth-child(2n),
.qr-code-art span:nth-child(5n) {
    background: #5b2ec6;
}

.public-qr-card p {
    margin: 0;
    color: #5b2ec6;
    font-weight: 900;
}

.public-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.public-tag-list span {
    padding: 10px 14px;
    border: 1px solid #e6e2f5;
    border-radius: 999px;
    background: #ffffff;
    color: #1f2430;
    font-weight: 800;
}

.public-section-dark {
    background:
        radial-gradient(circle at 85% 20%, rgba(196, 0, 255, 0.22), transparent 28%),
        #0f0b24;
    color: #ffffff;
}

.public-section-dark .public-section-heading h2,
.public-section-dark .public-section-heading p {
    color: #ffffff;
}

.public-dark-card {
    padding: 26px;
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    box-shadow: none;
}

.public-dark-card h3,
.public-dark-card p {
    color: #ffffff;
}

.public-dark-card p {
    color: rgba(255,255,255,0.72);
}

.public-compare {
    display: grid;
    gap: 16px;
}

.public-compare-column {
    padding: 26px;
    border: 1px solid #e9e7f3;
    border-radius: 24px;
    background: #f7f7fb;
}

.public-compare-plus {
    background: linear-gradient(135deg, #5b2ec6, #a100ff);
    color: #ffffff;
}

.public-compare-column h3 {
    margin: 0 0 12px;
    font-weight: 900;
}

.public-compare-column p {
    margin: 0;
    line-height: 1.65;
}

.public-price-card {
    position: relative;
    margin-bottom: 18px;
    padding: 30px;
}

.public-price-card strong {
    display: block;
    margin: 18px 0;
    color: #1f2430;
    font-size: 42px;
    font-weight: 900;
}

.public-price-card strong small {
    color: #6b7280;
    font-size: 16px;
}

.public-price-card ul {
    display: grid;
    gap: 10px;
    margin: 0 0 24px;
    padding: 0;
    list-style: none;
}

.public-price-card li {
    color: #1f2430;
    font-weight: 700;
}

.public-price-card li:before {
    content: "\f00c";
    margin-right: 8px;
    color: #17c964;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}

.public-price-featured,
.public-price-store {
    border-color: rgba(91, 46, 198, 0.36);
}

.public-price-badge {
    display: inline-flex;
    margin-bottom: 16px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(91, 46, 198, 0.1);
    color: #5b2ec6;
    font-size: 12px;
    font-weight: 900;
}

.public-plan-link {
    margin-top: 18px;
    text-align: center;
}

.public-plan-link a {
    color: #5b2ec6;
    font-weight: 900;
}

.public-faq-list {
    max-width: 860px;
    margin: 0 auto;
}

.public-faq-item {
    margin-bottom: 12px;
    border: 1px solid #e9e7f3;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(31, 36, 48, 0.06);
}

.public-faq-item summary {
    cursor: pointer;
    padding: 20px 22px;
    color: #1f2430;
    font-size: 17px;
    font-weight: 900;
}

.public-faq-item p {
    margin: 0;
    padding: 0 22px 22px;
    color: #6b7280;
    line-height: 1.65;
}

.public-contact-section {
    background: linear-gradient(135deg, #ffffff, #f1ebff);
}

.public-contact-email {
    color: #5b2ec6 !important;
    font-weight: 900;
}

.public-contact-form {
    padding: 24px;
    border: 1px solid #e9e7f3;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 18px 40px rgba(31, 36, 48, 0.08);
}

.public-contact-form input,
.public-contact-form textarea {
    width: 100%;
    margin-bottom: 14px;
    padding: 14px 16px;
    border: 1px solid #dfe1ea;
    border-radius: 14px;
    background: #ffffff;
    color: #1f2430;
    font-size: 16px;
}

.public-contact-form input:focus,
.public-contact-form textarea:focus {
    border-color: #5b2ec6;
    box-shadow: 0 0 0 4px rgba(91, 46, 198, 0.12);
    outline: none;
}

.public-footer {
    padding: 54px 0 28px;
    background: #0f0b24;
    color: rgba(255,255,255,0.76);
}

.public-footer p {
    max-width: 430px;
    margin-top: 16px;
    line-height: 1.65;
}

.public-footer h3 {
    margin: 0 0 14px;
    color: #ffffff;
    font-size: 15px;
    font-weight: 900;
}

.public-footer a {
    display: block;
    margin-bottom: 10px;
    color: rgba(255,255,255,0.72);
    font-weight: 700;
}

.public-footer a:hover,
.public-footer a:focus {
    color: #ffffff;
}

.public-footer-bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
    margin-top: 36px;
    padding-top: 22px;
    border-top: 1px solid rgba(255,255,255,0.1);
    font-size: 14px;
}

.public-auth {
    min-height: calc(100vh - 76px);
    padding: 110px 0 80px;
    background:
        radial-gradient(circle at 82% 18%, rgba(196, 0, 255, 0.24), transparent 32%),
        linear-gradient(135deg, #0f0b24 0%, #23115b 52%, #5b2ec6 100%);
    color: #ffffff;
}

.public-auth-card {
    padding: 28px;
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 28px;
    background: rgba(255,255,255,0.1);
    box-shadow: 0 24px 62px rgba(0,0,0,0.24);
    backdrop-filter: blur(18px);
}

.public-auth-card h1 {
    margin: 0 0 12px;
    color: #ffffff;
    font-size: clamp(32px, 6vw, 56px);
    font-weight: 900;
    line-height: 1.04;
}

.public-auth-card p {
    color: rgba(255,255,255,0.78);
    font-size: 18px;
    line-height: 1.6;
}

.public-auth-form {
    padding: 24px;
    border-radius: 24px;
    background: #ffffff;
    color: #1f2430;
    box-shadow: 0 20px 50px rgba(0,0,0,0.24);
}

.public-auth-form label {
    color: #1f2430;
    font-size: 14px;
    font-weight: 900;
}

.public-auth-form .auth-input,
.public-auth-form input {
    min-height: 50px;
    border: 1px solid #dfe1ea;
    border-radius: 14px;
    font-size: 16px;
}

.public-auth-form .auth-input:focus,
.public-auth-form input:focus {
    border-color: #5b2ec6;
    box-shadow: 0 0 0 4px rgba(91, 46, 198, 0.12);
}

.public-auth-form .submit {
    width: 100%;
    min-height: 50px;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, #5b2ec6, #a100ff);
    color: #ffffff;
    font-weight: 900;
}

.public-auth-links a {
    display: inline-flex;
    margin-top: 14px;
    color: #ffffff;
    font-weight: 800;
}

.auth-url-field {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    overflow: hidden;
    border: 1px solid #dfe1ea;
    border-radius: 14px;
    background: #f7f7fb;
}

.auth-url-field span {
    padding: 0 12px;
    color: #5b2ec6;
    font-weight: 900;
}

.auth-url-field input {
    border: 0 !important;
    box-shadow: none !important;
    background: #ffffff;
}

@media (min-width: 768px) {
    .public-grid-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-compare {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .public-hero-visual {
        margin-top: 0;
    }

    .public-grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .public-grid-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
	.cliente-topbar {
		padding: 10px 16px;
	}

	.cliente-topbar #ca-navbar {
		margin-top: 10px;
		padding: 12px;
		border: 1px solid #ece8f6;
		border-radius: 12px;
		box-shadow: 0 10px 22px rgba(26, 41, 89, .08);
	}

	.link-layout-choice-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

    .profile-fields-grid {
        grid-template-columns: 1fr;
    }

    .profile-actions-card {
        position: static;
    }

    .cliente-preview-column {
        position: static;
    }

    .layout-style-grid,
    .layout-photo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .layout-upload-grid {
        grid-template-columns: 1fr;
    }

    .layout-palette-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .layout-editor-card__head {
        flex-direction: column;
    }

    .link-editor-body {
        max-height: none;
        padding: 16px;
    }

    .link-layout-choice-grid,
    .link-performance-grid,
    .link-button-preview-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .link-button-preview-card {
        grid-template-columns: 1fr;
    }

    .public-header .navbar-collapse {
        padding: 16px 0 4px;
    }

    .public-nav-actions {
        align-items: stretch;
        flex-direction: column;
        margin: 12px 0 0;
    }

    .public-section {
        padding: 64px 0;
    }
}

@media (max-width: 575.98px) {
	.cliente-layout-model-grid {
		grid-template-columns: 1fr;
	}

	.link-layout-choice-grid,
	.link-premium-color-grid {
		grid-template-columns: 1fr;
	}

    .profile-editor__header,
    .profile-editor-card,
    .profile-actions-card {
        padding: 16px;
        border-radius: 16px;
    }

    .profile-editor__header h3 {
        font-size: 21px;
    }

    .profile-editor-card__head,
    .profile-vcard-box,
    .profile-actions-card {
        flex-direction: column;
        align-items: stretch;
    }

    .profile-upload-row {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }

    .profile-upload-copy {
        justify-items: center;
    }

    .profile-actions-card > div,
    .profile-actions-card .cliente-mini-btn,
    .profile-actions-card .submit-btn {
        width: 100%;
    }

    .link-editor-dialog {
        margin: 8px;
        height: calc(100vh - 16px);
    }

    .link-editor-modal {
        height: 100%;
        max-height: calc(100vh - 16px);
        border-radius: 14px;
    }

    .link-editor-modal__header,
    .link-editor-footer {
        padding: 14px;
    }

    .link-editor-modal__header h5 {
        font-size: 19px;
    }

    .link-editor-grid > [class*="col-"] {
        padding: 14px;
        border-radius: 14px;
    }

    .link-performance-grid,
    .link-layout-choice-grid {
        grid-template-columns: 1fr;
    }

    .link-editor-footer,
    .link-editor-footer > div {
        align-items: stretch;
        flex-direction: column;
    }

    .btn-admin-primary,
    .btn-admin-secondary,
    .btn-admin-danger {
        width: 100%;
    }

    .layout-palette-grid {
        grid-template-columns: 1fr;
    }

    .layout-palette-chip {
        min-height: 52px;
    }

    .layout-style-grid,
    .layout-photo-grid {
        grid-template-columns: 1fr;
    }

    .layout-editor-card {
        padding: 16px;
        border-radius: 16px;
    }

    .layout-save-bar {
        left: 10px;
        right: 10px;
        flex-direction: column;
        align-items: stretch;
    }

    .public-nav {
        min-height: 68px;
    }

    .public-brand img,
    .public-footer img {
        width: 148px;
    }

    .public-hero {
        min-height: auto;
        padding: 54px 0 56px;
    }

    .public-lead {
        font-size: 17px;
    }

    .public-hero-actions .btn-public {
        width: 100%;
    }

    .public-floating-card {
        position: static;
        margin: 12px 5px 0;
    }

    .public-phone-screen {
        min-height: 500px;
    }

    .store-preview-grid {
        grid-template-columns: 1fr;
    }

    .public-section-heading {
        text-align: left;
    }

    .public-section-heading.text-left {
        text-align: left !important;
    }
}

#nav-store #corpo-store {
    row-gap: 14px;
}

#nav-store .card {
    border: 1px solid #e7e5f2;
    border-radius: 14px;
    box-shadow: 0 12px 26px rgba(29, 22, 58, 0.08);
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

#nav-store .card:hover {
    border-color: rgba(91, 50, 180, 0.25);
    box-shadow: 0 18px 34px rgba(29, 22, 58, 0.12);
    transform: translateY(-2px);
}

#nav-store .card img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 10px;
    background: #f1f2f7;
}

#nav-store .card h5,
#nav-store .card h6 {
    color: #1f2433;
}

#nav-store .btn-editar-produto {
    color: #5b32b4;
    font-weight: 700;
    text-decoration: none;
}

#nav-store .btn-editar-produto:hover,
#nav-store .btn-editar-produto:focus {
    color: #401f90;
    text-decoration: none;
}

.password-reset-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 16px;
    background: radial-gradient(circle at top left, rgba(109, 40, 217, .32), transparent 34%), linear-gradient(135deg, #14002e 0%, #4c1d95 52%, #f7f4ff 100%);
}

.password-reset-shell {
    width: 100%;
    max-width: 460px;
}

.password-reset-card {
    width: 100%;
    padding: 34px;
    border: 1px solid rgba(255,255,255,.38);
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(20, 0, 46, .22);
}

.password-reset-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 178px;
    min-height: 48px;
    margin-bottom: 22px;
    padding: 10px 16px;
    border-radius: 14px;
    background: #14002e;
}

.password-reset-logo img {
    max-width: 146px;
    height: auto;
}

.password-reset-copy span {
    display: block;
    margin-bottom: 8px;
    color: #5b32b4;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.password-reset-copy h1 {
    margin: 0 0 10px;
    color: #1f2430;
    font-size: 30px;
    line-height: 1.15;
    font-weight: 900;
}

.password-reset-copy p {
    margin: 0 0 24px;
    color: #697386;
    font-size: 15px;
    line-height: 1.55;
}

.password-reset-form {
    display: grid;
    gap: 16px;
}

.password-reset-field label {
    display: block;
    margin-bottom: 8px;
    color: #1f2430;
    font-weight: 800;
}

.password-reset-field .auth-input {
    width: 100%;
    min-height: 52px;
    padding: 12px 14px;
    border: 1px solid #ded8ee;
    border-radius: 12px;
    color: #1f2430;
    background: #fff;
    outline: none;
}

.password-reset-field .auth-input:focus {
    border-color: #5b32b4;
    box-shadow: 0 0 0 4px rgba(91, 50, 180, .12);
}

.password-reset-error {
    display: block;
    min-height: 18px;
    margin-top: 7px;
    color: #b42318;
    font-size: 13px;
}

.password-reset-submit,
.password-reset-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 13px 18px;
    border-radius: 12px;
    font-weight: 900;
    cursor: pointer;
    text-decoration: none !important;
}

.password-reset-submit {
    border: 0;
    background: #5b32b4;
    color: #fff !important;
}

.password-reset-submit:disabled {
    opacity: .7;
    cursor: wait;
}

.password-reset-secondary {
    border: 1px solid #ded8ee;
    background: #fff;
    color: #5b32b4 !important;
}

.password-reset-links,
.password-reset-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
}

.password-reset-links a {
    color: #5b32b4;
    font-weight: 800;
}

.password-reset-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    margin-bottom: 16px;
    border-radius: 16px;
    background: #f0ebff;
    color: #5b32b4;
    font-size: 24px;
}

.password-reset-icon--error {
    background: #fff1f0;
    color: #b42318;
}

.auth-success-message {
    margin-bottom: 16px;
    padding: 12px 14px;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    background: #f0fdf4;
    color: #166534;
    font-weight: 800;
}

.public-error-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 36px 16px;
    background: radial-gradient(circle at top left, rgba(109, 40, 217, .32), transparent 34%), linear-gradient(135deg, #14002e 0%, #4c1d95 52%, #f7f4ff 100%);
}

.public-error-card {
    width: min(100%, 560px);
    padding: 34px;
    border: 1px solid rgba(255,255,255,.38);
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 24px 70px rgba(20, 0, 46, .22);
    text-align: center;
}

.public-error-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin-bottom: 22px;
    padding: 10px 16px;
    border-radius: 14px;
    background: #14002e;
}

.public-error-logo img {
    max-width: 150px;
    height: auto;
}

.public-error-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    margin-bottom: 18px;
    border-radius: 18px;
    background: #f0ebff;
    color: #5b32b4;
    font-size: 26px;
}

.public-error-card h1 {
    margin: 0 0 12px;
    color: #1f2430;
    font-size: 34px;
    line-height: 1.12;
    font-weight: 900;
}

.public-error-card p {
    max-width: 420px;
    margin: 0 auto 24px;
    color: #647084;
    font-size: 16px;
    line-height: 1.6;
}

.public-error-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}

.public-error-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 18px;
    border-radius: 12px;
    font-weight: 900;
    text-decoration: none !important;
}

.public-error-actions a:first-child {
    background: #5b32b4;
    color: #ffffff;
}

.public-error-actions a:last-child {
    border: 1px solid #ded8ee;
    background: #ffffff;
    color: #5b32b4;
}

.cliente-links-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding: 20px;
    border: 1px solid #e7e1f4;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 14px 36px rgba(31, 24, 74, .06);
}

.cliente-links-header h3 {
    margin: 4px 0 4px;
    color: #1f2633;
    font-size: 22px;
    font-weight: 900;
}

.cliente-links-header p {
    margin: 0;
    color: #697386;
}

.cliente-add-link-top,
.cliente-add-link-bottom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    padding: 12px 18px;
    border: 0;
    border-radius: 12px;
    background: #5b32b4;
    color: #ffffff !important;
    font-weight: 900;
    box-shadow: 0 12px 26px rgba(91, 50, 180, .22);
    cursor: pointer;
}

.cliente-add-link-bottom {
    width: 100%;
    margin: 0;
}

@media (max-width: 575.98px) {
    .cliente-links-header {
        align-items: stretch;
        flex-direction: column;
    }

    .cliente-add-link-top {
        width: 100%;
    }

    .password-reset-page {
        align-items: flex-start;
        padding-top: 24px;
    }

    .public-error-card {
        padding: 26px 18px;
    }

    .public-error-card h1 {
        font-size: 28px;
    }

    .public-error-actions a {
        width: 100%;
    }

    .password-reset-card {
        padding: 24px 18px;
        border-radius: 18px;
    }

    .password-reset-copy h1 {
        font-size: 26px;
    }

    .password-reset-actions,
    .password-reset-actions a,
    .password-reset-actions button {
        width: 100%;
    }

    .modal-dialog {
        margin: 8px;
    }

    .modal-content {
        border-radius: 10px;
    }

    .modal-body {
        padding: 18px 14px;
    }

    .img-tipo,
    .img-tipo-link,
    .img-tipo-social {
        max-width: 74px;
        height: auto;
    }

    .input-cliente,
    .input-cliente-link,
    .link-editor-select {
        width: 100%;
        min-height: 46px;
        font-size: 16px;
    }

    .link-icon-choice-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: 220px;
    }

    .link-image-upload {
        grid-template-columns: 58px minmax(0, 1fr);
    }

    .link-image-preview {
        width: 58px;
        height: 58px;
    }
}

/* ===== CONTA TAB — redesign em cards ===== */

.conta-tab-header {
    padding: 4px 0 18px;
    border-bottom: 1px solid #f0eef8;
    margin-bottom: 20px;
}
.conta-tab-header__title {
    font-size: 20px;
    font-weight: 800;
    color: #1f2633;
    margin: 0 0 4px;
}
.conta-tab-header__sub {
    font-size: 13px;
    color: #697386;
    margin: 0;
}

.conta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}

.conta-card {
    background: #fff;
    border: 1px solid #e7e4f2;
    border-radius: 16px;
    padding: 22px;
    box-shadow: 0 2px 8px rgba(91,50,180,0.06);
    margin-bottom: 0;
}

.conta-card__head {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
}

.conta-card__icon {
    width: 42px;
    height: 42px;
    min-width: 42px;
    background: #f1eafd;
    color: #5b32b4;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.conta-card__title {
    font-size: 16px;
    font-weight: 800;
    color: #1f2633;
    margin: 0 0 2px;
}

.conta-card__desc {
    font-size: 13px;
    color: #697386;
    margin: 0;
}

.conta-info-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.conta-info-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid #f0eef8;
    gap: 8px;
}
.conta-info-row:last-child {
    border-bottom: none;
}
.conta-info-row span {
    font-size: 12px;
    color: #697386;
    white-space: nowrap;
    padding-top: 2px;
}
.conta-info-row strong {
    font-size: 14px;
    color: #1f2633;
    text-align: right;
}

.conta-link-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.conta-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border: 1px solid #5b32b4;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    color: #5b32b4;
    background: transparent;
    cursor: pointer;
    text-decoration: none;
    line-height: 1.4;
    transition: background 0.15s, color 0.15s;
}
.conta-action-btn:hover {
    background: #f1eafd;
    color: #5b32b4;
    text-decoration: none;
}
.conta-action-btn--primary {
    background: #5b32b4;
    color: #fff;
    border-color: #5b32b4;
}
.conta-action-btn--primary:hover {
    background: #4a28a0;
    color: #fff;
}

.conta-card--upgrade {
    background: linear-gradient(135deg, #f4efff 0%, #ede5ff 100%);
    border-color: #c9b8f0;
}

.conta-upgrade-icon {
    text-align: center;
    font-size: 32px;
    margin-bottom: 12px;
}

.conta-upgrade-benefits {
    padding-left: 0;
    list-style: none;
    font-size: 14px;
    margin-bottom: 16px;
    color: #1f2633;
}
.conta-upgrade-benefits li {
    padding: 3px 0;
}
.conta-upgrade-benefits li::before {
    content: "✓ ";
    color: #27ae60;
    font-weight: 800;
}

.conta-upgrade-cta {
    display: block;
    width: 100%;
    min-height: 44px;
    border-radius: 12px;
    background: #5b32b4;
    color: #fff !important;
    font-weight: 700;
    font-size: 15px;
    text-align: center;
    border: none;
    transition: background 0.15s;
}
.conta-upgrade-cta:hover {
    background: #4a28a0;
    color: #fff !important;
}

.conta-card--admin {
    border-color: #c9b8f0;
    background: #faf8ff;
    margin-bottom: 20px;
}

.conta-admin-badge {
    display: inline-block;
    background: #5b32b4;
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 999px;
    letter-spacing: 0.05em;
    vertical-align: middle;
}

.conta-card--danger {
    border-color: #f5c6cb;
    background: #fffafa;
    margin-bottom: 20px;
}

.conta-danger-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.conta-danger-btn {
    background: transparent;
    border: 1px solid #e74c3c;
    color: #e74c3c;
    border-radius: 999px;
    padding: 7px 16px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
}
.conta-danger-btn:hover {
    background: #e74c3c;
    color: #fff;
}

.conta-qr-block {
    text-align: center;
    padding: 12px 0;
}
.conta-qr-block img {
    max-width: 160px;
    border-radius: 12px;
    border: 1px solid #e7e4f2;
}

.conta-locked-feature {
    background: #f7f5fc;
    border: 1px dashed #c9b8f0;
    border-radius: 12px;
    padding: 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.conta-setting-section {
    padding-top: 16px;
    border-top: 1px solid #f0eef8;
    margin-top: 16px;
}
.conta-setting-section:first-child {
    padding-top: 0;
    border-top: none;
    margin-top: 0;
}

.conta-setting-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

@media (max-width: 768px) {
    .conta-grid {
        grid-template-columns: 1fr;
    }
    .conta-danger-row {
        flex-direction: column;
        align-items: flex-start;
    }
    .conta-danger-btn {
        width: 100%;
        text-align: center;
    }
    .conta-setting-row {
        flex-direction: column;
        gap: 8px;
    }
    .conta-action-btn {
        font-size: 13px;
        padding: 7px 14px;
    }
}

/* ===== STORE TAB - Admin Area ===== */

.store-tab-header {
    margin-bottom: 24px;
    padding-bottom: 18px;
    border-bottom: 1px solid #f0eef8;
}
.store-tab-header span {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #8b5cf6;
    margin-bottom: 4px;
}
.store-tab-header h3 {
    font-size: 22px;
    font-weight: 700;
    color: #1f2633;
    margin: 0 0 4px;
}
.store-tab-header p {
    font-size: 14px;
    color: #697386;
    margin: 0;
}

/* WhatsApp alert */
.store-whats-alert {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 14px;
    padding: 14px 18px;
    margin-bottom: 18px;
    flex-wrap: wrap;
}
.store-whats-alert__icon {
    font-size: 22px;
    color: #d97706;
    flex-shrink: 0;
}
.store-whats-alert__content {
    flex: 1;
    min-width: 180px;
}
.store-whats-alert__content strong {
    display: block;
    font-size: 14px;
    color: #92400e;
    margin-bottom: 2px;
}
.store-whats-alert__content p {
    font-size: 13px;
    color: #b45309;
    margin: 0;
}
.store-whats-alert__btn {
    background: #d97706;
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
}
.store-whats-alert__btn:hover { background: #b45309; }

/* WhatsApp OK bar */
.store-whats-ok {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    padding: 10px 16px;
    margin-bottom: 18px;
    font-size: 13px;
    color: #166534;
    flex-wrap: wrap;
}
.store-whats-ok__btn {
    background: none;
    border: 1px solid #86efac;
    border-radius: 8px;
    padding: 4px 12px;
    font-size: 12px;
    color: #166534;
    cursor: pointer;
    margin-left: auto;
    transition: background .15s;
}
.store-whats-ok__btn:hover { background: #dcfce7; }

/* Summary cards */
.store-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}
.store-summary-card {
    background: #fff;
    border: 1px solid #e8e4f3;
    border-radius: 14px;
    padding: 14px 16px;
    text-align: center;
    box-shadow: 0 2px 8px rgba(91,50,180,.05);
}
.store-summary-card__value {
    font-size: 22px;
    font-weight: 700;
    color: #5b32b4;
    line-height: 1.1;
    margin-bottom: 4px;
}
.store-summary-card__label {
    font-size: 12px;
    color: #697386;
}
.store-summary-card--ok .store-summary-card__value { color: #16a34a; }
.store-summary-card--warn .store-summary-card__value { color: #d97706; }

/* Action bar */
.store-action-bar {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 22px;
}
.store-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid #d6cef0;
    background: #fff;
    color: #3d2b8c;
    transition: background .15s, border-color .15s;
    text-decoration: none;
}
.store-action-btn:hover {
    background: #f3f0fc;
    border-color: #b4a7e0;
    color: #3d2b8c;
    text-decoration: none;
}
.store-action-btn--primary {
    background: #5b32b4;
    color: #fff;
    border-color: #5b32b4;
}
.store-action-btn--primary:hover {
    background: #4a279a;
    border-color: #4a279a;
    color: #fff;
}

/* Product grid */
.store-product-grid {
    margin-bottom: 10px;
}
.store-prod-card {
    background: #fff;
    border: 1px solid #e8e4f3;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(91,50,180,.07);
    transition: box-shadow .18s, transform .18s;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.store-prod-card:hover {
    box-shadow: 0 6px 24px rgba(91,50,180,.14);
    transform: translateY(-2px);
}
.store-prod-card__img {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: #f7f5fb;
    display: flex;
    align-items: center;
    justify-content: center;
}
.store-prod-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.store-prod-card__no-img {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    color: #c4b8e8;
    font-size: 13px;
    width: 100%;
    height: 100%;
    min-height: 120px;
}
.store-prod-card__no-img i { font-size: 28px; }
.store-prod-card__body {
    padding: 10px 12px 8px;
    flex: 1;
}
.store-prod-card__name {
    font-size: 13px;
    font-weight: 600;
    color: #1f2633;
    margin: 0 0 6px;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.store-prod-card__price {
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.store-prod-card__original {
    font-size: 11px;
    color: #aaa;
    text-decoration: line-through;
}
.store-prod-card__discounted {
    font-size: 14px;
    color: #5b32b4;
}
.store-prod-card__actions {
    padding: 8px 12px 10px;
    border-top: 1px solid #f0eef8;
}
.store-prod-card__actions button {
    width: 100%;
    padding: 7px 0;
    background: #f3f0fc;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    color: #5b32b4;
    cursor: pointer;
    transition: background .15s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.store-prod-card__actions button:hover { background: #e5e0f8; }

/* Empty state */
.store-empty-state {
    text-align: center;
    padding: 48px 24px;
    background: #faf9fd;
    border: 1px dashed #d6cef0;
    border-radius: 18px;
    margin-bottom: 16px;
}
.store-empty-state__icon {
    font-size: 48px;
    color: #c4b8e8;
    margin-bottom: 16px;
}
.store-empty-state h4 {
    font-size: 18px;
    color: #1f2633;
    margin-bottom: 8px;
}
.store-empty-state p {
    font-size: 14px;
    color: #697386;
    max-width: 420px;
    margin: 0 auto 20px;
    line-height: 1.6;
}
.store-empty-tip {
    font-size: 12px;
    color: #b45309;
    margin-top: 14px !important;
}

@media (max-width: 992px) {
    .store-summary-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
    .store-summary-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .store-action-bar { flex-direction: column; }
    .store-action-btn { width: 100%; justify-content: center; }
    .store-tab-header h3 { font-size: 18px; }
}

/* Password strength indicator */
.senha-strength {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 6px;
    min-height: 18px;
}
.senha-strength__bar {
    flex: 1;
    height: 5px;
    background: #e9e5f3;
    border-radius: 4px;
    overflow: hidden;
}
.senha-strength__fill {
    height: 100%;
    width: 0%;
    border-radius: 4px;
    transition: width 0.25s ease, background 0.25s ease;
    background: #e9e5f3;
}
.senha-strength__fill--1 { background: #ef4444; }
.senha-strength__fill--2 { background: #f97316; }
.senha-strength__fill--3 { background: #eab308; }
.senha-strength__fill--4 { background: #22c55e; }
.senha-strength__fill--5 { background: #16a34a; }
.senha-strength__label {
    font-size: 11px;
    font-weight: 600;
    min-width: 72px;
    color: #697386;
    text-align: right;
}

/* Store upsell page (non-ProStore users) */
.store-upsell {
    max-width: 680px;
    margin: 0 auto;
    padding: 8px 0 32px;
}
.store-upsell__hero {
    text-align: center;
    padding: 40px 24px 32px;
    background: linear-gradient(135deg, #f5f0ff 0%, #ede8ff 100%);
    border-radius: 20px;
    margin-bottom: 24px;
}
.store-upsell__badge {
    display: inline-block;
    background: #5b32b4;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 4px 14px;
    border-radius: 20px;
    margin-bottom: 20px;
}
.store-upsell__icon {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 8px 28px rgba(91,50,180,.18);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    font-size: 30px;
    color: #5b32b4;
}
.store-upsell__title {
    font-size: 22px;
    font-weight: 800;
    color: #1f2430;
    margin-bottom: 12px;
    line-height: 1.3;
}
.store-upsell__desc {
    font-size: 15px;
    color: #697386;
    line-height: 1.65;
    max-width: 480px;
    margin: 0 auto 28px;
}
.store-upsell__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #5b32b4;
    color: #fff !important;
    font-size: 15px;
    font-weight: 700;
    padding: 13px 28px;
    border-radius: 12px;
    text-decoration: none !important;
    transition: background .18s, transform .15s, box-shadow .18s;
    box-shadow: 0 6px 20px rgba(91,50,180,.28);
}
.store-upsell__cta:hover {
    background: #4a28a0;
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(91,50,180,.35);
    color: #fff !important;
}
.store-upsell__features {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 28px;
}
.store-upsell__feature {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: #fff;
    border: 1px solid #ede8ff;
    border-radius: 14px;
    padding: 16px 18px;
}
.store-upsell__feature-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: #f0e8ff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    color: #5b32b4;
}
.store-upsell__feature strong {
    display: block;
    font-size: 14px;
    color: #1f2430;
    font-weight: 700;
    margin-bottom: 3px;
}
.store-upsell__feature span {
    font-size: 13px;
    color: #697386;
    line-height: 1.5;
}
.store-upsell__preview {
    position: relative;
    margin-bottom: 28px;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #ede8ff;
}
.store-upsell__preview-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #5b32b4;
    padding: 12px 18px 8px;
    background: #faf8ff;
    border-bottom: 1px solid #ede8ff;
}
.store-upsell__preview-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 16px;
    background: #faf8ff;
    filter: blur(3px);
    pointer-events: none;
    user-select: none;
}
.store-upsell__preview-card {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e9e5f3;
    padding: 14px 10px 12px;
    text-align: center;
}
.store-upsell__preview-img {
    width: 52px;
    height: 52px;
    border-radius: 10px;
    background: #f0e8ff;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 10px;
    font-size: 22px;
    color: #5b32b4;
}
.store-upsell__preview-name {
    font-size: 12px;
    font-weight: 700;
    color: #1f2430;
    margin-bottom: 4px;
}
.store-upsell__preview-price {
    font-size: 13px;
    font-weight: 800;
    color: #5b32b4;
}
.store-upsell__preview-blur {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(250,248,255,0) 0%, rgba(250,248,255,.85) 60%, rgba(250,248,255,1) 100%);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 20px;
}
.store-upsell__footer {
    text-align: center;
}
@media (max-width: 576px) {
    .store-upsell__hero { padding: 28px 16px 24px; }
    .store-upsell__title { font-size: 19px; }
    .store-upsell__preview-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 12px; }
}

/* Store tab upgrade indicator */
.tab-badge-upgrade {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #5b32b4;
    color: #fff;
    font-size: 8px;
    vertical-align: middle;
    margin-left: 1px;
}
.cliente-tab-upgrade {
    opacity: .75;
}
.cliente-tab-upgrade.active {
    opacity: 1;
}

/* ============================================================
   Layout upsell (free users)
   ============================================================ */
.layout-upsell {
    padding: 16px 4px 8px;
    max-width: 560px;
    margin: 0 auto;
}
.layout-upsell__hero {
    text-align: center;
    padding: 12px 0 18px;
}
.layout-upsell__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #f3f0ff;
    color: #5b32b4;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 10px;
}
.layout-upsell__title {
    font-size: 19px;
    font-weight: 800;
    color: #1f2430;
    margin: 0 0 8px;
    line-height: 1.25;
}
.layout-upsell__desc {
    font-size: 14px;
    color: #6b7280;
    margin: 0;
    line-height: 1.5;
}
.layout-upsell__themes-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 4px 0 10px;
}
.layout-upsell__themes-header strong {
    font-size: 13px;
    color: #374151;
}
.layout-upsell__themes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 20px;
}
.layout-upsell__theme-card {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid #e5e7eb;
    background: #fff;
}
.layout-upsell__theme-preview {
    height: 86px;
    position: relative;
    display: flex;
    align-items: flex-end;
    padding: 0 8px;
}
.layout-upsell__theme-inner {
    width: 100%;
    border-radius: 6px 6px 0 0;
    height: 62px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px 8px 0;
    gap: 4px;
}
.layout-upsell__theme-avatar {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    flex-shrink: 0;
}
.layout-upsell__theme-line {
    height: 4px;
    width: 70%;
    border-radius: 3px;
}
.layout-upsell__theme-btn {
    height: 7px;
    width: 50%;
    border-radius: 4px;
    margin-top: 2px;
    opacity: .85;
}
.layout-upsell__theme-overlay {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 86px;
    background: rgba(0,0,0,.38);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 17px;
    pointer-events: none;
}
.layout-upsell__theme-info {
    padding: 6px 8px 8px;
    background: #fff;
}
.layout-upsell__theme-info strong {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: #1f2430;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.layout-upsell__theme-dots {
    display: flex;
    gap: 3px;
    margin-top: 4px;
}
.layout-upsell__theme-dots i {
    display: inline-block;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    border: 1px solid rgba(0,0,0,.1);
}
.layout-upsell__features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 22px;
}
.layout-upsell__feature {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    background: #f9f7ff;
    border-radius: 10px;
    padding: 12px;
}
.layout-upsell__feature i {
    color: #5b32b4;
    font-size: 15px;
    margin-top: 2px;
    flex-shrink: 0;
}
.layout-upsell__feature strong {
    display: block;
    font-size: 12px;
    color: #1f2430;
    font-weight: 700;
}
.layout-upsell__feature span {
    display: block;
    font-size: 11px;
    color: #6b7280;
    line-height: 1.4;
}
.layout-upsell__footer {
    text-align: center;
    padding-bottom: 16px;
}
.layout-upsell__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #5b32b4;
    color: #fff !important;
    font-weight: 700;
    font-size: 15px;
    padding: 14px 28px;
    border-radius: 999px;
    text-decoration: none !important;
    transition: background .15s;
}
.layout-upsell__cta:hover {
    background: #4a27a0;
}

/* ===== SUBSCRIPTION ALERT BANNERS ===== */
.subscription-alert {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.5;
}
.subscription-alert i {
    font-size: 18px;
    flex-shrink: 0;
}
.subscription-alert a {
    font-weight: 700;
    text-decoration: underline;
}
.subscription-alert--warning {
    background: #fff8e1;
    border: 1px solid #f9a825;
    color: #7a5000;
}
.subscription-alert--warning i { color: #f9a825; }
.subscription-alert--warning a { color: #7a5000; }
.subscription-alert--danger {
    background: #fce4ec;
    border: 1px solid #e53935;
    color: #7f0000;
}
.subscription-alert--danger i { color: #e53935; }
.subscription-alert--danger a { color: #7f0000; }

/* ===== THEME CARDS — FREE SELECTABLE ===== */
.layout-upsell__theme-card--selectable {
    cursor: pointer;
    transition: transform .15s, box-shadow .15s;
}
.layout-upsell__theme-card--selectable:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,0,0,.13);
}
.layout-upsell__theme-card--active {
    outline: 3px solid #5b32b4;
    outline-offset: 2px;
}
.layout-upsell__theme-check {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #5b32b4;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    z-index: 2;
}
.layout-upsell__feature--locked {
    opacity: .6;
    pointer-events: none;
}
.layout-upsell__lock-icon {
    margin-left: auto;
    color: #aaa;
    font-size: 12px;
}
