/* ============================================================
   DIGITRO PRO — Theme CSS  (v2 — full rewrite)
   Modern, refined, premium. Bento layouts, gradient borders,
   sane typography scale, sophisticated color treatment.
   ============================================================ */

/* ---------------------------------------
   0. DESIGN TOKENS
   --------------------------------------- */
:root {
	/* Brand */
	--dp-primary:        #00C853;
	--dp-primary-rgb:    0, 200, 83;
	--dp-primary-deep:   #00A341;
	--dp-accent:         #00E676;
	--dp-accent-rgb:     0, 230, 118;
	--dp-lime:           #C6FF00;
	--dp-success:        #22C55E;
	--dp-warning:        #F59E0B;
	--dp-danger:         #EF4444;

	/* Surfaces (dark default) */
	--dp-bg:             #050708;
	--dp-bg-1:           #0A0E11;
	--dp-bg-2:           #0F1418;
	--dp-bg-3:           #161B20;
	--dp-bg-4:           #1E252B;
	--dp-bg-overlay:     rgba(5, 7, 8, 0.85);

	/* Borders — subtle gradients used everywhere */
	--dp-border:         rgba(255, 255, 255, 0.06);
	--dp-border-strong:  rgba(255, 255, 255, 0.12);

	/* Text */
	--dp-text:           #F5F7FA;
	--dp-text-soft:      #C0C8D2;
	--dp-text-muted:     #8893A1;
	--dp-text-faint:     #5B6675;

	/* Type */
	--dp-font-sans:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
	--dp-font-display:   'Space Grotesk', 'Inter', sans-serif;
	--dp-font-mono:      'JetBrains Mono', 'SF Mono', ui-monospace, Menlo, monospace;
	--dp-font-ar:        'Cairo', 'Inter', sans-serif;

	/* Scale — sane, refined */
	--dp-h1: clamp(2.25rem, 4.5vw, 3.75rem);   /* 36–60 px */
	--dp-h2: clamp(1.75rem, 3vw, 2.5rem);      /* 28–40 px */
	--dp-h3: 1.375rem;                          /* 22 px */
	--dp-h4: 1.125rem;                          /* 18 px */
	--dp-text-lg:  1.0625rem;                   /* 17 px */
	--dp-text-md:  1rem;
	--dp-text-sm:  0.875rem;
	--dp-text-xs:  0.75rem;

	/* Spacing */
	--dp-s-1: 0.25rem;  --dp-s-2: 0.5rem;
	--dp-s-3: 0.75rem;  --dp-s-4: 1rem;
	--dp-s-5: 1.25rem;  --dp-s-6: 1.5rem;
	--dp-s-8: 2rem;     --dp-s-10: 2.5rem;
	--dp-s-12: 3rem;    --dp-s-16: 4rem;
	--dp-s-20: 5rem;    --dp-s-24: 6rem;

	/* Radii */
	--dp-r-sm:  10px;
	--dp-r:     14px;
	--dp-r-md:  18px;
	--dp-r-lg:  24px;
	--dp-r-xl:  32px;
	--dp-r-full: 9999px;

	/* Shadows */
	--dp-shadow-1: 0 1px 0 rgba(255,255,255,0.04) inset, 0 1px 2px rgba(0,0,0,0.4);
	--dp-shadow-2: 0 1px 0 rgba(255,255,255,0.05) inset, 0 8px 24px rgba(0,0,0,0.35);
	--dp-shadow-3: 0 1px 0 rgba(255,255,255,0.06) inset, 0 24px 48px rgba(0,0,0,0.5);
	--dp-shadow-brand: 0 16px 40px -8px rgba(var(--dp-primary-rgb), 0.5);

	/* Motion */
	--dp-ease:      cubic-bezier(.4, 0, .2, 1);
	--dp-ease-out:  cubic-bezier(.16, 1, .3, 1);
	--dp-bounce:    cubic-bezier(.68, -0.55, .27, 1.55);
	--dp-dur:       .3s;
	--dp-dur-slow:  .6s;

	/* Layout */
	--dp-container:        1240px;
	--dp-container-narrow: 920px;
	--dp-container-wide:   1440px;
	--dp-gutter:           clamp(1rem, 3vw, 2rem);
	--dp-header-h:         72px;

	/* Gradients — refined, never gaudy */
	--dp-grad-brand:  linear-gradient(135deg, #00C853 0%, #00E676 100%);
	--dp-grad-deep:   linear-gradient(135deg, #00A341 0%, #00C853 100%);
	--dp-grad-text:   linear-gradient(135deg, #69F0AE 0%, #00E676 50%, #00C853 100%);
	--dp-grad-surface: linear-gradient(180deg, rgba(255,255,255,0.025) 0%, transparent 60%);
	--dp-grad-border:  linear-gradient(135deg, rgba(var(--dp-primary-rgb), 0.4), rgba(var(--dp-primary-rgb), 0.05));
}

/* Light mode tokens */
[data-theme="light"] {
	--dp-bg:             #FAFBFC;
	--dp-bg-1:           #FFFFFF;
	--dp-bg-2:           #F4F6F9;
	--dp-bg-3:           #ECEFF3;
	--dp-bg-4:           #E0E5EB;
	--dp-bg-overlay:     rgba(250, 251, 252, 0.85);
	--dp-border:         rgba(0, 0, 0, 0.06);
	--dp-border-strong:  rgba(0, 0, 0, 0.12);
	--dp-text:           #0A0E11;
	--dp-text-soft:      #2D353F;
	--dp-text-muted:     #5B6675;
	--dp-text-faint:     #8893A1;
	--dp-shadow-1: 0 1px 2px rgba(0,0,0,0.05);
	--dp-shadow-2: 0 4px 16px rgba(0,0,0,0.06);
	--dp-shadow-3: 0 16px 40px rgba(0,0,0,0.08);
	--dp-grad-surface: linear-gradient(180deg, rgba(0,0,0,0.015) 0%, transparent 60%);
	color-scheme: light;
}

/* ---------------------------------------
   1. RESET + BASE
   --------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; tab-size: 4; }
body {
	margin: 0;
	font-family: var(--dp-font-sans);
	font-size: var(--dp-text-md);
	line-height: 1.6;
	color: var(--dp-text);
	background: var(--dp-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	font-feature-settings: 'cv11', 'ss01', 'ss03';
}
html[lang="ar"] body, body.dp-rtl { font-family: var(--dp-font-ar); }

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--dp-text); text-decoration: none; transition: color var(--dp-dur); }
a:hover { color: var(--dp-primary); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--dp-font-display);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin: 0 0 var(--dp-s-4);
	color: var(--dp-text);
}
html[lang="ar"] h1, html[lang="ar"] h2, html[lang="ar"] h3 {
	font-family: var(--dp-font-ar);
	font-weight: 800;
	letter-spacing: 0;
}
h1 { font-size: var(--dp-h1); font-weight: 800; letter-spacing: -0.03em; }
h2 { font-size: var(--dp-h2); font-weight: 700; letter-spacing: -0.025em; }
h3 { font-size: var(--dp-h3); font-weight: 700; }
h4 { font-size: var(--dp-h4); font-weight: 600; }

p { margin: 0 0 var(--dp-s-4); color: var(--dp-text-soft); line-height: 1.65; }
small { color: var(--dp-text-muted); }
strong { color: var(--dp-text); font-weight: 600; }

button, input, select, textarea { font: inherit; color: inherit; }
button { background: transparent; border: 0; cursor: pointer; }

::selection { background: var(--dp-primary); color: #000; }

/* Skip link */
.dp-skip-link {
	position: absolute; top: -40px; left: 8px;
	background: var(--dp-primary); color: #000;
	padding: 8px 14px; border-radius: 6px;
	font-weight: 600; z-index: 200;
	transition: top var(--dp-dur);
}
.dp-skip-link:focus { top: 8px; }

/* ---------------------------------------
   2. LAYOUT PRIMITIVES
   --------------------------------------- */
.dp-container {
	width: 100%;
	max-width: var(--dp-container);
	margin-inline: auto;
	padding-inline: var(--dp-gutter);
}
.dp-container--narrow { max-width: var(--dp-container-narrow); }
.dp-container--wide   { max-width: var(--dp-container-wide); }

.dp-grid { display: grid; gap: var(--dp-s-6); }
.dp-grid--2 { grid-template-columns: repeat(2, 1fr); }
.dp-grid--3 { grid-template-columns: repeat(3, 1fr); }
.dp-grid--4 { grid-template-columns: repeat(4, 1fr); }
.dp-grid--auto { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
@media (max-width: 980px) {
	.dp-grid--3, .dp-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.dp-grid--2 { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.dp-grid--3, .dp-grid--4 { grid-template-columns: 1fr; }
}

.dp-section { padding-block: clamp(3rem, 7vw, 6rem); position: relative; }
.dp-section--tight { padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.dp-section--surface { background: var(--dp-bg-1); border-block: 1px solid var(--dp-border); }
.dp-section__head { text-align: center; margin-bottom: var(--dp-s-12); }
.dp-section__head--row { display: flex; justify-content: space-between; align-items: end; text-align: start; gap: var(--dp-s-6); flex-wrap: wrap; margin-bottom: var(--dp-s-8); }

.dp-text-center { text-align: center; }
.dp-muted       { color: var(--dp-text-muted); }
.dp-align-start { align-items: start; }
.dp-align-center{ align-items: center; }

/* ---------------------------------------
   3. AMBIENT BACKGROUND (subtle, refined)
   --------------------------------------- */
.dp-bg-canvas {
	position: fixed; inset: 0; z-index: -1;
	pointer-events: none; overflow: hidden;
}
.dp-bg-grid {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(ellipse at 50% 0%, #000 30%, transparent 80%);
}
[data-theme="light"] .dp-bg-grid {
	background-image:
		linear-gradient(rgba(0,0,0,0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0,0,0,0.03) 1px, transparent 1px);
}
.dp-bg-glow {
	position: absolute; width: 720px; height: 720px;
	border-radius: 50%; filter: blur(130px); opacity: 0.32;
	animation: dp-float 24s infinite alternate ease-in-out;
}
.dp-bg-glow--1 { background: rgba(var(--dp-primary-rgb), 0.45); top: -200px; inset-inline-start: -150px; }
.dp-bg-glow--2 { background: rgba(var(--dp-accent-rgb), 0.3); top: 40%; inset-inline-end: -200px; animation-delay: -8s; }
.dp-bg-glow--3 { background: rgba(0, 230, 118, 0.22); bottom: -200px; inset-inline-start: 30%; animation-delay: -16s; }
[data-theme="light"] .dp-bg-glow { opacity: 0.18; }

@keyframes dp-float {
	0%   { transform: translate(0, 0) scale(1); }
	50%  { transform: translate(60px, -40px) scale(1.15); }
	100% { transform: translate(-40px, 30px) scale(0.92); }
}

/* ---------------------------------------
   4. HEADER
   --------------------------------------- */
.dp-header {
	position: sticky; top: 0; z-index: 50;
	background: var(--dp-bg-overlay);
	backdrop-filter: blur(18px) saturate(180%);
	-webkit-backdrop-filter: blur(18px) saturate(180%);
	border-bottom: 1px solid var(--dp-border);
	transition: background var(--dp-dur);
}
.dp-header.is-scrolled {
	background: rgba(5, 7, 8, 0.94);
	box-shadow: 0 8px 24px -8px rgba(0,0,0,0.4);
}
[data-theme="light"] .dp-header.is-scrolled {
	background: rgba(255,255,255, 0.96);
	box-shadow: 0 8px 24px -12px rgba(0,0,0,0.08);
}
.dp-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	min-height: var(--dp-header-h);
	gap: clamp(0.75rem, 1.5vw, 1.5rem);
}
.dp-header__brand { flex-shrink: 0; min-width: 0; }

.dp-logo {
	display: inline-flex; align-items: center; gap: 10px;
	color: var(--dp-text); font-weight: 800; font-size: 1.125rem;
	letter-spacing: -0.02em;
	line-height: 1;
	white-space: nowrap;
	overflow: hidden;
}
.dp-logo:hover { color: var(--dp-text); }
.dp-logo__icon {
	width: 36px; height: 36px;
	flex-shrink: 0;
	display: grid; place-items: center;
}
.dp-logo__icon svg { width: 100%; height: 100%; }
.dp-logo__text {
	font-family: var(--dp-font-display);
	background: var(--dp-grad-text);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent;
	white-space: nowrap;
}
/* WP custom-logo support — size and crop sanely */
.dp-logo .custom-logo,
.custom-logo-link img {
	max-height: 40px !important;
	width: auto !important;
	height: auto;
	object-fit: contain;
	display: block;
}

.dp-nav--primary {
	flex: 1 1 auto;
	display: flex; justify-content: center;
	min-width: 0;
}
.dp-menu--primary {
	display: flex; gap: 2px;
	list-style: none; padding: 0; margin: 0;
	flex-wrap: nowrap;
}
.dp-menu--primary > li { flex-shrink: 0; }
.dp-menu--primary > li > a {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 9px 14px; border-radius: var(--dp-r);
	color: var(--dp-text-soft); font-weight: 500; font-size: 0.9rem;
	white-space: nowrap;
	line-height: 1.2;
	transition: all var(--dp-dur);
}
.dp-menu--primary > li > a:hover { color: var(--dp-primary); background: rgba(var(--dp-primary-rgb), 0.08); }
.dp-menu--primary > li.current-menu-item > a { color: var(--dp-primary); background: rgba(var(--dp-primary-rgb), 0.08); }

.dp-header__utility { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

@media (max-width: 1180px) {
	.dp-menu--primary > li > a { padding: 8px 11px; font-size: 0.85rem; }
}

/* Theme toggle — clean pill */
.dp-theme-toggle {
	width: 50px; height: 28px; border-radius: 999px;
	background: var(--dp-bg-3);
	border: 1px solid var(--dp-border-strong);
	position: relative; cursor: pointer;
	transition: background var(--dp-dur);
}
.dp-theme-toggle__thumb {
	position: absolute; top: 2px; inset-inline-start: 2px;
	width: 22px; height: 22px; border-radius: 50%;
	background: var(--dp-grad-brand);
	display: grid; place-items: center;
	color: #000;
	transition: transform var(--dp-dur) var(--dp-bounce);
}
[data-theme="light"] .dp-theme-toggle__thumb { transform: translateX(22px); }
html[dir="rtl"][data-theme="light"] .dp-theme-toggle__thumb { transform: translateX(-22px); }
.dp-theme-toggle__sun, .dp-theme-toggle__moon { width: 12px; height: 12px; position: absolute; transition: opacity var(--dp-dur); }
.dp-theme-toggle__sun  { opacity: 0; }
.dp-theme-toggle__moon { opacity: 1; }
[data-theme="light"] .dp-theme-toggle__sun  { opacity: 1; }
[data-theme="light"] .dp-theme-toggle__moon { opacity: 0; }

/* Lang switcher */
.dp-lang-switcher {
	display: inline-flex; padding: 3px; gap: 2px;
	background: var(--dp-bg-3); border: 1px solid var(--dp-border-strong);
	border-radius: 999px;
}
.dp-lang-switcher__btn {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 5px 11px; border-radius: 999px;
	color: var(--dp-text-muted); font-size: 0.72rem; font-weight: 700;
	letter-spacing: 0.04em; text-transform: uppercase;
	transition: all var(--dp-dur);
}
.dp-lang-switcher__btn.is-active { background: var(--dp-grad-brand); color: #000; }
.dp-lang-switcher__flag { font-size: 13px; }

/* Header buttons */
.dp-cart-btn, .dp-account-btn {
	display: inline-grid; place-items: center; position: relative;
	width: 38px; height: 38px; border-radius: 50%;
	background: var(--dp-bg-3); border: 1px solid var(--dp-border-strong);
	color: var(--dp-text-soft); transition: all var(--dp-dur);
}
.dp-cart-btn:hover, .dp-account-btn:hover {
	border-color: var(--dp-primary); color: var(--dp-primary);
	transform: translateY(-1px);
}
.dp-cart-btn__count {
	position: absolute; top: -3px; inset-inline-end: -3px;
	min-width: 18px; height: 18px; padding: 0 5px;
	border-radius: 9px; background: var(--dp-primary); color: #000;
	font-size: 10px; font-weight: 800; display: grid; place-items: center;
}

.dp-burger { display: none; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--dp-border-strong); flex-direction: column; align-items: center; justify-content: center; gap: 4px; }
.dp-burger span { display: block; width: 16px; height: 2px; background: var(--dp-text); border-radius: 2px; }

.dp-mobile-menu {
	position: fixed; inset: 0; z-index: 100;
	background: var(--dp-bg-overlay); backdrop-filter: blur(30px);
	transform: translateX(100%);
	transition: transform .5s var(--dp-ease-out);
	visibility: hidden;
}
html[dir="rtl"] .dp-mobile-menu { transform: translateX(-100%); }
.dp-mobile-menu.is-open { transform: translateX(0); visibility: visible; }
.dp-mobile-menu__inner { padding: 4rem 1.5rem; height: 100%; overflow-y: auto; }
.dp-mobile-menu__close { position: absolute; top: 20px; inset-inline-end: 20px; font-size: 28px; width: 40px; height: 40px; }
.dp-menu--mobile { list-style: none; padding: 0; margin: 0; }
.dp-menu--mobile > li > a {
	display: block; padding: 14px 0; font-size: 1.25rem;
	font-weight: 700; color: var(--dp-text); border-bottom: 1px solid var(--dp-border);
}

@media (max-width: 1024px) {
	.dp-nav--primary { display: none; }
	.dp-burger { display: flex; }
}
@media (max-width: 640px) {
	.dp-cart-btn, .dp-account-btn { display: none; }
}

/* ---------------------------------------
   5. BUTTONS  (refined, never too big)
   --------------------------------------- */
.dp-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 8px;
	padding: 10px 20px; min-height: 42px;
	border-radius: var(--dp-r);
	font-weight: 600; font-size: 0.9rem;
	border: 1px solid transparent;
	transition: all var(--dp-dur) var(--dp-ease);
	position: relative; overflow: hidden;
	white-space: nowrap;
}
.dp-btn--sm { padding: 7px 14px; min-height: 34px; font-size: 0.8rem; }
.dp-btn--lg { padding: 13px 26px; min-height: 48px; font-size: 0.95rem; }
.dp-btn--block { width: 100%; }

.dp-btn--primary {
	background: var(--dp-grad-brand);
	color: #000; font-weight: 700;
	box-shadow: var(--dp-shadow-brand);
}
.dp-btn--primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 20px 40px -8px rgba(var(--dp-primary-rgb), 0.55);
	color: #000;
}
.dp-btn--primary::after {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.3), transparent 70%);
	transform: translateX(-150%);
	transition: transform .8s var(--dp-ease);
}
.dp-btn--primary:hover::after { transform: translateX(150%); }

.dp-btn--ghost {
	background: var(--dp-bg-2);
	border-color: var(--dp-border-strong);
	color: var(--dp-text);
}
.dp-btn--ghost:hover {
	border-color: var(--dp-primary);
	color: var(--dp-primary);
	background: rgba(var(--dp-primary-rgb), 0.06);
}

.dp-btn--outline { border-color: var(--dp-primary); color: var(--dp-primary); }
.dp-btn--outline:hover { background: var(--dp-primary); color: #000; }

/* ---------------------------------------
   6. PILL / TAG / EYEBROW
   --------------------------------------- */
.dp-eyebrow {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 6px 14px; border-radius: 999px;
	background: rgba(var(--dp-primary-rgb), 0.08);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.2);
	color: var(--dp-primary);
	font-family: var(--dp-font-mono);
	font-size: 0.7rem; font-weight: 600;
	letter-spacing: 0.1em; text-transform: uppercase;
	margin-bottom: var(--dp-s-5);
}
html[lang="ar"] .dp-eyebrow { font-family: var(--dp-font-ar); letter-spacing: 0; font-size: 0.75rem; }
.dp-eyebrow__dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--dp-primary);
	box-shadow: 0 0 8px var(--dp-primary);
	animation: dp-pulse 2s infinite;
}
@keyframes dp-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.6; transform: scale(1.4); }
}

