/* ===== DGVX LLC — Shared Stylesheet ===== */
:root{
  --primary:#0A2540;--accent:#14B8A6;--gold:#C8A45D;--secondary:#1D4E7A;
  --white:#fff;--muted:#64748B;--card:#ffffff;--border:#E2E8F0;
  --text:#1F2937;
  --font-en:'Inter',"Segoe UI",Arial,sans-serif;
  --font-ar:'Tajawal','Segoe UI',Arial,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-en);color:var(--text);
  background:#F6F9FC;
  min-height:100vh;line-height:1.5;
}
html[lang="ar"] body{font-family:var(--font-ar)}
a{color:inherit;text-decoration:none}
.container{width:min(var(--maxw),92%);margin:auto}
img,svg{max-width:100%}

/* ---------- Header / Nav ---------- */
header{position:sticky;top:0;z-index:30;background:rgba(246,249,252,.92);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:14px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.7px;font-size:15px;white-space:nowrap;color:var(--text)}
.logo{width:46px;height:46px;flex:none;display:grid;place-items:center;transform:rotate(45deg);border:3px solid var(--primary);border-bottom-color:var(--gold);box-shadow:0 0 30px rgba(200,164,93,.15)}
.logo span{transform:rotate(-45deg);font-size:11px;letter-spacing:1.6px;color:var(--primary)}
.nav-right{display:flex;align-items:center;gap:14px}
.links{display:flex;gap:24px;color:#4B5563;font-weight:650;font-size:15px}
.links a{white-space:nowrap}
.links a:hover{color:var(--accent)}

.lang-toggle{
  display:flex;align-items:center;border:1px solid var(--border);border-radius:999px;overflow:hidden;
  font-weight:800;font-size:13px;background:var(--white);flex:none;
}
.lang-toggle button{
  border:none;background:transparent;color:var(--muted);padding:8px 14px;cursor:pointer;font-weight:800;font-size:13px;
  font-family:inherit;
}
.lang-toggle button.active{background:var(--accent);color:#fff}

.nav-toggle{display:none;background:none;border:1px solid var(--border);border-radius:10px;color:var(--text);width:42px;height:42px;font-size:20px;cursor:pointer;flex:none;align-items:center;justify-content:center}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 24px;border-radius:10px;border:1px solid rgba(255,255,255,.22);background:var(--accent);font-weight:800;color:#fff;box-shadow:0 6px 16px rgba(20,184,166,.25);cursor:pointer;font-size:15px}
.btn.secondary{background:transparent;color:var(--text);box-shadow:none;border-color:var(--border)}
.btn.secondary:hover{border-color:var(--accent)}
.btn.small{padding:9px 16px;font-size:13px}

/* ---------- Layout blocks ---------- */
.hero{padding:80px 0 60px}
.eyebrow{color:var(--accent);font-weight:900;text-transform:uppercase;letter-spacing:2.2px;font-size:13px}
h1{font-size:clamp(36px,6vw,64px);line-height:1.08;margin:14px 0 16px;font-weight:800;color:var(--primary)}
h1 .accent,h2 .accent{color:var(--accent)}
h2{font-size:clamp(22px,3.4vw,32px);font-weight:800;margin:0 0 12px;color:var(--primary)}
h3{font-weight:800;color:var(--primary)}
p{color:var(--muted);line-height:1.85;font-size:16.5px}
.lede{font-size:19px;color:#4B5563}

.grid{display:grid;gap:22px}
.cards{grid-template-columns:repeat(4,1fr)}
.grid.two{grid-template-columns:1.1fr .9fr;align-items:center}

.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 2px 12px rgba(10,37,64,.06);transition:border-color .2s ease}
.card:hover{border-color:var(--accent)}
.icon{width:56px;height:56px;border-radius:16px;background:rgba(20,184,166,.1);display:grid;place-items:center;color:var(--accent);margin-bottom:18px}
.icon svg{width:26px;height:26px}

section{padding:64px 0;border-top:1px solid var(--border)}
.section-title{text-align:center;margin-bottom:40px}
.section-title small{color:var(--accent);font-weight:900;text-transform:uppercase;letter-spacing:2px;font-size:13px}
.section-title h2{font-size:clamp(28px,4vw,42px);margin:10px 0 0}

.notice{border-left:4px solid var(--gold);background:rgba(200,164,93,.08);padding:16px 18px;border-radius:10px;color:var(--muted);font-size:14.5px}
html[lang="ar"] .notice{border-left:none;border-right:4px solid var(--gold)}

/* ---------- Forms ---------- */
.form input,.form textarea,.form select{width:100%;padding:14px 15px;margin-top:7px;border-radius:10px;border:1px solid var(--border);background:var(--white);color:var(--text);font-family:inherit;font-size:15px}
.form select option{background:var(--white);color:var(--text)}
.form label{display:block;margin:15px 0 4px;color:var(--text);font-weight:700;font-size:14.5px}
.form textarea{min-height:150px;resize:vertical}
.form small{color:var(--muted)}

/* ---------- Legal table ---------- */
.legal-info{table-layout:fixed;border-collapse:separate;border-spacing:0 4px;margin:1rem 0;width:100%}
.legal-info td{padding:.65rem 1rem .65rem 0;border-bottom:1px solid var(--border);vertical-align:top;font-size:15px;color:var(--text)}
.legal-info td:first-child{font-weight:700;width:220px;min-width:220px;color:var(--gold);padding-inline-end:18px;white-space:nowrap}
html[lang="ar"] .legal-info td:first-child{padding-inline-end:0;padding-inline-start:18px;width:200px;min-width:200px}
html[lang="ar"] .legal-info td{padding:.65rem 0 .65rem 1rem}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--border);padding:24px 0}
.faq-item:first-child{padding-top:0}
.faq-item:last-child{border-bottom:none}
.faq-item h3{margin:0 0 8px;font-size:18px;color:var(--text)}
.faq-item p{margin:0}
.faq-item ul{margin:8px 0 0;padding-left:20px}
.faq-item li{margin-bottom:6px;font-size:14px;color:var(--muted)}

