/* ═══════════════════════════════════════════════
   ENSIGN — Blog Post Stylesheet v3
   Brand Book v1.0 · Cinematic Oasis (Night theme)
   ══════════════════════════════════════════════ */

:root{
  --bone:#F2EFE8;
  --bone-soft:#EDE8DC;
  --night:#07111E;
  --oasis:#00D9C0;
  --oasis-soft:rgba(0,217,192,.12);
  --ink:#0A0A0A;
  --ink-mute:rgba(242,239,232,.62);
  --ink-soft:rgba(242,239,232,.38);
  --line:rgba(242,239,232,.10);
  --line-soft:rgba(242,239,232,.06);
  --glass:rgba(255,255,255,.05);
  --shadow-sm:0 1px 4px rgba(0,0,0,.20);
  --shadow-md:0 8px 28px -8px rgba(0,0,0,.40), 0 2px 8px rgba(0,0,0,.20);
  --shadow-lg:0 24px 70px -20px rgba(0,0,0,.60), 0 8px 24px rgba(0,0,0,.30);
  --ease:cubic-bezier(.23,1,.32,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --sans:'Manrope',sans-serif;
  --display:'Fraunces',serif;
  --mono:'JetBrains Mono',monospace;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0;}
html{ scroll-behavior:smooth;}
html,body{
  background:var(--night);
  color:var(--bone);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.005em;
  line-height:1.6;
}
html[dir="rtl"], html[dir="rtl"] body, [lang="ar"]{
  font-family:'Noto Kufi Arabic',var(--sans),-apple-system,BlinkMacSystemFont,sans-serif;
  letter-spacing:0;
}
img,svg,video{ display:block; max-width:100%;}
a{ color:inherit; text-decoration:none;}
button{ font:inherit; cursor:pointer; border:0; background:none;}


.container{ max-width:1280px; margin:0 auto; padding:0 56px;}
.section{ position:relative; z-index:2;}

/* ═══ Background ═══ */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 60vw 60vw at -15vw -10vw, rgba(0,217,192,.07), transparent 70%),
    radial-gradient(ellipse 55vw 55vw at 110vw 50vh, rgba(0,217,192,.04), transparent 70%);
}
body::after{ display:none;}
body > *{ position:relative; z-index:2;}

/* ═══ Nav ═══ */
.site-nav{
  position:fixed; top:18px; left:50%; transform:translateX(-50%);
  z-index:50;
  display:flex; align-items:center; gap:32px;
  background:rgba(242,239,232,.85);
  backdrop-filter:blur(22px) saturate(140%); -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, var(--shadow-md);
  border-radius:999px;
  padding:10px 12px 10px 22px;
  width:auto; max-width:calc(100% - 48px);
  color:var(--ink);
}
[dir="rtl"] .site-nav{ padding:10px 22px 10px 12px;}
.site-nav .nav-brand{
  display:flex; align-items:center; gap:8px;
  font-weight:700; font-size:15px; letter-spacing:-.02em;
  color:var(--ink);
}
.site-nav .nav-logo-img{ display:block; height:20px; width:auto; filter:brightness(0);}
.site-nav .nav-links{ display:flex; gap:6px;}
.site-nav .nav-links a{
  font-size:13px; color:rgba(10,10,10,.62);
  padding:8px 14px; border-radius:999px;
  white-space:nowrap;
  transition:color .25s, background .25s;
}
.site-nav .nav-links a:hover{ color:var(--ink); background:rgba(10,10,10,.06);}
.site-nav .nav-actions{ display:flex; align-items:center; gap:8px;}
.site-nav .nav-lang{
  font-size:13px; font-weight:500; color:rgba(10,10,10,.62);
  padding:8px 14px; border-radius:999px;
  transition:color .25s, background .25s;
}
.site-nav .nav-lang:hover{ color:var(--ink); background:rgba(10,10,10,.06);}
.site-nav .nav-cta{
  background:var(--ink); color:#fff;
  padding:10px 18px; border-radius:999px;
  font-size:13px; font-weight:500;
  display:inline-flex; align-items:center; gap:8px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  will-change:transform;
}
.site-nav .nav-cta:hover{ transform:translateY(-2px); box-shadow:0 12px 28px -8px rgba(10,10,10,.4);}
[dir="rtl"] .site-nav .nav-cta svg{ transform:scaleX(-1);}

