/* ==========================================================================
   ROOT
   ========================================================================== */
:root{
  --bg:#041a15;
  --bg-deep:#02110d;
  --text:#f7f1e8;
  --muted:rgba(255,255,255,.82);
  --gold:#d8c29c;
  --line:rgba(255,255,255,.12);
  --shadow:none;
  --nav-h:92px;
  --chapter-h:72px;
  --speed:8000ms;
  --button:#efe7dc;
  --transition-smooth:all .35s cubic-bezier(.4,0,.2,1);
}

*{
  box-sizing:border-box;
  min-width:0;
}

html,body{
  margin:0 !important;
  padding:0 !important;
  width:100%;
  font-family:"Cinzel", serif;
	color: #000!important;
}

html{
    scroll-behavior: smooth;
    font-style: normal;
    font-weight: 200;	color: #000!important;
}

body{
	overflow-x: clip;overflow-x: clip;
  font-family:"Cinzel", serif;
  background:#fff !important;
  color:var(--text);
  overflow-x:clip;	color: #000!important;
}

img,
svg,
video,
canvas,
iframe{
  display:block;
  max-width:100%;
  height:auto;
}

a{
  text-decoration:none;
  color:inherit;
}

button{
  font:inherit;
  cursor:pointer;
}

h1,h2,h3,h4,h5{
  font-family:"Cinzel", serif;
  letter-spacing:.03em;
}

.site-header + *{
  scroll-margin-top:var(--nav-h);
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  z-index:2000;
  background:#031d12;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:var(--transition-smooth);
  margin-bottom:0;
}

.site-header.scrolled{
  background:#041a15;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:none;
}

.nav-shell{
  width:min(1320px,calc(100% - 40px))!important;
  margin:0 auto;
  min-height:var(--nav-h);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.brand{
  justify-self:start;
  display:flex;
  align-items:center;
  line-height:0;
}

.brand img{
  height:92px !important;
  width:auto !important;
  object-fit:contain;
  margin-top:0;
  padding-bottom:0;
  max-width:min(42vw,220px);
}

.nav-menu{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:22px;
  color:rgba(255,255,255,.82);
  font-size:.95rem;
  min-width:0;
  flex-wrap:wrap;
}

.nav-menu a{
  position:relative;
  transition:color .3s ease;
}

.nav-menu a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:100%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0);
  transform-origin:right;
  transition:transform .32s ease;
}

.nav-menu a:hover::after{
  transform:scaleX(1);
  transform-origin:left;
}

.instagram-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  height:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  transition:transform .25s ease,opacity .25s ease;
  flex:0 0 auto;
}

.instagram-link:hover{
  transform:translateY(-1px);
  opacity:.85;
}

.instagram-link::after{
  display:none;
}

.instagram-link svg{
  width:22px;
  height:22px;
  fill:none;
  stroke:#fff;
  stroke-width:1.7;
}

.instagram-link .fill-dot{
  fill:#fff;
  stroke:none;
}

.hamburger{
  display:none;
  justify-self:end;
  width:48px;
  height:48px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.05);
  position:relative;
  z-index:2100;
}

.hamburger span{
  position:absolute;
  left:50%;
  width:20px;
  height:1.5px;
  background:#fff;
  transform:translateX(-50%);
  transition:.35s ease;
}

.hamburger span:nth-child(1){top:16px}
.hamburger span:nth-child(2){top:23px}
.hamburger span:nth-child(3){top:30px}

.hamburger.active span:nth-child(1){
  top:23px;
  transform:translateX(-50%) rotate(45deg);
}

.hamburger.active span:nth-child(2){
  opacity:0;
}

.hamburger.active span:nth-child(3){
  top:23px;
  transform:translateX(-50%) rotate(-45deg);
}

/* ==========================================================================
   HERO SLIDER
   ========================================================================== */
.hero{
  position:relative;
  width:100%;
  height:100svh;
  min-height:100vh;
  padding-top:var(--nav-h);
  overflow:hidden;
}

.hero-slider{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

.chapter-title{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:var(--chapter-h);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 24px;
  margin:0;
  z-index:7;
  text-align:center;
  background:linear-gradient(180deg,rgba(16,54,41,.96),rgba(9,34,25,.96));
  box-shadow:none;
  font-family:"Cinzel", serif;
  font-size:clamp(1.1rem,1.8vw,1.9rem);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fff;
}

.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:scale(1.02);
  transition:opacity 1.2s ease,transform 1.4s ease,visibility 1.2s ease;
}

.hero-slide.active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:scale(1);
  z-index:2;
}

.hero-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
  transform:scale(1.08);
  transition:transform 8.5s ease;
}

.hero-slide.active .hero-img{
  transform:scale(1.02);
}