.dp-tag {
	display: inline-block; padding: 3px 10px; border-radius: 6px;
	background: rgba(var(--dp-primary-rgb), 0.1); color: var(--dp-primary);
	font-size: 0.72rem; font-weight: 600;
	margin-inline-end: 6px; margin-bottom: 6px;
}

.dp-grad-text {
	background: var(--dp-grad-text);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}

/* ---------------------------------------
   7. HERO  (bento-style, refined)
   --------------------------------------- */
.dp-hero {
	padding-block: clamp(3rem, 8vw, 7rem);
	position: relative;
}
.dp-hero__inner {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
@media (max-width: 980px) {
	.dp-hero__inner { grid-template-columns: 1fr; }
}

.dp-hero__title {
	font-size: var(--dp-h1);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.035em;
	margin-bottom: var(--dp-s-5);
}
html[lang="ar"] .dp-hero__title { font-weight: 800; line-height: 1.2; letter-spacing: -0.01em; }

.dp-hero__subtitle {
	font-size: var(--dp-text-lg);
	color: var(--dp-text-soft);
	margin-bottom: var(--dp-s-8);
	max-width: 540px;
	line-height: 1.6;
}

.dp-hero__cta { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: var(--dp-s-10); }

.dp-hero__stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--dp-s-5);
	padding-top: var(--dp-s-6);
	border-top: 1px solid var(--dp-border);
	max-width: 580px;
}
.dp-hero__stat { display: flex; flex-direction: column; gap: 2px; }
.dp-hero__stat-num {
	font-family: var(--dp-font-display);
	font-size: 1.5rem;
	font-weight: 800;
	background: var(--dp-grad-text);
	-webkit-background-clip: text; -webkit-text-fill-color: transparent;
	letter-spacing: -0.02em;
}
.dp-hero__stat span:last-child {
	font-size: 0.72rem;
	color: var(--dp-text-muted);
	font-weight: 500;
	letter-spacing: 0.02em;
}
@media (max-width: 600px) { .dp-hero__stats { grid-template-columns: repeat(2, 1fr); } }