.nav-burger{
  display:none; flex-direction:column; gap:4px; padding:10px;
  border-radius:999px; transition:background .25s;
}
.nav-burger:hover{ background:rgba(10,10,10,.06);}
.nav-burger span{
  width:18px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s var(--ease), opacity .2s;
}
.nav-burger.open span:nth-child(1){ transform:translateY(6px) rotate(45deg);}
.nav-burger.open span:nth-child(2){ opacity:0;}
.nav-burger.open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg);}

.nav-mobile{
  position:fixed; top:80px; left:24px; right:24px;
  z-index:49;
  background:rgba(242,239,232,.97);
  backdrop-filter:blur(22px) saturate(140%); -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:var(--shadow-lg);
  border-radius:24px;
  padding:18px;
  display:none; flex-direction:column; gap:6px;
  opacity:0; transform:translateY(-12px);
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  color:var(--ink);
}
.nav-mobile.open{ display:flex; opacity:1; transform:translateY(0);}
.nav-mobile a{
  padding:14px 16px; border-radius:14px;
  font-size:15px; color:var(--ink); font-weight:500;
  transition:background .2s;
}
.nav-mobile a:hover{ background:rgba(10,10,10,.06);}
.nav-mobile .nav-mobile-cta{ background:var(--ink); color:#fff; text-align:center; margin-top:6px;}

/* ═══ Article Hero ═══ */
.blog-post-hero{ padding:160px 0 0;}
.blog-post-header{ max-width:820px; margin:0 auto;}
.blog-post-breadcrumb{
  display:flex; flex-wrap:wrap; gap:8px; align-items:center;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.06em; color:var(--ink-soft);
  margin-bottom:32px;
}
[dir="rtl"] .blog-post-breadcrumb{ font-family:var(--mono),'Noto Kufi Arabic',monospace;}
.blog-post-breadcrumb a{ color:var(--ink-soft); transition:color .2s;}
.blog-post-breadcrumb a:hover{ color:var(--bone);}
.blog-post-breadcrumb .breadcrumb-sep{ opacity:.5;}

.blog-post-category{
  display:inline-block;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--oasis);
  padding:6px 14px; border-radius:999px;
  background:var(--oasis-soft);
  margin-bottom:24px;
}
[dir="rtl"] .blog-post-category{ font-family:'Noto Kufi Arabic',sans-serif; letter-spacing:.06em; text-transform:none;}

.blog-post-title{
  font-family:var(--display);
  font-size:clamp(34px, 4.6vw, 64px);
  line-height:1.1; letter-spacing:-.02em;
  font-weight:300; color:var(--bone);
  margin:0 0 28px;
}
[dir="rtl"] .blog-post-title{
  font-family:'Noto Kufi Arabic',sans-serif;
  font-weight:600; line-height:1.25; letter-spacing:-.005em;
}

.blog-post-meta{
  display:flex; flex-wrap:wrap; gap:14px; align-items:center;
  font-family:var(--mono); font-size:12px; color:var(--ink-mute);
  letter-spacing:.04em;
}
[dir="rtl"] .blog-post-meta{ font-family:var(--mono),'Noto Kufi Arabic',monospace;}
.blog-post-meta span{ display:inline-flex; align-items:center; gap:6px;}
.blog-post-meta svg{ width:14px; height:14px; opacity:.5;}
.blog-post-meta .meta-dot{ width:3px; height:3px; border-radius:50%; background:var(--ink-soft);}

/* ═══ Featured Image ═══ */
.blog-post-image{
  margin:48px auto 0; max-width:1200px;
  border-radius:24px; overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-lg);
}
.blog-post-image img{ width:100%; height:auto; display:block;}

/* ═══ Article Body ═══ */
.blog-post-content{
  max-width:720px; margin:0 auto;
  font-size:18px; line-height:1.80; color:var(--bone);
}
[dir="rtl"] .blog-post-content{ font-size:18px; line-height:2.0;}

.blog-post-content > * + *{ margin-top:1.4em;}
.blog-post-content > h2 + *,
.blog-post-content > h3 + *{ margin-top:1em;}

.blog-post-content h2{
  font-family:var(--display);
  font-size:clamp(26px, 2.6vw, 34px);
  line-height:1.2; letter-spacing:-.015em; font-weight:300;
  margin:2.6em 0 .2em;
  color:var(--bone);
}
[dir="rtl"] .blog-post-content h2{
  font-family:'Noto Kufi Arabic',sans-serif;
  font-weight:600; line-height:1.4; letter-spacing:0;
}