/* ---------- Footer ---------- */
.footer{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:32px 0;color:var(--muted);border-top:1px solid var(--border);font-size:14.5px}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-links a:hover{color:var(--accent)}

/* ---------- Trust Bar ---------- */
.trust-bar{padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:0;background:#fff}
.trust-items{display:flex;justify-content:center;gap:32px;flex-wrap:wrap}
.trust-items span{color:var(--primary);font-weight:700;font-size:13.5px;letter-spacing:.4px;text-transform:uppercase}

/* ---------- How We Work ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-top:28px}
.step{text-align:center;padding:20px 12px;background:var(--card);border:1px solid var(--border);border-radius:16px}
.step .num{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:900;margin:0 auto 12px;font-size:16px}
.step h4{margin:0 0 6px;font-size:15px;color:var(--primary)}
.step p{margin:0;font-size:13.5px;color:var(--muted)}

/* ---------- Who We Help ---------- */
.sectors{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:20px}
.sector{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:12px;font-weight:650;font-size:14.5px;color:var(--text)}
.sector .icon{width:auto;height:auto;margin:0}
.sector .icon svg{width:20px;height:20px}

/* ---------- New Sections ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:20px}
.feature-item{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:22px}
.feature-item h4{margin:0 0 6px;font-size:15px;color:var(--text)}
.feature-item p{margin:0;font-size:14px}

.tag-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.tag{background:rgba(20,184,166,.08);border:1px solid rgba(20,184,166,.2);border-radius:999px;padding:6px 16px;font-size:13.5px;color:var(--muted);font-weight:600}

.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:20px}
.result-item{text-align:center;padding:22px 14px;background:var(--card);border:1px solid var(--border);border-radius:16px}
.result-item .icon{margin-bottom:10px;background:none;color:var(--accent);width:auto;height:auto}
.result-item .icon svg{width:28px;height:28px}
.result-item h4{margin:0 0 4px;font-size:15px;color:var(--text)}
.result-item p{margin:0;font-size:13.5px}

.trust-center{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;margin-top:20px}
.trust-center p{margin:8px 0;font-size:15px}
.trust-center .check{color:var(--accent);font-weight:900;margin-inline-end:8px}

/* ---------- Motion (fade-in on load, respects reduced motion) ---------- */
.fade-in{animation:fadeUp .6s ease both}
.fade-in.d1{animation-delay:.06s}.fade-in.d2{animation-delay:.12s}.fade-in.d3{animation-delay:.18s}.fade-in.d4{animation-delay:.24s}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.fade-in{animation:none}}