/* --- Hero Bento Visual --- */
.dp-hero__visual {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto auto;
	gap: 12px;
	position: relative;
}
.dp-hero__bento {
	background: var(--dp-bg-2);
	border: 1px solid var(--dp-border-strong);
	border-radius: var(--dp-r-lg);
	padding: 18px;
	position: relative;
	overflow: hidden;
	transition: transform .5s var(--dp-ease-out), border-color .3s;
}
.dp-hero__bento:hover { transform: translateY(-4px); border-color: var(--dp-primary); }
.dp-hero__bento::before {
	content: ''; position: absolute; inset: 0;
	background: var(--dp-grad-surface);
	pointer-events: none;
}
.dp-hero__bento--wide { grid-column: 1 / -1; }
.dp-hero__bento--accent {
	background: linear-gradient(135deg, rgba(var(--dp-primary-rgb), 0.16), var(--dp-bg-2));
	border-color: rgba(var(--dp-primary-rgb), 0.3);
}
.dp-hero__bento-label {
	display: flex; align-items: center; gap: 6px;
	font-family: var(--dp-font-mono); font-size: 0.7rem; font-weight: 600;
	color: var(--dp-text-muted); text-transform: uppercase; letter-spacing: 0.1em;
	margin-bottom: 12px;
}
html[lang="ar"] .dp-hero__bento-label { font-family: var(--dp-font-ar); letter-spacing: 0; font-size: 0.78rem; }
.dp-hero__bento-label::before {
	content: ''; width: 6px; height: 6px; border-radius: 50%;
	background: var(--dp-primary); box-shadow: 0 0 8px var(--dp-primary);
}
.dp-hero__bento-value {
	font-family: var(--dp-font-display);
	font-size: 1.875rem; font-weight: 800;
	letter-spacing: -0.025em; line-height: 1.05;
	margin-bottom: 4px;
}
html[lang="ar"] .dp-hero__bento-value { font-family: var(--dp-font-ar); }
.dp-hero__bento-sub { font-size: 0.78rem; color: var(--dp-text-muted); }