.blog-post-content h3{
  font-size:clamp(19px, 1.8vw, 22px);
  line-height:1.3; letter-spacing:-.015em; font-weight:600;
  margin:2em 0 .2em;
  color:var(--bone);
}
[dir="rtl"] .blog-post-content h3{ font-family:'Noto Kufi Arabic',sans-serif; line-height:1.5;}

.blog-post-content h4{
  font-size:17px; font-weight:600; line-height:1.4;
  margin:1.8em 0 .2em; color:var(--bone);
}

.blog-post-content p{ color:var(--bone);}
.blog-post-content p strong{ color:var(--bone); font-weight:700;}

.blog-post-content a{
  color:var(--oasis);
  text-decoration:underline;
  text-decoration-color:rgba(0,217,192,.35);
  text-underline-offset:3px;
  transition:text-decoration-color .25s;
}
.blog-post-content a:hover{ text-decoration-color:var(--oasis);}

.blog-post-content ul,
.blog-post-content ol{
  padding-inline-start:1.4em;
  color:var(--bone);
}
.blog-post-content ul{ list-style:none; padding-inline-start:0;}
.blog-post-content ul > li{
  position:relative; padding-inline-start:1.6em; margin-top:.7em;
}
.blog-post-content ul > li::before{
  content:""; position:absolute; inset-inline-start:0; top:.75em;
  width:5px; height:5px; border-radius:50%;
  background:var(--oasis); flex:none;
}
.blog-post-content ol > li{ margin-top:.7em; padding-inline-start:.4em;}
.blog-post-content ol > li::marker{ color:var(--ink-mute); font-family:var(--mono);}

.blog-post-content blockquote{
  position:relative; margin:2em 0;
  padding:24px 32px;
  background:rgba(0,217,192,.05);
  border:1px solid rgba(255,255,255,.06);
  border-inline-start:3px solid var(--oasis);
  border-radius:14px;
  font-size:20px; line-height:1.55;
  color:var(--bone); font-style:italic; font-weight:300;
}
[dir="rtl"] .blog-post-content blockquote{ font-style:normal; font-weight:500;}

.blog-post-content code{
  background:rgba(255,255,255,.07);
  padding:2px 8px; border-radius:6px;
  font-family:var(--mono); font-size:.92em;
  color:var(--oasis);
}
.blog-post-content pre{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:20px 22px;
  overflow-x:auto;
  font-size:14px; line-height:1.6;
}
.blog-post-content pre code{ background:transparent; padding:0; color:var(--bone);}

.blog-post-content table{
  width:100%; border-collapse:collapse;
  margin:2em 0;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px; overflow:hidden;
  box-shadow:var(--shadow-sm);
  font-size:15px;
}
.blog-post-content th,
.blog-post-content td{
  padding:14px 18px;
  text-align:start;
  border-bottom:1px solid rgba(255,255,255,.05);
  vertical-align:top; color:var(--bone);
}
.blog-post-content th{
  background:rgba(255,255,255,.05);
  font-weight:600; color:var(--bone);
  font-size:13px; letter-spacing:.04em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.blog-post-content tr:last-child td{ border-bottom:0;}
.blog-post-content tr:hover td{ background:rgba(255,255,255,.03);}

.blog-post-content img,
.blog-post-content picture img{
  margin:2em auto;
  border-radius:18px; box-shadow:var(--shadow-md);
}

.blog-post-content hr,
.blog-post-divider{
  border:0; height:1px;
  background:var(--line);
  margin:3em 0;
  max-width:720px; margin-left:auto; margin-right:auto;
}

.blog-post-content .pull-quote{
  font-family:var(--display);
  font-size:clamp(22px, 2.4vw, 30px);
  line-height:1.3; letter-spacing:-.01em;
  color:var(--bone); font-weight:300; font-style:italic;
  text-align:center;
  padding:36px 24px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin:2.4em 0;
}

/* ═══ Share row ═══ */
.blog-share{
  max-width:720px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px;
  padding:20px 0;
}
.blog-share-label{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft);
}
[dir="rtl"] .blog-share-label{ font-family:'Noto Kufi Arabic',sans-serif; letter-spacing:.04em; text-transform:none;}
.blog-share-links{ display:flex; gap:8px;}
.blog-share-link{
  width:40px; height:40px; border-radius:50%;
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink-mute);
  transition:transform .35s var(--ease), background .25s, color .25s, border-color .25s;
}
.blog-share-link:hover{
  transform:translateY(-2px);
  background:var(--oasis); color:var(--night); border-color:var(--oasis);
}