.hero-film{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(180deg,rgba(4,12,9,.10) 0%,rgba(4,12,9,.08) 26%,rgba(4,12,9,.34) 100%),
    radial-gradient(circle at center,rgba(255,255,255,.03),rgba(0,0,0,.28) 72%);
}

.hero-inner{
  position:relative;
  z-index:6;
  width:min(100%,1440px);
  height:100%;
  margin:0 auto;
  padding:calc(var(--chapter-h) + 32px) 32px 90px;
  display:flex;
  align-items:flex-end;
}

.tasks{
  display:grid;
  gap:26px;
  width:100%;
}

.tasks-vertical{
  max-width:900px;
  grid-template-columns:1fr;
}

.tasks-horizontal{
  max-width:100%;
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.task{
  max-width:none;
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
  opacity:0;
  transform:translateY(30px);
  transition:opacity .95s ease,transform 1.1s ease;
}

.hero-slide.active .task{
  opacity:1;
  transform:translateY(0);
}

.hero-slide.active .task:nth-child(2){
  transition-delay:.16s;
}

.eyebrow{
  margin:0 0 10px;
  font-family:'Cinzel', serif;
  font-size:clamp(.72rem,.9vw,.88rem);
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.88);
}

.task h2{
    margin: 0 0 12px;
    font-weight: 500;
    font-size: clamp(2rem,3.2vw,4.3rem);
    line-height: .92;
    letter-spacing: .02em;
    text-shadow: none;
    color: #fff;
    text-transform: uppercase !important;
}

.task p{
  margin:0 0 18px;
  max-width:52ch;
  font-family:'Cinzel', serif;
  font-size:clamp(.9rem,1vw,1rem);
  line-height:1.6;
  color:var(--muted);
  text-shadow:none;
}

.task-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:132px;
  min-height:44px;
  padding:0 22px;
  border-radius:999px;
  border:1px solid transparent;
  background:var(--button);
  color:#112219;
  text-decoration:none;
  font-family:'Cinzel', serif;
  font-size:.84rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  transition:all .3s ease;
}

.task-btn:hover{
  transform:translateY(-1px);
  background:#fff;
}

.task-btn.ghost{
  background:transparent;
  border-color:rgba(255,255,255,.48);
  color:#fff;
}

.task-btn.ghost:hover{
  background:var(--button);
  color:#112219;
  border-color:var(--button);
}

.slider-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:46px;
  height:46px;
  border:none;
  border-radius:50%;
  background:rgba(8,20,15,.36);
  color:#fff;
  display:grid;
  place-items:center;
  z-index:8;
  cursor:pointer;
  backdrop-filter:none;
  box-shadow:none;
  border:1px solid rgba(255,255,255,.18);
  transition:all .28s ease;
}

.slider-arrow:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.32);
}

.slider-arrow span{
  display:block;
  font-size:1rem;
  line-height:1;
  transform:translateY(-1px);
}

.slider-arrow.prev{
  left:22px;
}

.slider-arrow.next{
  right:22px;
}

.slider-bottom{
  position:absolute;
  left:50%;
  bottom:26px;
  transform:translateX(-50%);
  width:min(92vw,1360px);
  z-index:8;
  display:flex;
  align-items:center;
  gap:16px;
}

.slider-dots{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:none;
  background:rgba(255,255,255,.35);
  padding:0;
  cursor:pointer;
  transition:all .28s ease;
}

.dot.active{
  width:34px;
  background:#f4efe7;
}

.slider-progress{
  flex:1;
  height:3px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.18);
  min-width:0;
}