/* Live ticker variant */
.dp-hero__ticker {
	display: flex; align-items: baseline; gap: 8px;
	margin-bottom: 6px;
}
.dp-hero__ticker-symbol { font-family: var(--dp-font-mono); font-size: 0.78rem; color: var(--dp-text-muted); }
.dp-hero__ticker-price {
	font-family: var(--dp-font-display);
	font-size: 1.5rem; font-weight: 800;
}
.dp-hero__ticker-change {
	font-family: var(--dp-font-mono); font-size: 0.72rem;
	color: var(--dp-success); font-weight: 600;
}

/* Logos cluster */
.dp-hero__logos {
	display: flex; flex-wrap: wrap; gap: 6px;
}
.dp-hero__logo-chip {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 5px 9px; border-radius: 8px;
	background: var(--dp-bg-3); border: 1px solid var(--dp-border);
	font-size: 0.72rem; font-weight: 600; color: var(--dp-text-soft);
}
.dp-hero__logo-chip::before {
	content: ''; width: 6px; height: 6px; border-radius: 50%;
	background: var(--dp-chip-color, var(--dp-primary));
}

/* ---------------------------------------
   8. MARQUEE (refined)
   --------------------------------------- */
.dp-marquee {
	overflow: hidden;
	padding-block: var(--dp-s-6);
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.dp-marquee__track {
	display: flex; align-items: center;
	gap: clamp(2rem, 4vw, 3.5rem);
	animation: dp-marquee 40s linear infinite;
	width: max-content;
}
.dp-marquee__item {
	font-family: var(--dp-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--dp-text-muted);
	white-space: nowrap;
	letter-spacing: -0.01em;
	opacity: 0.7;
	transition: opacity .3s;
}
.dp-marquee__item:hover { opacity: 1; color: var(--dp-text); }
.dp-marquee__sep {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--dp-primary); opacity: 0.4;
	flex-shrink: 0;
}
@keyframes dp-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
html[dir="rtl"] .dp-marquee__track { animation-direction: reverse; }

/* ---------------------------------------
   9. SERVICE CARDS — gradient-border design
   --------------------------------------- */
.dp-service-card {
	display: block;
	padding: 1px;
	border-radius: var(--dp-r-lg);
	background: var(--dp-border);
	transition: background var(--dp-dur);
	position: relative;
	color: var(--dp-text);
}
.dp-service-card::before {
	content: ''; position: absolute; inset: 0;
	border-radius: inherit;
	background: linear-gradient(135deg, rgba(var(--dp-primary-rgb), 0.5), transparent 50%);
	opacity: 0;
	transition: opacity var(--dp-dur);
	pointer-events: none;
}
.dp-service-card:hover { color: var(--dp-text); }
.dp-service-card:hover::before { opacity: 1; }

.dp-service-card__inner {
	position: relative;
	padding: clamp(1.25rem, 2.5vw, 1.75rem);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border-radius: calc(var(--dp-r-lg) - 1px);
	height: 100%;
	display: flex; flex-direction: column;
}
.dp-service-card__icon {
	width: 44px; height: 44px;
	border-radius: var(--dp-r);
	background: rgba(var(--dp-primary-rgb), 0.1);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.2);
	display: grid; place-items: center;
	font-size: 22px; color: var(--dp-primary);
	margin-bottom: var(--dp-s-4);
}
.dp-service-card h3 {
	font-size: 1.1rem;
	margin-bottom: var(--dp-s-2);
}
.dp-service-card p {
	font-size: 0.875rem;
	color: var(--dp-text-muted);
	margin-bottom: var(--dp-s-5);
	flex: 1;
}
.dp-service-card__link {
	display: inline-flex; align-items: center; gap: 5px;
	color: var(--dp-primary);
	font-weight: 600; font-size: 0.82rem;
	letter-spacing: 0.02em;
	transition: gap var(--dp-dur);
}
.dp-service-card:hover .dp-service-card__link { gap: 10px; }

/* ---------------------------------------
   10. ACCOUNT CARDS  (refined product cards)
   --------------------------------------- */
.dp-account-card {
	display: flex; flex-direction: column;
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	overflow: hidden;
	transition: all var(--dp-dur) var(--dp-ease-out);
	--card-brand: var(--dp-primary);
}
.dp-account-card:hover {
	transform: translateY(-4px);
	border-color: var(--card-brand);
	box-shadow: 0 24px 48px -16px rgba(0,0,0,0.5), 0 0 0 1px var(--card-brand);
}
.dp-account-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	background: linear-gradient(135deg, var(--card-brand) 0%, rgba(0,0,0,0.4) 100%);
	overflow: hidden;
}
.dp-account-card__media::before {
	content: ''; position: absolute; inset: 0;
	background:
		radial-gradient(circle at 25% 25%, rgba(255,255,255,0.18), transparent 50%),
		linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.4));
}
.dp-account-card__img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .8s var(--dp-ease-out);
	position: relative;
}
.dp-account-card:hover .dp-account-card__img { transform: scale(1.05); }

.dp-account-card__body {
	padding: var(--dp-s-5);
	display: flex; flex-direction: column;
	gap: var(--dp-s-3);
	flex: 1;
}
.dp-account-card__title {
	font-size: 1.0625rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-bottom: 0;
}
.dp-account-card__title a { color: var(--dp-text); }
.dp-account-card__title a:hover { color: var(--card-brand); }
.dp-account-card__meta {
	display: inline-flex; align-items: center; gap: 5px;
	color: var(--dp-text-muted);
	font-size: 0.75rem;
	font-family: var(--dp-font-mono);
}
html[lang="ar"] .dp-account-card__meta { font-family: var(--dp-font-ar); }
.dp-account-card__price { margin-top: auto; padding-top: var(--dp-s-3); border-top: 1px solid var(--dp-border); }