/* ═══ CTA card ═══ */
.cta-card{
  position:relative; overflow:hidden;
  max-width:1100px; margin:60px auto 0;
  border-radius:36px; padding:80px 56px;
  background:var(--bone);
  border:1px solid rgba(255,255,255,.15);
  box-shadow:var(--shadow-lg);
  text-align:center;
}
.cta-card::before{
  content:""; position:absolute; inset:-50%; pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 30% 20%, rgba(0,217,192,.25), transparent 70%),
    radial-gradient(ellipse 50% 40% at 70% 80%, rgba(0,217,192,.10), transparent 70%);
  animation:ctaSwirl 22s ease-in-out infinite;
}
@keyframes ctaSwirl{ 0%,100%{transform:rotate(0deg) scale(1);} 50%{transform:rotate(8deg) scale(1.05);} }
.cta-card > *{ position:relative; z-index:1;}
.cta-pattern{ display:none;}

.kicker{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(10,10,10,.4);
  display:block; margin-bottom:20px;
}

.cta-title{
  font-family:var(--display);
  font-size:clamp(30px, 4vw, 56px);
  line-height:1.1; letter-spacing:-.02em; font-weight:300;
  max-width:780px; margin:0 auto 18px;
  color:var(--ink);
}
[dir="rtl"] .cta-title{
  font-family:'Noto Kufi Arabic',sans-serif;
  font-weight:600; line-height:1.25;
}
.cta-subtitle{
  font-size:17px; line-height:1.65; color:rgba(10,10,10,.62);
  max-width:620px; margin:0 auto 36px;
}
.cta-buttons{
  display:inline-flex; gap:12px; flex-wrap:wrap; justify-content:center;
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px; border-radius:999px;
  font-size:14px; font-weight:600; font-family:var(--sans);
  text-decoration:none; cursor:pointer;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .25s, color .25s;
  will-change:transform;
}
.btn-large{ padding:16px 28px;}
.btn-primary{ background:var(--night); color:var(--bone); box-shadow:var(--shadow-md);}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(0,0,0,.5);}
.btn-outline{ background:transparent; color:var(--ink); border:1px solid rgba(10,10,10,.15);}
.btn-outline:hover{ transform:translateY(-2px); border-color:var(--ink); background:rgba(10,10,10,.04);}
.btn-whatsapp{
  background:#25D366; color:#fff;
  box-shadow:0 10px 28px -8px rgba(37,211,102,.45);
}
.btn-whatsapp:hover{ transform:translateY(-2px); background:#22c25c;}
[dir="rtl"] .btn svg{ transform:scaleX(-1);}

/* ═══ Footer ═══ */
.site-footer{
  margin-top:80px;
  padding:80px 0 40px;
  border-top:1px solid var(--line);
  position:relative; z-index:2;
}
.footer-inner{
  max-width:1280px; margin:0 auto; padding:0 56px;
  display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:40px;
}
.footer-brand{ display:flex; flex-direction:column; gap:8px;}
.footer-brand-name{
  display:flex; align-items:center; gap:8px;
  font-size:18px; font-weight:700; letter-spacing:-.02em;
  color:var(--bone);
}
.footer-brand-name svg{
  width:14px; height:14px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #7B8FF7 0%, var(--oasis) 60%, #3B45D9 100%);
}
.footer-brand-name svg circle, .footer-brand-name svg defs{ display:none;}
.footer-brand-name .dot{ color:var(--oasis);}
.footer-tagline{ font-size:13px; color:var(--ink-mute);}
.footer-desc{ font-size:13px; color:var(--ink-soft); max-width:280px;}

.footer-col h4{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:16px; font-weight:500;
}
[dir="rtl"] .footer-col h4{ font-family:'Noto Kufi Arabic',sans-serif; letter-spacing:.06em; text-transform:none;}
.footer-col a{
  display:block; font-size:14px; color:var(--ink-mute);
  padding:6px 0;
  transition:color .25s, transform .3s var(--ease);
}
.footer-col a:hover{ color:var(--bone); transform:translateX(3px);}
[dir="rtl"] .footer-col a:hover{ transform:translateX(-3px);}

.footer-bottom{
  max-width:1280px; margin:64px auto 0; padding:24px 56px 0;
  border-top:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  flex-wrap:wrap;
  font-size:12px; color:var(--ink-soft);
}
.footer-legal{ display:flex; gap:16px;}
.footer-legal a{ color:var(--ink-soft); transition:color .25s;}
.footer-legal a:hover{ color:var(--bone);}
.footer-social{ display:flex; gap:8px;}
.social-link{
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink-mute);
  transition:transform .35s var(--ease), background .25s, color .25s, border-color .25s;
}
.social-link:hover{ transform:translateY(-2px); background:var(--oasis); color:var(--night); border-color:var(--oasis);}