/* ---------- Mobile ---------- */
@media(max-width:930px){
  .links{
    position:fixed;inset:70px 14px auto 14px;display:none;flex-direction:column;gap:4px;
    background:rgba(255,255,255,.96);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:16px;
    padding:10px;box-shadow:0 24px 60px rgba(0,0,0,.12);z-index:25;
  }
  .links.open{display:flex}
  .links a{padding:13px 14px;border-radius:10px}
  .links a:hover{background:rgba(10,37,64,.05)}
  .nav-toggle{display:flex}
  .cards{grid-template-columns:1fr}
  .grid.two{grid-template-columns:1fr!important}
  h1{font-size:40px}
  .footer{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){
  .container{width:94%}
  .hero{padding:56px 0 40px}
  section{padding:48px 0}
  .lang-toggle button{padding:7px 10px;font-size:12px}
}

/* ---------- Cookie Consent Banner ---------- */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--border);padding:16px 24px;
  display:none;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  font-size:14px;color:var(--text);
  transform:translateY(100%);transition:transform .35s ease;
}
.cookie-banner.show{display:flex;transform:translateY(0)}
.cookie-banner p{margin:0;max-width:680px;color:var(--muted);font-size:14px}
.cookie-banner a{color:var(--accent);white-space:nowrap}
.cookie-banner .btn{flex:none}

.include-list{list-style:none;padding:0;margin:10px 0 0}
.include-list li{padding:5px 0 5px 20px;position:relative;color:var(--muted);font-size:14px}
.include-list li::before{content:"–";position:absolute;left:0;color:var(--gold);font-weight:700}
html[lang="ar"] .include-list li{padding:5px 20px 5px 0}
html[lang="ar"] .include-list li::before{left:auto;right:0}

/* ---------- Refinements v2 ---------- */
/* Unified checkmark (works on every page, not only inside .trust-center) */
.check{color:var(--accent);font-weight:900;margin-inline-end:8px}

/* Button feedback */
.btn:hover{filter:brightness(1.07)}
.btn:active{transform:scale(.98)}

/* Keyboard focus visibility (accessibility) */
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(20,184,166,.15)}
.form select{cursor:pointer}

/* Arabic (RTL) typography fixes: letter-spacing breaks connected Arabic script */
html[lang="ar"] .eyebrow,
html[lang="ar"] .section-title small,
html[lang="ar"] .trust-items span,
html[lang="ar"] .brand{letter-spacing:0}
html[lang="ar"] .faq-item ul{padding-left:0;padding-right:20px}

/* Floating WhatsApp button (shared) */
.dgvx-whatsapp{position:fixed;bottom:24px;right:24px;z-index:999;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.25);transition:transform .2s ease}
.dgvx-whatsapp:hover{transform:scale(1.08)}
.dgvx-whatsapp svg{width:30px;height:30px;fill:#fff}
html[dir="rtl"] .dgvx-whatsapp{right:auto;left:24px}

/* ---------- Design v3: dark hero with network map ---------- */
.hero-dark{background:var(--primary);position:relative;overflow:hidden}
.hero-dark .container{position:relative;z-index:1}
.hero-dark h1{color:#F6F9FC}
.hero-dark .lede{color:#B9C9D9}
.hero-map{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero-dark .btn.secondary{color:#DCE7F2;border-color:#2A5A86}
.hero-dark .btn.secondary:hover{border-color:var(--accent);color:#fff}
@media(prefers-reduced-motion:reduce){.hero-map animate{display:none}}

/* ---------- Design v3: dark sections ---------- */
.section-dark{background:var(--primary);border-top-color:rgba(255,255,255,.08)}
.section-dark h2{color:#F6F9FC}
.section-dark .trust-center{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.section-dark .trust-center p{color:#DCE7F2}

/* ---------- Design v3: stats band ---------- */
.stats-band{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;margin-top:28px;text-align:center}
.stat .num{font-size:34px;font-weight:800;color:var(--accent);line-height:1}
.stat .num.gold{color:var(--gold)}
.stat p{margin:8px 0 0;color:#B9C9D9;font-size:14px}

/* ---------- Design v3: dark footer ---------- */
footer{background:#071A2E}
.footer{border-top:none;color:#8FA6BC}
.footer a:hover{color:var(--accent)}

/* ---------- Design v3: diamond brand motif on section labels ---------- */
.section-title small::before,.section-title small::after{content:"";display:inline-block;width:7px;height:7px;transform:rotate(45deg);vertical-align:2px}
.section-title small::before{background:var(--gold);margin-inline-end:10px}
.section-title small::after{background:var(--accent);margin-inline-start:10px}

/* ---------- Design v3: scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Design v3: Arabic optical size ---------- */
html[lang="ar"] p{font-size:17px}
html[lang="ar"] .lede{font-size:20px}
/* force rebuild */
