/* =========================================================================
   Vimeva — premium thema-laag
   Magenta -> paars huisstijl, vier-pijler switch, showcases, CTA.
   ====================================================================== */

:root {
	--vimeva-magenta: #d6177f;
	--vimeva-pink:    #e0218a;
	--vimeva-purple:  #7b2e9e;
	--vimeva-deep:    #3a1257;
	--vimeva-ink:     #1c1230;
	--vimeva-grad:    linear-gradient(135deg, #e0218a 0%, #7b2e9e 100%);
	--vimeva-grad-soft: linear-gradient(135deg, #fbe7f3 0%, #efe4f8 100%);
	--vimeva-shadow:  0 18px 50px rgba(58, 18, 87, 0.16);
	--vimeva-shadow-sm: 0 8px 24px rgba(58, 18, 87, 0.10);
	--vimeva-radius:  20px;
	--vimeva-font:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ---- Typografie verfijning (premium) ---------------------------------- */
body.vimeva-theme,
body.vimeva-theme p,
body.vimeva-theme .et_pb_text,
body.vimeva-theme h1, body.vimeva-theme h2, body.vimeva-theme h3,
body.vimeva-theme h4, body.vimeva-theme h5, body.vimeva-theme h6,
body.vimeva-theme .et_pb_module {
	font-family: var(--vimeva-font);
	-webkit-font-smoothing: antialiased;
}
body.vimeva-theme h1, body.vimeva-theme h2, body.vimeva-theme h3 {
	letter-spacing: -0.02em;
	font-weight: 800;
}

/* ---- Generieke premium componenten ------------------------------------ */
.vimeva-eyebrow {
	display: inline-block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--vimeva-magenta);
	margin-bottom: 14px;
}

.vimeva-btn {
	display: inline-block;
	padding: 15px 32px;
	border-radius: 999px;
	background: var(--vimeva-grad);
	color: #fff !important;
	font-weight: 700;
	font-size: 15px;
	text-decoration: none;
	border: 0;
	cursor: pointer;
	box-shadow: 0 10px 28px rgba(214, 23, 127, 0.32);
	transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.vimeva-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 38px rgba(123, 46, 158, 0.40);
	opacity: .97;
}
.vimeva-btn--light {
	background: #fff;
	color: var(--vimeva-purple) !important;
	box-shadow: 0 12px 30px rgba(0,0,0,.18);
}

/* =======================================================================
   Vier-pijler switch
   ==================================================================== */
.vimeva-pillars {
	max-width: 1180px;
	margin: 0 auto;
	padding: 90px 24px;
	font-family: var(--vimeva-font);
}
.vimeva-pillars__head { text-align: center; max-width: 720px; margin: 0 auto 42px; }
.vimeva-pillars__title {
	font-size: clamp(30px, 4vw, 46px);
	font-weight: 900;
	color: var(--vimeva-ink);
	margin: 0 0 14px;
	letter-spacing: -0.03em;
}
.vimeva-pillars__intro { font-size: 18px; color: #5d5470; margin: 0; }

.vimeva-switch {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
	background: #f4f0f9;
	padding: 8px;
	border-radius: 999px;
	max-width: 640px;
	margin: 0 auto 40px;
}
.vimeva-switch__btn {
	flex: 1 1 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-width: 130px;
	padding: 14px 20px;
	border-radius: 999px;
	background: transparent;
	border: 0;
	font-family: var(--vimeva-font);
	font-weight: 700;
	font-size: 15px;
	color: var(--vimeva-deep);
	cursor: pointer;
	transition: all .3s ease;
}
.vimeva-switch__btn .vimeva-switch__icon { font-size: 18px; line-height: 1; }
.vimeva-switch__btn:hover { color: var(--vimeva-magenta); }
.vimeva-switch__btn.is-active {
	background: var(--vimeva-grad);
	color: #fff;
	box-shadow: 0 10px 24px rgba(214, 23, 127, 0.30);
}

.vimeva-panels { position: relative; }
.vimeva-panel {
	display: none;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 48px;
	align-items: center;
	background: #fff;
	border: 1px solid #efe9f4;
	border-radius: var(--vimeva-radius);
	box-shadow: var(--vimeva-shadow);
	padding: 48px;
	animation: vimevaFade .45s ease;
}
.vimeva-panel.is-active { display: grid; }
@keyframes vimevaFade { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

.vimeva-panel__tag {
	display: inline-block;
	font-size: 13px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
	color: var(--vimeva-purple); margin-bottom: 12px;
}
.vimeva-panel__title { font-size: 30px; font-weight: 800; color: var(--vimeva-ink); margin: 0 0 14px; }
.vimeva-panel__text { font-size: 17px; color: #5d5470; line-height: 1.6; margin: 0 0 22px; }
.vimeva-panel__list { list-style: none; padding: 0; margin: 0 0 28px; }
.vimeva-panel__list li {
	position: relative; padding-left: 30px; margin-bottom: 12px;
	font-size: 16px; color: #2c2440; font-weight: 500;
}
.vimeva-panel__list li::before {
	content: ''; position: absolute; left: 0; top: 4px;
	width: 18px; height: 18px; border-radius: 50%;
	background: var(--vimeva-grad);
}
.vimeva-panel__list li::after {
	content: '✓'; position: absolute; left: 4px; top: 2px;
	color: #fff; font-size: 11px; font-weight: 800;
}
.vimeva-panel__visual {
	height: 100%;
	min-height: 280px;
	border-radius: 16px;
	background: var(--vimeva-grad);
	display: flex; flex-direction: column;
	align-items: center; justify-content: center; gap: 14px;
	color: #fff; text-align: center;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,.12);
	position: relative; overflow: hidden;
}
.vimeva-panel__visual::after {
	content: ''; position: absolute; inset: 0;
	background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.25), transparent 55%);
}
.vimeva-panel__visual-icon { font-size: 64px; line-height: 1; position: relative; }
.vimeva-panel__visual-label { font-size: 22px; font-weight: 800; letter-spacing: .04em; position: relative; }

/* =======================================================================
   Showcase grid
   ==================================================================== */
.vimeva-showcase { max-width: 1180px; margin: 0 auto; padding: 90px 24px; font-family: var(--vimeva-font); }
.vimeva-showcase__head { text-align: center; max-width: 700px; margin: 0 auto 48px; }
.vimeva-showcase__title { font-size: clamp(30px, 4vw, 46px); font-weight: 900; color: var(--vimeva-ink); margin: 0 0 14px; letter-spacing: -0.03em; }
.vimeva-showcase__intro { font-size: 18px; color: #5d5470; margin: 0; }
.vimeva-showcase__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.vimeva-card {
	background: #fff; border-radius: var(--vimeva-radius);
	overflow: hidden; border: 1px solid #efe9f4;
	box-shadow: var(--vimeva-shadow-sm);
	transition: transform .3s ease, box-shadow .3s ease;
}
.vimeva-card:hover { transform: translateY(-6px); box-shadow: var(--vimeva-shadow); }
.vimeva-card__media {
	height: 180px; background: var(--vimeva-grad); position: relative;
	display: flex; align-items: flex-end; padding: 18px;
}
.vimeva-card[data-pillar="hosting"] .vimeva-card__media { background: linear-gradient(135deg, #7b2e9e 0%, #3a1257 100%); }
.vimeva-card[data-pillar="socials"] .vimeva-card__media { background: linear-gradient(135deg, #e0218a 0%, #d6177f 100%); }
.vimeva-card[data-pillar="apps"] .vimeva-card__media    { background: linear-gradient(135deg, #9b2c8f 0%, #7b2e9e 100%); }
.vimeva-card__media::after {
	content: ''; position: absolute; inset: 0;
	background: radial-gradient(circle at 80% 10%, rgba(255,255,255,.22), transparent 50%);
}
.vimeva-card__badge {
	position: relative; z-index: 1;
	background: rgba(255,255,255,.92); color: var(--vimeva-purple);
	font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
	padding: 6px 14px; border-radius: 999px;
}
.vimeva-card__body { padding: 24px 24px 28px; }
.vimeva-card__name { font-size: 20px; font-weight: 800; color: var(--vimeva-ink); margin: 0 0 8px; }
.vimeva-card__desc { font-size: 15px; color: #5d5470; line-height: 1.55; margin: 0 0 16px; }
.vimeva-card__link { font-weight: 700; color: var(--vimeva-magenta); font-size: 15px; }

/* =======================================================================
   CTA band
   ==================================================================== */
.vimeva-cta { padding: 24px; }
.vimeva-cta__inner {
	max-width: 1180px; margin: 0 auto;
	background: var(--vimeva-grad);
	border-radius: 28px; padding: 64px 40px; text-align: center;
	color: #fff; position: relative; overflow: hidden;
	box-shadow: var(--vimeva-shadow);
}
.vimeva-cta__inner::after {
	content: ''; position: absolute; inset: 0;
	background: radial-gradient(circle at 15% 20%, rgba(255,255,255,.18), transparent 45%),
	            radial-gradient(circle at 85% 90%, rgba(255,255,255,.14), transparent 45%);
}
.vimeva-cta__title { position: relative; font-size: clamp(26px, 3.4vw, 40px); font-weight: 900; margin: 0 0 14px; letter-spacing: -0.02em; }
.vimeva-cta__text { position: relative; font-size: 18px; opacity: .94; margin: 0 0 28px; }
.vimeva-cta .vimeva-btn { position: relative; }

/* =======================================================================
   Premium refinements op de Divi/Molti basis
   ==================================================================== */
/* Strakkere primaire knoppen overal */
body.vimeva-theme .et_pb_button {
	border-radius: 999px !important;
	font-family: var(--vimeva-font) !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	transition: all .25s ease !important;
}
body.vimeva-theme .et_pb_button:hover { transform: translateY(-2px); }

/* Responsive */
@media (max-width: 980px) {
	.vimeva-panel { grid-template-columns: 1fr; padding: 32px; }
	.vimeva-panel__visual { order: -1; min-height: 200px; }
	.vimeva-showcase__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.vimeva-showcase__grid { grid-template-columns: 1fr; }
	.vimeva-switch { border-radius: 22px; }
	.vimeva-switch__btn { min-width: 110px; }
	.vimeva-pillars, .vimeva-showcase { padding: 60px 18px; }
}

/* =======================================================================
   Header: live status-indicator + gelijke header-knoppen
   ==================================================================== */
.vimeva-status {
	display: inline-flex !important;
	align-items: center;
	gap: 9px;
	padding: 6px 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.10);
	border: 1px solid rgba(255, 255, 255, 0.16);
	color: #fff !important;
	font-weight: 600;
	font-size: 13.5px;
	line-height: 1;
	text-decoration: none !important;
	white-space: nowrap;
	transition: background .2s ease, border-color .2s ease;
}
.vimeva-status:hover { background: rgba(255, 255, 255, 0.18); }
.vimeva-status__dot {
	width: 9px; height: 9px; border-radius: 50%;
	background: #9aa0ad; flex: 0 0 auto;
}
.vimeva-status__label { color: #fff; }

/* States */
.vimeva-status[data-state="online"] .vimeva-status__dot {
	background: #2bd576;
	box-shadow: 0 0 0 0 rgba(43, 213, 118, .6);
	animation: vimevaPulse 2s infinite;
}
.vimeva-status[data-state="offline"] { background: rgba(255, 71, 87, 0.18); border-color: rgba(255, 71, 87, 0.4); }
.vimeva-status[data-state="offline"] .vimeva-status__dot {
	background: #ff4757;
	box-shadow: 0 0 0 0 rgba(255, 71, 87, .6);
	animation: vimevaPulseRed 2s infinite;
}
.vimeva-status[data-state="checking"] .vimeva-status__dot { animation: vimevaBlink 1s infinite; }
@keyframes vimevaPulse {
	0%   { box-shadow: 0 0 0 0 rgba(43, 213, 118, .6); }
	70%  { box-shadow: 0 0 0 7px rgba(43, 213, 118, 0); }
	100% { box-shadow: 0 0 0 0 rgba(43, 213, 118, 0); }
}
@keyframes vimevaPulseRed {
	0%   { box-shadow: 0 0 0 0 rgba(255, 71, 87, .6); }
	70%  { box-shadow: 0 0 0 7px rgba(255, 71, 87, 0); }
	100% { box-shadow: 0 0 0 0 rgba(255, 71, 87, 0); }
}
@keyframes vimevaBlink { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

/* Gelijke header-knoppen: zelfde maat, altijd 1 regel */
body.vimeva-theme .et_pb_button.vimeva-hdr-btn,
body.vimeva-theme .vimeva-hdr-btn .et_pb_button,
body.vimeva-theme .vimeva-hdr-btn.et_pb_button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-width: 210px;
	box-sizing: border-box;
	padding: 16px 30px !important;
	white-space: nowrap !important;
	text-align: center;
	font-size: 15px !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	border-radius: 999px !important;
}

/* Robuuste fallback: gelijke, niet-afbrekende knoppen in de Theme Builder-header
   (werkt ook als de htmlAttributes-class nog niet opnieuw geïmporteerd is). */
body.vimeva-theme .et-l--header .et_pb_button_module_wrapper { display: inline-block; }
body.vimeva-theme .et-l--header .et_pb_button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-width: 210px;
	box-sizing: border-box;
	padding: 16px 30px !important;
	white-space: nowrap !important;
	text-align: center;
	line-height: 1.1 !important;
	border-radius: 999px !important;
}