/* ═══ WhatsApp FAB ═══ */
.whatsapp-fab{
  position:fixed; bottom:24px;
  inset-inline-end:24px;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.55);
  z-index:60;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.whatsapp-fab:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 22px 40px -10px rgba(37,211,102,.6);}

/* ═══ Animations ═══ */
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(24px);}
  to{ opacity:1; transform:translateY(0);}
}
[data-animate="fade-up"]{ animation:fadeUp 1.1s var(--ease-out) both;}
[data-animate="fade-up"][data-delay="0.1"]{ animation-delay:.1s;}
[data-animate="fade-up"][data-delay="0.2"]{ animation-delay:.2s;}
[data-animate="fade-up"][data-delay="0.3"]{ animation-delay:.35s;}
[data-animate="fade-up"][data-delay="0.4"]{ animation-delay:.5s;}

/* ═══ Reduced motion ═══ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  [data-animate]{ opacity:1!important; transform:none!important;}
}

/* ═══ Responsive ═══ */
@media (max-width:1100px){
  .container{ padding:0 32px;}
  .footer-inner{ grid-template-columns:1fr 1fr; padding:0 32px;}
  .footer-bottom{ padding:24px 32px 0;}
}
@media (max-width:820px){
  .blog-post-content{ font-size:17px; line-height:1.75;}
  [dir="rtl"] .blog-post-content{ font-size:17px;}
}
@media (max-width:820px){
  .site-nav-wrap{ padding:0 8px;}
  .site-nav{ padding:5px 6px 5px 10px !important; gap:2px; flex-wrap:nowrap; width:100%; max-width:none;}
  .site-nav .nav-brand{ flex-shrink:0;}
  .site-nav .nav-logo-img{ height:13px;}
  .site-nav .nav-links{ display:flex !important; flex-shrink:1; flex-grow:1; justify-content:space-around; align-items:center; gap:0; min-width:0; padding:0 2px;}
  .site-nav .nav-links a{ font-size:10.5px !important; padding:6px 3px !important; white-space:nowrap; letter-spacing:-.01em;}
  .site-nav .nav-cta{ flex-shrink:0; padding:6px 10px !important; font-size:10.5px !important; gap:0 !important;}
  .site-nav .nav-cta svg{ display:none;}
  .nav-burger{ display:none !important;}
  .nav-mobile{ display:none !important;}
}
@media (max-width:720px){
  .container{ padding:0 18px;}
  .blog-post-hero{ padding:120px 0 0;}
  .blog-post-image{ margin:32px auto 0;}
  .blog-post-content blockquote{ padding:18px 22px; font-size:18px;}
  .blog-post-content table{ font-size:14px;}
  .blog-post-content th, .blog-post-content td{ padding:10px 12px;}
  .cta-card{ padding:48px 22px; margin:48px 18px 0;}
  .footer-inner{ grid-template-columns:1fr; padding:0 18px; gap:32px;}
  .footer-bottom{ padding:24px 18px 0; flex-direction:column; align-items:flex-start;}
}
@media (max-width:380px){
  .site-nav-wrap{ padding:0 6px;}
  .site-nav{ padding:4px 5px 4px 8px !important; gap:0;}
  .site-nav .nav-logo-img{ height:12px;}
  .site-nav .nav-links a{ font-size:9.5px !important; padding:5px 2px !important;}
  .site-nav .nav-cta{ font-size:10px !important; padding:5px 8px !important;}
}