.dp-price { display: inline-flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.dp-price__current, .dp-price__sale {
	font-family: var(--dp-font-display);
	font-size: 1.5rem; font-weight: 800;
	color: var(--card-brand, var(--dp-primary));
	letter-spacing: -0.025em;
}
.dp-price__old { font-size: 0.85rem; color: var(--dp-text-faint); text-decoration: line-through; }
.dp-price__off {
	background: var(--dp-danger); color: #fff;
	padding: 2px 6px; border-radius: 4px;
	font-size: 0.65rem; font-weight: 800; letter-spacing: 0.04em;
}

.dp-badge {
	position: absolute; top: 10px; inset-inline-start: 10px;
	padding: 4px 9px; border-radius: 999px;
	font-size: 0.65rem; font-weight: 700;
	text-transform: uppercase; letter-spacing: 0.06em;
	backdrop-filter: blur(8px);
}
.dp-badge--in  { background: rgba(34, 197, 94, 0.18); color: #4ADE80; border: 1px solid rgba(34, 197, 94, 0.3); }
.dp-badge--low { background: rgba(245, 158, 11, 0.18); color: #FBBF24; border: 1px solid rgba(245, 158, 11, 0.3); }
.dp-badge--out { background: rgba(239, 68, 68, 0.18); color: #F87171; border: 1px solid rgba(239, 68, 68, 0.3); }

/* ---------------------------------------
   11. FILTER CHIPS
   --------------------------------------- */
.dp-filter {
	display: flex; gap: 6px; flex-wrap: wrap;
	padding-block: var(--dp-s-2);
	margin-bottom: var(--dp-s-6);
}
.dp-filter__chip {
	padding: 8px 16px; border-radius: 999px;
	background: var(--dp-bg-2); border: 1px solid var(--dp-border);
	color: var(--dp-text-soft);
	font-size: 0.8rem; font-weight: 600;
	white-space: nowrap;
	transition: all var(--dp-dur);
}
.dp-filter__chip:hover { border-color: var(--dp-border-strong); color: var(--dp-text); }
.dp-filter__chip.is-active {
	background: var(--dp-grad-brand);
	border-color: transparent;
	color: #000;
	box-shadow: var(--dp-shadow-brand);
}

/* ---------------------------------------
   12. DOLLAR CALCULATOR
   --------------------------------------- */
.dp-calculator {
	padding: 1px;
	border-radius: var(--dp-r-lg);
	background: var(--dp-grad-border);
	position: relative;
}
.dp-calculator > * { position: relative; }
.dp-calculator__inner {
	padding: var(--dp-s-6);
	background: var(--dp-bg-2);
	background-image: var(--dp-grad-surface);
	border-radius: calc(var(--dp-r-lg) - 1px);
}

.dp-calculator__head { display: flex; align-items: center; justify-content: space-between; gap: var(--dp-s-3); flex-wrap: wrap; margin-bottom: var(--dp-s-6); }
.dp-calculator__tabs { display: inline-flex; padding: 3px; background: var(--dp-bg-3); border: 1px solid var(--dp-border); border-radius: 999px; gap: 3px; }
.dp-calculator__tab { padding: 7px 16px; border-radius: 999px; font-weight: 600; font-size: 0.82rem; color: var(--dp-text-muted); transition: all var(--dp-dur); }
.dp-calculator__tab.is-active { background: var(--dp-grad-brand); color: #000; box-shadow: var(--dp-shadow-brand); }
.dp-calculator__rate { text-align: end; }
.dp-calculator__rate small { display: block; color: var(--dp-text-muted); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--dp-font-mono); }
.dp-calculator__rate strong { font-family: var(--dp-font-display); font-size: 1rem; }

.dp-calculator__field { margin-bottom: var(--dp-s-4); }
.dp-calculator__field label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 0.82rem; color: var(--dp-text-soft); }
.dp-calculator__input-wrap {
	display: flex; align-items: center;
	background: var(--dp-bg-3); border: 1px solid var(--dp-border-strong);
	border-radius: var(--dp-r); padding: 3px 16px;
	transition: border-color var(--dp-dur);
}
.dp-calculator__input-wrap:focus-within { border-color: var(--dp-primary); }
.dp-calculator__input-wrap input {
	flex: 1; padding: 11px 0; background: transparent; border: 0; outline: 0;
	font-family: var(--dp-font-display);
	font-size: 1.5rem; font-weight: 800;
	color: var(--dp-text);
	letter-spacing: -0.025em;
}
.dp-calculator__suffix { color: var(--dp-text-muted); font-weight: 600; font-family: var(--dp-font-mono); font-size: 0.85rem; }
.dp-calculator__range { margin-top: 10px; }
.dp-calculator__range input { width: 100%; accent-color: var(--dp-primary); }
.dp-calculator__range-marks { display: flex; justify-content: space-between; font-size: 10px; color: var(--dp-text-muted); margin-top: 4px; font-family: var(--dp-font-mono); }

.dp-calculator__result { background: var(--dp-bg-3); border: 1px solid var(--dp-border); border-radius: var(--dp-r); padding: var(--dp-s-4); margin: var(--dp-s-5) 0; }
.dp-calculator__result-row { display: flex; justify-content: space-between; align-items: baseline; padding: 7px 0; border-bottom: 1px dashed var(--dp-border); }
.dp-calculator__result-row:last-child { border-bottom: 0; }
.dp-calculator__result-row small { color: var(--dp-text-muted); font-size: 0.78rem; }
.dp-calculator__result-row strong { font-family: var(--dp-font-display); font-size: 1.125rem; font-weight: 800; }
.dp-calculator__result-row strong small { font-size: 0.72rem; color: var(--dp-text-muted); margin-inline-start: 4px; font-weight: 500; font-family: var(--dp-font-mono); }

.dp-calculator__pay { margin-top: var(--dp-s-4); text-align: center; }
.dp-calculator__pay small { color: var(--dp-text-muted); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--dp-font-mono); }
.dp-calculator__pay-list { display: flex; justify-content: center; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.dp-calculator__pay-list span { padding: 4px 10px; border-radius: 6px; background: var(--dp-bg-3); border: 1px solid var(--dp-border); font-size: 11px; font-weight: 600; }

/* ---------------------------------------
   13. PROCESS STEPS
   --------------------------------------- */
.dp-process { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--dp-s-6); position: relative; }
@media (max-width: 800px) { .dp-process { grid-template-columns: 1fr; } }
.dp-process__step {
	padding: 1px;
	border-radius: var(--dp-r-lg);
	background: var(--dp-border);
	transition: background .4s;
}
.dp-process__step:hover { background: var(--dp-grad-border); }
.dp-process__step-inner {
	padding: var(--dp-s-6);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border-radius: calc(var(--dp-r-lg) - 1px);
	height: 100%;
}
.dp-process__num {
	display: inline-flex; align-items: center;
	font-family: var(--dp-font-mono);
	font-size: 0.7rem; font-weight: 600;
	color: var(--dp-primary);
	padding: 4px 10px; border-radius: 6px;
	background: rgba(var(--dp-primary-rgb), 0.1);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.2);
	margin-bottom: var(--dp-s-3);
	letter-spacing: 0.05em;
}
html[lang="ar"] .dp-process__num { font-family: var(--dp-font-ar); letter-spacing: 0; font-size: 0.78rem; }
.dp-process__step h3 { font-size: 1.125rem; margin-bottom: var(--dp-s-2); }
.dp-process__step p { font-size: 0.875rem; color: var(--dp-text-muted); margin: 0; }

/* ---------------------------------------
   14. FEATURE / TESTIMONIAL / FAQ
   --------------------------------------- */
.dp-feature-card {
	padding: var(--dp-s-6);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	transition: all var(--dp-dur);
}
.dp-feature-card:hover { transform: translateY(-3px); border-color: var(--dp-primary); }
.dp-feature-card__icon { font-size: 28px; margin-bottom: var(--dp-s-3); }
.dp-feature-card h3 { font-size: 1.0625rem; margin-bottom: var(--dp-s-2); }
.dp-feature-card p { font-size: 0.875rem; color: var(--dp-text-muted); margin: 0; }

.dp-feature-list { list-style: none; padding: 0; margin: var(--dp-s-4) 0; display: grid; gap: 8px; }
.dp-feature-list li { display: flex; align-items: start; gap: 10px; color: var(--dp-text-soft); font-size: 0.92rem; }
.dp-feature-list li span:first-child {
	flex-shrink: 0; width: 18px; height: 18px; border-radius: 50%;
	background: rgba(var(--dp-primary-rgb), 0.15);
	color: var(--dp-primary); font-weight: 800;
	display: grid; place-items: center; font-size: 10px;
	margin-top: 2px;
}

.dp-testimonial {
	padding: var(--dp-s-6);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	transition: all var(--dp-dur);
}
.dp-testimonial:hover { border-color: var(--dp-primary); transform: translateY(-3px); }
.dp-testimonial__stars { color: #FBBF24; font-size: 0.92rem; letter-spacing: 2px; margin-bottom: var(--dp-s-3); }
.dp-testimonial__quote {
	font-size: 0.95rem;
	color: var(--dp-text); line-height: 1.65;
	margin-bottom: var(--dp-s-4);
}
.dp-testimonial__author { display: flex; align-items: center; gap: 12px; padding-top: var(--dp-s-3); border-top: 1px solid var(--dp-border); }
.dp-testimonial__author::before {
	content: ''; flex: 0 0 38px; width: 38px; height: 38px;
	border-radius: 50%; background: var(--dp-grad-brand);
}
.dp-testimonial__author strong { display: block; font-size: 0.9rem; }
.dp-testimonial__author small { font-size: 0.75rem; color: var(--dp-text-muted); }

.dp-faq { display: grid; gap: 10px; }
.dp-faq__item {
	background: var(--dp-bg-1); border: 1px solid var(--dp-border);
	border-radius: var(--dp-r); overflow: hidden;
	transition: all var(--dp-dur);
}
.dp-faq__item:hover { border-color: var(--dp-border-strong); }
.dp-faq__item[open] { border-color: var(--dp-primary); background: var(--dp-bg-2); }
.dp-faq__item summary {
	padding: var(--dp-s-4) var(--dp-s-5);
	display: flex; justify-content: space-between; align-items: center; gap: var(--dp-s-3);
	font-weight: 600; font-size: 0.95rem; cursor: pointer;
	list-style: none;
}
.dp-faq__item summary::-webkit-details-marker { display: none; }
.dp-faq__icon {
	flex: 0 0 28px; width: 28px; height: 28px; border-radius: 8px;
	display: grid; place-items: center;
	background: rgba(var(--dp-primary-rgb), 0.1); color: var(--dp-primary);
	font-weight: 800; font-size: 16px;
	transition: transform var(--dp-dur);
}
.dp-faq__item[open] .dp-faq__icon { transform: rotate(45deg); background: var(--dp-grad-brand); color: #000; }
.dp-faq__answer { padding: 0 var(--dp-s-5) var(--dp-s-5); color: var(--dp-text-soft); font-size: 0.92rem; line-height: 1.65; }

/* ---------------------------------------
   15. PLAN CARDS
   --------------------------------------- */
.dp-billing-toggle {
	display: inline-flex; padding: 3px; gap: 3px;
	background: var(--dp-bg-2); border: 1px solid var(--dp-border);
	border-radius: 999px; margin: var(--dp-s-5) auto;
}
.dp-billing-toggle__btn { padding: 8px 18px; border-radius: 999px; font-weight: 600; font-size: 0.85rem; color: var(--dp-text-muted); transition: all var(--dp-dur); }
.dp-billing-toggle__btn.is-active { background: var(--dp-grad-brand); color: #000; }
.dp-billing-toggle__save {
	margin-inline-start: 5px;
	padding: 1px 5px; border-radius: 4px;
	background: rgba(0,0,0,0.2); font-size: 9px; font-weight: 800;
}

.dp-plan-card {
	padding: var(--dp-s-8);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	transition: all var(--dp-dur);
	position: relative;
}
.dp-plan-card:hover { transform: translateY(-4px); border-color: var(--dp-primary); }
.dp-plan-card--featured {
	background:
		radial-gradient(ellipse at 0% 0%, rgba(var(--dp-primary-rgb), 0.15), transparent 60%),
		var(--dp-bg-2);
	border-color: var(--dp-primary);
	box-shadow: var(--dp-shadow-brand);
}
.dp-plan-card__badge {
	position: absolute; top: -12px; inset-inline-start: 24px;
	padding: 5px 12px; border-radius: 999px;
	background: var(--dp-grad-brand); color: #000;
	font-size: 0.68rem; font-weight: 800;
	letter-spacing: 0.06em; text-transform: uppercase;
}
.dp-plan-card__name { font-size: 1.125rem; margin-bottom: var(--dp-s-2); }
.dp-plan-card__price { display: flex; align-items: baseline; gap: 4px; margin: var(--dp-s-4) 0; }
.dp-plan-card__currency { font-size: 1.125rem; color: var(--dp-text-muted); }
.dp-plan-card__num {
	font-family: var(--dp-font-display);
	font-size: 2.75rem; font-weight: 800;
	line-height: 1; letter-spacing: -0.04em;
	color: var(--dp-text);
}
.dp-plan-card__period { color: var(--dp-text-muted); font-size: 0.82rem; margin-inline-start: 4px; }
.dp-plan-card__excerpt { color: var(--dp-text-muted); font-size: 0.88rem; }

/* ---------------------------------------
   16. PAGE HERO  (for inner pages)
   --------------------------------------- */
.dp-page-hero {
	padding-block: clamp(2.5rem, 6vw, 5rem);
	text-align: center;
	border-bottom: 1px solid var(--dp-border);
	background: linear-gradient(180deg, rgba(var(--dp-primary-rgb), 0.04), transparent);
}
.dp-page-hero h1 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: var(--dp-s-3); }
.dp-page-hero .dp-muted { font-size: 1rem; max-width: 560px; margin-inline: auto; }

/* ---------------------------------------
   17. SEARCH
   --------------------------------------- */
.dp-search { display: flex; gap: 3px; background: var(--dp-bg-2); border: 1px solid var(--dp-border); border-radius: 999px; padding: 3px; }
.dp-search__input { flex: 1; padding: 8px 14px; background: transparent; border: 0; color: var(--dp-text); outline: 0; font-size: 0.85rem; }
.dp-search__btn { width: 34px; height: 34px; border-radius: 50%; background: var(--dp-grad-brand); color: #000; display: grid; place-items: center; }

/* ---------------------------------------
   18. SINGLE PRODUCT
   --------------------------------------- */
.dp-single-account { padding-block: clamp(2rem, 4vw, 3rem); }
.dp-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; color: var(--dp-text-muted); margin-bottom: var(--dp-s-6); font-family: var(--dp-font-mono); }
html[lang="ar"] .dp-breadcrumb { font-family: var(--dp-font-ar); }
.dp-breadcrumb a:hover { color: var(--dp-primary); }
.dp-breadcrumb span { color: var(--dp-text); }
.dp-single-account__media {
	border-radius: var(--dp-r-lg); overflow: hidden;
	border: 1px solid var(--dp-border);
	background: var(--dp-bg-2);
	aspect-ratio: 4 / 3;
}
.dp-single-account__info h1 { margin-bottom: var(--dp-s-3); }
.dp-single-account__meta { display: flex; gap: 12px; flex-wrap: wrap; color: var(--dp-text-muted); font-size: 0.85rem; margin: var(--dp-s-3) 0; }
.dp-single-account__price { margin: var(--dp-s-4) 0; }
.dp-single-account__price .dp-price__current, .dp-single-account__price .dp-price__sale { font-size: 2.25rem; }
.dp-single-account__buy { display: grid; gap: 8px; max-width: 340px; margin: var(--dp-s-5) 0; }
.dp-single-account__features { margin-top: var(--dp-s-5); }
.dp-single-account__desc { margin-top: var(--dp-s-12); padding-top: var(--dp-s-8); border-top: 1px solid var(--dp-border); }

/* ---------------------------------------
   19. 404
   --------------------------------------- */
.dp-404 { display: grid; place-items: center; min-height: 60vh; padding: var(--dp-s-10); text-align: center; }
.dp-404__glitch {
	font-family: var(--dp-font-display);
	font-size: clamp(6rem, 18vw, 12rem);
	font-weight: 900;
	background: var(--dp-grad-text);
	-webkit-background-clip: text; -webkit-text-fill-color: transparent;
	margin: 0; line-height: 1;
}
.dp-404__cta { display: flex; gap: 10px; justify-content: center; margin-top: var(--dp-s-6); }

/* ---------------------------------------
   20. FOOTER
   --------------------------------------- */
.dp-footer {
	background: var(--dp-bg-1);
	border-top: 1px solid var(--dp-border);
}
.dp-footer__cta { padding-block: var(--dp-s-12); }
.dp-footer-cta-card {
	background:
		radial-gradient(ellipse at 0% 100%, rgba(var(--dp-primary-rgb), 0.18), transparent 50%),
		radial-gradient(ellipse at 100% 0%, rgba(var(--dp-accent-rgb), 0.12), transparent 50%),
		var(--dp-bg-2);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.25);
	border-radius: var(--dp-r-xl);
	padding: clamp(2rem, 5vw, 3.5rem);
	display: grid; grid-template-columns: 1.4fr 1fr;
	gap: var(--dp-s-6); align-items: center;
}
@media (max-width: 800px) { .dp-footer-cta-card { grid-template-columns: 1fr; text-align: center; } .dp-footer-cta-card__actions { justify-content: center; } }
.dp-footer-cta-card__title { font-size: clamp(1.5rem, 3vw, 2.25rem); margin-bottom: 8px; }
.dp-footer-cta-card__content p { margin: 0; font-size: 0.95rem; }
.dp-footer-cta-card__actions { display: flex; gap: 10px; flex-wrap: wrap; }

.dp-footer__main { padding-block: var(--dp-s-12); }
.dp-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.4fr; gap: var(--dp-s-8); }
@media (max-width: 900px) { .dp-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .dp-footer__grid { grid-template-columns: 1fr; } }

.dp-footer__title { font-size: 0.85rem; font-weight: 700; margin-bottom: var(--dp-s-4); color: var(--dp-text); text-transform: uppercase; letter-spacing: 0.08em; font-family: var(--dp-font-mono); }
html[lang="ar"] .dp-footer__title { font-family: var(--dp-font-ar); letter-spacing: 0; font-size: 0.9rem; }
.dp-footer__links { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.dp-footer__links a { color: var(--dp-text-muted); font-size: 0.875rem; }
.dp-footer__links a:hover { color: var(--dp-primary); }
.dp-footer__about { color: var(--dp-text-muted); font-size: 0.875rem; margin-top: var(--dp-s-3); }

.dp-social { display: flex; gap: 6px; margin-top: var(--dp-s-4); }
.dp-social__link {
	display: grid; place-items: center;
	width: 34px; height: 34px; border-radius: 10px;
	background: var(--dp-bg-2); border: 1px solid var(--dp-border);
	color: var(--dp-text-muted); transition: all var(--dp-dur);
}
.dp-social__link:hover { background: var(--dp-grad-brand); color: #000; border-color: transparent; transform: translateY(-2px); }

.dp-newsletter { display: flex; gap: 6px; margin-bottom: var(--dp-s-4); }
.dp-newsletter__input { flex: 1; padding: 10px 14px; border-radius: var(--dp-r); background: var(--dp-bg-2); border: 1px solid var(--dp-border); color: var(--dp-text); font-size: 0.85rem; }
.dp-newsletter__input:focus { outline: none; border-color: var(--dp-primary); }
.dp-footer__contact { display: grid; gap: 6px; font-size: 0.85rem; }
.dp-footer__contact-row { color: var(--dp-text-muted); }
.dp-footer__contact-row strong { color: var(--dp-text); margin-inline-end: 6px; }
.dp-footer__contact-row:hover { color: var(--dp-primary); }

.dp-footer__bottom { padding: var(--dp-s-5) 0; border-top: 1px solid var(--dp-border); }
.dp-footer__bottom > .dp-container { display: flex; justify-content: space-between; align-items: center; gap: var(--dp-s-4); flex-wrap: wrap; }
.dp-footer__copy { margin: 0; color: var(--dp-text-muted); font-size: 0.82rem; }
.dp-footer__bottom-links { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--dp-s-5); font-size: 0.82rem; }
.dp-footer__bottom-links a { color: var(--dp-text-muted); }
.dp-footer__bottom-links a:hover { color: var(--dp-primary); }

/* ---------------------------------------
   21. FLOATING WHATSAPP
   --------------------------------------- */
.dp-floating-wa {
	position: fixed; bottom: 22px; inset-inline-end: 22px;
	z-index: 60;
	width: 54px; height: 54px; border-radius: 50%;
	background: #25D366; color: #fff;
	display: grid; place-items: center;
	box-shadow: 0 12px 28px rgba(37, 211, 102, 0.45);
	transition: all var(--dp-dur);
}
.dp-floating-wa:hover { transform: scale(1.08); color: #fff; }
.dp-floating-wa__pulse {
	position: absolute; inset: 0; border-radius: 50%;
	background: #25D366; opacity: 0.4;
	animation: dp-wa-pulse 2s infinite;
}
@keyframes dp-wa-pulse {
	0%   { transform: scale(1);  opacity: 0.6; }
	100% { transform: scale(1.7); opacity: 0; }
}

/* ---------------------------------------
   22. SCROLL PROGRESS
   --------------------------------------- */
.dp-scroll-progress {
	position: fixed; top: 0; left: 0; right: 0; z-index: 51;
	height: 2px;
	background: var(--dp-grad-brand);
	transform: scaleX(0); transform-origin: 0 0;
	transition: transform .1s linear;
}

/* ---------------------------------------
   23. BLOG POST CARD
   --------------------------------------- */
.dp-post-card {
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	overflow: hidden;
	transition: all var(--dp-dur);
}
.dp-post-card:hover { transform: translateY(-3px); border-color: var(--dp-primary); }
.dp-post-card__media img { aspect-ratio: 16 / 10; object-fit: cover; }
.dp-post-card__body { padding: var(--dp-s-5); }
.dp-post-card__meta { font-family: var(--dp-font-mono); font-size: 0.72rem; color: var(--dp-text-muted); margin-bottom: 8px; }
html[lang="ar"] .dp-post-card__meta { font-family: var(--dp-font-ar); }
.dp-post-card__title { font-size: 1.0625rem; margin-bottom: var(--dp-s-2); }
.dp-post-card__title a { color: var(--dp-text); }
.dp-post-card__title a:hover { color: var(--dp-primary); }
.dp-post-card__excerpt { font-size: 0.875rem; color: var(--dp-text-muted); }
.dp-post-card__link { display: inline-block; color: var(--dp-primary); font-weight: 600; font-size: 0.85rem; margin-top: var(--dp-s-3); }

/* ---------------------------------------
   24. PAGINATION
   --------------------------------------- */
.pagination, .nav-links { display: flex; gap: 6px; justify-content: center; margin-top: var(--dp-s-8); }
.page-numbers {
	display: inline-grid; place-items: center;
	min-width: 38px; height: 38px; padding: 0 12px;
	border-radius: var(--dp-r); background: var(--dp-bg-2); border: 1px solid var(--dp-border);
	color: var(--dp-text-soft); font-size: 0.85rem; font-weight: 600;
}
.page-numbers:hover, .page-numbers.current { background: var(--dp-grad-brand); color: #000; border-color: transparent; }

/* ---------------------------------------
   25. SECTION VARIANTS
   --------------------------------------- */
.dp-cta-row { display: flex; gap: 10px; flex-wrap: wrap; }
.dp-page-content { font-size: 1rem; line-height: 1.7; }
.dp-page-content p { margin-bottom: var(--dp-s-4); }
.dp-page-head { margin-bottom: var(--dp-s-8); }
.dp-page-head__title { font-size: clamp(2rem, 4vw, 2.75rem); }

/* ---------------------------------------
   26. CONTACT PAGE
   --------------------------------------- */
.dp-contact-hero {
	padding-block: clamp(3rem, 6vw, 5rem);
	background:
		radial-gradient(ellipse 800px 400px at 50% 0%, rgba(var(--dp-primary-rgb), 0.12), transparent 70%),
		var(--dp-bg);
	text-align: center;
	border-bottom: 1px solid var(--dp-border);
}
.dp-contact-hero__inner { max-width: 720px; margin-inline: auto; }
.dp-contact-hero h1 { font-size: clamp(2rem, 4.5vw, 3.25rem); margin-bottom: var(--dp-s-4); }
.dp-contact-hero__sub { font-size: 1.0625rem; color: var(--dp-text-soft); margin-bottom: var(--dp-s-6); }
.dp-contact-hero__pills { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.dp-contact-hero__pill {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 14px; border-radius: 999px;
	background: var(--dp-bg-2); border: 1px solid var(--dp-border);
	font-size: 0.78rem; color: var(--dp-text-soft); font-weight: 500;
}
.dp-contact-hero__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--dp-success); animation: dp-pulse 2s infinite; box-shadow: 0 0 8px var(--dp-success); }
.dp-contact-hero__dot--green { background: var(--dp-success); }

.dp-contact-channels {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--dp-s-4);
}
@media (max-width: 800px) { .dp-contact-channels { grid-template-columns: 1fr; } }
.dp-contact-channel {
	display: block;
	padding: var(--dp-s-6);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
	color: var(--dp-text);
	transition: all var(--dp-dur) var(--dp-ease-out);
	position: relative;
	overflow: hidden;
}
.dp-contact-channel:hover {
	transform: translateY(-4px);
	border-color: var(--dp-primary);
	color: var(--dp-text);
	box-shadow: 0 24px 48px -16px rgba(0,0,0,0.5);
}
.dp-contact-channel--whatsapp:hover { border-color: #25D366; box-shadow: 0 24px 48px -16px rgba(37,211,102,0.4); }
.dp-contact-channel__icon {
	width: 52px; height: 52px;
	border-radius: var(--dp-r);
	background: rgba(var(--dp-primary-rgb), 0.1);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.2);
	color: var(--dp-primary);
	display: grid; place-items: center;
	margin-bottom: var(--dp-s-4);
}
.dp-contact-channel--whatsapp .dp-contact-channel__icon { background: rgba(37, 211, 102, 0.1); border-color: rgba(37, 211, 102, 0.2); color: #25D366; }
.dp-contact-channel h3 { font-size: 1.125rem; margin-bottom: 6px; }
.dp-contact-channel p { font-size: 0.875rem; color: var(--dp-text-muted); margin-bottom: var(--dp-s-3); }
.dp-contact-channel__handle {
	font-family: var(--dp-font-mono); font-size: 0.85rem;
	color: var(--dp-text);
	padding: 8px 12px; border-radius: var(--dp-r);
	background: var(--dp-bg-3); border: 1px solid var(--dp-border);
	margin-bottom: var(--dp-s-4);
	word-break: break-all;
}
html[lang="ar"] .dp-contact-channel__handle { font-family: var(--dp-font-mono); direction: ltr; text-align: start; }
.dp-contact-channel__cta {
	display: inline-flex; align-items: center; gap: 6px;
	font-weight: 600; font-size: 0.85rem;
	color: var(--dp-primary);
	transition: gap var(--dp-dur);
}
.dp-contact-channel--whatsapp .dp-contact-channel__cta { color: #25D366; }
.dp-contact-channel:hover .dp-contact-channel__cta { gap: 12px; }

.dp-contact-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 4vw, 3rem);
	align-items: start;
}
@media (max-width: 980px) { .dp-contact-grid { grid-template-columns: 1fr; } }

.dp-contact-form-wrap h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); margin-block: var(--dp-s-3) var(--dp-s-4); }
.dp-contact-form-wrap > p { font-size: 0.95rem; margin-bottom: var(--dp-s-6); }
.dp-contact-form { display: grid; gap: var(--dp-s-4); }
.dp-contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--dp-s-4); }
@media (max-width: 600px) { .dp-contact-form__row { grid-template-columns: 1fr; } }
.dp-contact-form__field { display: grid; gap: 6px; }
.dp-contact-form__field span {
	font-size: 0.78rem; font-weight: 600;
	color: var(--dp-text-soft);
	letter-spacing: 0.02em;
}
.dp-contact-form__field input,
.dp-contact-form__field select,
.dp-contact-form__field textarea {
	padding: 12px 14px;
	background: var(--dp-bg-2);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r);
	color: var(--dp-text);
	font-size: 0.92rem;
	transition: border-color var(--dp-dur), background var(--dp-dur);
	font-family: var(--dp-font-sans);
}
html[lang="ar"] .dp-contact-form__field input,
html[lang="ar"] .dp-contact-form__field select,
html[lang="ar"] .dp-contact-form__field textarea { font-family: var(--dp-font-ar); }
.dp-contact-form__field input::placeholder,
.dp-contact-form__field textarea::placeholder { color: var(--dp-text-faint); }
.dp-contact-form__field input:focus,
.dp-contact-form__field select:focus,
.dp-contact-form__field textarea:focus {
	outline: none;
	border-color: var(--dp-primary);
	background: var(--dp-bg-3);
}
.dp-contact-form__field textarea { resize: vertical; min-height: 120px; }
.dp-contact-form__check {
	display: flex; align-items: center; gap: 10px;
	font-size: 0.85rem; color: var(--dp-text-muted);
	cursor: pointer;
}
.dp-contact-form__check input {
	width: 18px; height: 18px;
	accent-color: var(--dp-primary);
	cursor: pointer;
}
.dp-contact-form__actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: var(--dp-s-2); }