.slider-progress span{
  display:block;
  width:0%;
  height:100%;
  background:linear-gradient(90deg,#f3ece1,#cdb892);
  animation:progress var(--speed) linear forwards;
}

@keyframes progress{
  from{width:0%}
  to{width:100%}
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:900px){
  :root{
    --nav-h:78px;
    --chapter-h:58px;
  }

  .nav-shell{
    grid-template-columns:1fr auto;
    width:min(100%,calc(100% - 28px));
    gap:12px;
  }

  .brand{
    justify-self:center;
    grid-column:1 / -1;
    grid-row:1;
    text-align:center;
    padding-top:10px;
  }

  .brand img{
    height:72px;
    margin-top:0;
    max-width:180px;
  }

  .hamburger{
    display:inline-flex;
    justify-self:end;
    grid-column:2;
    grid-row:1;
    margin-top:0;
  }

  .nav-menu{
    position:fixed;
    top:calc(var(--nav-h) + 8px);
    left:14px;
    right:14px;
    flex-direction:column;
    align-items:flex-start;
    gap:18px;
    padding:18px;
    background:#041a15;
    border:1px solid rgba(255,255,255,.08);
    border-radius:24px;
    opacity:0;
    pointer-events:none;
    transform:translateY(-10px);
    transition:var(--transition-smooth);
    z-index:2050;
    max-height:calc(100svh - var(--nav-h) - 24px);
    overflow:auto;
  }

  .nav-menu.open{
    opacity:1;
    pointer-events:auto;
    transform:translateY(0);
  }

  .hero{
    height:100svh;
    min-height:100vh;
    padding-top:var(--nav-h);
  }

  .chapter-title{
    height:var(--chapter-h);
    padding:0 16px;
    font-size:clamp(.9rem,4vw,1.2rem);
    letter-spacing:.08em;
  }

  .hero-inner{
    width:100%;
    padding:calc(var(--chapter-h) + 24px) 18px 110px;
  }

  .tasks-vertical,
  .tasks-horizontal{
    max-width:none;
    grid-template-columns:1fr;
  }

  .task h2{
    font-size:2rem;
  }

  .slider-arrow{
    top:auto;
    bottom:26px;
    transform:none;
    width:42px;
    height:42px;
  }

  .slider-arrow.prev{left:14px}
  .slider-arrow.next{right:14px}

  .slider-bottom{
    width:min(94vw,760px);
    bottom:34px;
    padding:0 58px;
  }

  .footer-container{
    width:min(100%,calc(100% - 28px));
  }
}

@media (max-width:768px){
  .footer-container{
    padding-left:24px;
    padding-right:24px;
  }

  .footer-row{
    row-gap:24px;
  }

  .footer-right{
    justify-content:flex-start;
    text-align:left;
    margin-top:16px;
  }

  .logos-list{
    align-items:flex-start;
    gap:12px;
  }

  .footer-text{
    max-width:100%;
    font-size:20px;
  }

  .footer-emails a{
    font-size:20px;
  }

  .logos img{
    height:32px;
  }
}

@media (max-width:640px){
  .nav-shell,
  .footer-container{
    width:min(100%,calc(100% - 22px));
  }

  .brand{
    width:100%;
    justify-content:center;
    text-align:center;
  }

  .brand img{
    height:56px;
    max-width:150px;
  }

  .slider-arrow{
    width:38px;
    height:38px;
    font-size:1.7rem;
    top:auto;
    bottom:22px;
    transform:none;
  }

  .slider-arrow:hover{
    transform:scale(1.04);
  }

  .slider-arrow.prev{left:12px}
  .slider-arrow.next{right:12px}

  .slider-bottom{
    bottom:24px;
    gap:8px;
  }

  .slider-dots{
    max-width:170px;
  }

  .dot{
    width:8px;
    height:8px;
  }

  .slider-progress{
    width:110px;
  }

  .site-footer{
    padding:22px 0 16px;
  }

  .footer-text{
    font-size:.74rem;
    line-height:1.5;
  }

  .footer-emails a{
    font-size:.73rem;
  }

  .logos-title{
    font-size:.88rem;
    margin-bottom:6px;
  }

  .logos-list{
    font-size:.68rem;
    gap:8px;
  }

  .logos img{
    height:26px;
  }
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{
  position:relative;
  z-index:5;
  padding:60px 0 30px;
  border-top:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(circle at top,rgba(216,194,156,.08),transparent 32%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-deep) 100%);
}

.footer-container{
    max-width: 1320px;
    margin: auto;
    padding-left: 24px;
    padding-right: 24px;
    padding-top: 10px;
}

.footer-row{
  align-items:flex-start;
  row-gap:28px;
}

.footer-left{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.footer-text{
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: rgba(255,255,255,.78);
    /* [disabled]max-width: 582px; */
}

.footer-emails{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.footer-emails a{
    color: #f4efe4;
    font-size: 18px;
    overflow-wrap: anywhere;
}

.footer-right{
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
}

.logos-title{
  font-family:"Cinzel", serif;
  font-size:1rem;
  margin-bottom:10px;
  color:#f6ebd4;
}

.logos-list{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
  color:rgba(255,255,255,.78);
  font-size:20px;
}

.logos{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.logos img{
  height:40px;
  width:auto;
  object-fit:contain;
}

.footer-signature-text{
  text-align:center !important;
	color: white!important;
	font-size: 14px;
}

.footer-signature-text a{
  color:#fff !important;
  text-decoration:none;
}

.footer-signature-text a:hover{
  text-decoration:underline;
}

/* ==========================================================================
   REVEAL
   ========================================================================== */
.reveal{
  opacity:0;
  transform:translateY(30px) scale(.985);
  transition:opacity 1s ease,transform 1s ease;
}

.reveal.in-view{
  opacity:1;
  transform:translateY(0) scale(1);
}

/* ==========================================================================
   FINAL SITE FIXES
   ========================================================================== */
html, body {
  overflow-x: clip;
}

body {
  width: 100%;
}

.site-header,
.hero,
.page-main,
.page-section,
.site-footer {
  max-width: 100%;
}

.site-footer {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.site-footer .footer-container,
.site-footer .footer-row {
  width: 100%;
  max-width: 1320px;
  margin-inline: auto;
}

.site-footer .footer-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;
}

.site-footer .footer-left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
  min-width: 0;
  flex: 1 1 360px;
}

.site-footer .footer-right {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  text-align: right;
  min-width: 0;
  flex: 1 1 280px;
}

.site-footer .logos-list {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-start;
  min-width: 0;
  width: 100%;
}

.site-footer .logos {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
}

.site-footer .footer-text,
.site-footer .footer-note,
.site-footer .footer-emails,
.site-footer .footer-emails a,
.site-footer .logos-title {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
	font-size: 14px;
}

@media (max-width: 991.98px) {
  .site-footer .footer-row {
    gap: 22px;
  }
}

@media (max-width: 767.98px) {
  .site-footer .footer-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-footer .footer-left,
  .site-footer .footer-right,
  .site-footer .logos-list,
  .site-footer .logos {
    align-items: flex-start;
    justify-content: flex-start;
    text-align: left;
  }
}

.site-nav a {
  position: relative;
  display: inline-block;
}

.site-nav a.active {
  opacity: 1 !important;
}

.site-nav a.active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background: currentColor;
  opacity: 1 !important;
}

.site-header,
.site-nav,
.site-nav ul,
.site-nav li {
  overflow: visible;
}



.cards-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr)!important;
  gap: 20px;
  margin-bottom: 20px;
}