.dp-contact-info { display: grid; gap: var(--dp-s-4); position: sticky; top: calc(var(--dp-header-h) + 1rem); }
@media (max-width: 980px) { .dp-contact-info { position: static; } }
.dp-contact-info__card {
	padding: var(--dp-s-6);
	background: var(--dp-bg-1);
	background-image: var(--dp-grad-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-lg);
}
.dp-contact-info__card--accent {
	background:
		radial-gradient(ellipse at 0% 0%, rgba(var(--dp-primary-rgb), 0.15), transparent 60%),
		var(--dp-bg-2);
	border-color: rgba(var(--dp-primary-rgb), 0.3);
}
.dp-contact-info__card h3 { font-size: 1rem; margin-bottom: var(--dp-s-3); }
.dp-contact-info__card p { font-size: 0.875rem; color: var(--dp-text-muted); margin-bottom: var(--dp-s-4); }
.dp-contact-hours { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.dp-contact-hours li {
	display: flex; justify-content: space-between; align-items: center;
	padding: 8px 0; border-bottom: 1px dashed var(--dp-border);
	font-size: 0.875rem; color: var(--dp-text-muted);
}
.dp-contact-hours li:last-child { border-bottom: 0; }
.dp-contact-hours li strong { color: var(--dp-text); font-family: var(--dp-font-mono); font-size: 0.85rem; }
html[lang="ar"] .dp-contact-hours li strong { font-family: var(--dp-font-mono); direction: ltr; }
.dp-contact-hours__note {
	display: block !important;
	padding: 10px 12px !important;
	margin-top: 6px;
	background: rgba(var(--dp-primary-rgb), 0.08);
	border: 1px solid rgba(var(--dp-primary-rgb), 0.18) !important;
	border-radius: var(--dp-r);
	color: var(--dp-primary) !important;
	font-size: 0.8rem !important; font-weight: 600;
	text-align: center;
}

/* ---------------------------------------
   27. ELEMENTOR PAGE
   --------------------------------------- */
body.dp-elementor-page .dp-main > article > .entry-content { padding: 0; }

/* ---------------------------------------
   27. REDUCED MOTION
   --------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.dp-bg-glow, .dp-marquee__track, .dp-floating-wa__pulse, .dp-eyebrow__dot { animation: none !important; }
	[data-dp-fade], [data-dp-stagger] > *, [data-dp-split] .dp-char { opacity: 1 !important; transform: none !important; }
}