.service-card {
  background: #f5f5f5;
  border-radius: 10px;
  overflow: hidden;
}

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

/* كارت النص */
.text-card {
  background: #fff;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.text-card h3 {
  margin-bottom: 10px;
}

.text-card p {
  color: #555;
}.card-title {
  padding: 12px;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.card-img-top {
  height: 350px;
  object-fit: cover;
}

.primary-btn,
.outline-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 178px;
  min-height: 56px;
  padding: 12px 24px;
  border-radius: 0;
  font-size: 1.06rem;
  transition: transform .28s ease, box-shadow .28s ease, background-color .28s ease;
}
.primary-btn {
  background: var(--cts-green-2)!important;
  border: 1px solid var(--cts-green-2);
  color: #fff;
}
.outline-btn {
  background: transparent;
  border: 2px solid var(--cts-green-2);
  color: var(--cts-green);
}
.primary-btn:hover,
.outline-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(4,26,21,.14);
}
.section{
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-top: 80px;
    padding-right: 0px;
    padding-left: 0px;
    padding-bottom: 80px
}
.dark{
    background: #022f26;
    color: #fff;
    margin-right: 0px!important;
    margin-left: 0px!important;
    right: 0px!important;
    left: 0px!important;
}
.container{max-width:1400px}
.title{
    font-size: 40px;
    line-height: 1.1;
    margin-bottom: 30px
}
.text{font-size:18px;line-height:1.6;max-width:800px}
.small{letter-spacing:2px;text-transform:uppercase;margin-bottom:20px}
.center{text-align:center}
.nospace {
    margin: 0;
    width: 100%;
    right: 0px;
    left: 0px;
}

/* === Bootstrap standalone compatibility === */
body.standalone-page {
  font-family: 'Montserrat', sans-serif !important;
  background: var(--cts-light, #f3f3f1) !important;
  color: var(--cts-ink, #203127) !important;
}

body.standalone-page .container,
body.standalone-page .container-fluid {
  --bs-gutter-x: 1.5rem;
}

body.standalone-page a {
  color: inherit;
  text-decoration: none;
}

body.standalone-page .primary-btn,
body.standalone-page .outline-btn {
  border-radius: 0 !important;
}


body{font-family:'Montserrat', sans-serif !important;}
h1,h2,h3,h4,h5{font-family:'Cinzel', serif !important;}


/* === FINAL FONT RULES === */

/* Titles */
.page-title,
.section-title,
.service-title,
.services-title{
  font-family:'Cinzel', serif !important;
  font-weight:400 !important;
}

/* Paragraphs */
p,
.service-copy,
.body-copy p{
    font-family: 'Montserrat', sans-serif !important;
    /* [disabled]font-weight:400 !important; */
}

/* Header / nav */
.nav-menu a,
.site-header,
.nav-menu{
  font-family:'Montserrat', sans-serif !important;
  font-weight:400 !important;
}


/* hard fix font safety */
body{font-family:'Montserrat', sans-serif !important;}
h1,h2,h3,h4,h5{font-family:'Cinzel', serif !important; font-weight:400 !important;}
.nav-menu,.nav-menu a,.site-header{font-family:'Montserrat', sans-serif !important; font-weight:400 !important;}
