/*
Theme Name: Nile Contracting
Theme URI: https://nilecontracting.com
Author: Nile Contracting Co.
Author URI: https://nilecontracting.com
Description: قالب وردبريس مخصص لشركة النيل للمقاولات. تصميم بهوية "المخطط الهندسي" — خلفية بيضاء مكسورة ولمسات ذهبية نحاسية. كل الأقسام قابلة للتحكم الكامل عبر Appearance > Customize.
Version: 1.0.0
Requires at least: 5.8
Requires PHP: 7.4
Tested up to: 6.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: nile-contracting
Tags: business, custom-colors, custom-logo, custom-menu, featured-images, rtl-language-support, translation-ready
*/

/* ====================================================================
   1) METRICS VARIABLES — متغيرات الألوان الأساسية
   تُحدَّث ديناميكيًا من Customizer عبر inc/customizer-output.php
   القيم هنا هي الافتراضية (Defaults) فقط
   ==================================================================== */
:root{
  --nile-ink:#F8F6F1;        /* الخلفية الأساسية */
  --nile-panel:#F0ECE3;      /* خلفية الأقسام البديلة */
  --nile-panel-2:#E6E1D5;    /* خلفية البطاقات/الصور placeholder */
  --nile-line:#D8D2C2;       /* الحدود والخطوط */
  --nile-line-soft:#E1DCD0;  /* شبكة البلوبرنت بالخلفية */
  --nile-paper:#211D16;      /* النص الأساسي الغامق */
  --nile-paper-dim:#6B6457;  /* النص الثانوي */
  --nile-copper:#A87E2C;     /* الذهبي النحاسي — اللون المميز */
  --nile-copper-bright:#C2962F;
  --nile-copper-dim:#8C6A24;
  --nile-ok:#4F7A5E;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--nile-ink);
  color:var(--nile-paper);
  font-family:'IBM Plex Sans Arabic', 'Tajawal', sans-serif;
  font-weight:400;
  overflow-x:hidden;
}
body.lang-en, body[data-lang="en"]{
  font-family:'Inter', 'Archivo', sans-serif;
}
.nile-en{
  font-family:'Archivo', sans-serif;
  direction:ltr;
  unicode-bidi:isolate;
}
.nile-mono{
  font-family:'JetBrains Mono', monospace;
  direction:ltr;
  unicode-bidi:isolate;
}
img{max-width:100%; display:block;}
a{color:inherit;}
button{font-family:inherit; cursor:pointer;}

::selection{background:var(--nile-copper);color:#FFFFFF;}

/* ===== Blueprint grid texture (signature background) ===== */
.nile-blueprint-bg{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    linear-gradient(var(--nile-line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--nile-line-soft) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:.5;
  mask-image:linear-gradient(to bottom, black, transparent 85%);
}

/* ===== Scroll reveal ===== */
.nile-reveal{opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease;}
.nile-reveal.is-visible{opacity:1; transform:translateY(0);}

/* Skip link (accessibility) */
.skip-link{
  position:absolute; top:-100px; left:0;
  background:var(--nile-copper); color:#fff;
  padding:10px 18px; z-index:9999;
}
.skip-link:focus{top:0;}

/* ====================================================================
   2) TOP BAR / HEADER
   ==================================================================== */
.nile-topbar{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 48px;
  background:rgba(248,246,241,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--nile-line);
  transition:padding .3s ease;
}
.nile-topbar.is-scrolled{padding:12px 48px;}

.nile-brand{display:flex; align-items:center; gap:12px; text-decoration:none;}
.nile-brand-mark{width:34px; height:34px; position:relative;}
.nile-brand-mark svg{width:100%; height:100%;}
.nile-brand-text{display:flex; flex-direction:column; line-height:1;}
.nile-brand-text .ar{font-size:18px; font-weight:700; color:var(--nile-paper); letter-spacing:.5px;}
.nile-brand-text .ltr{font-size:9px; letter-spacing:3px; color:var(--nile-copper); margin-top:3px;}

.nile-nav{display:flex; align-items:center; gap:34px;}
.nile-nav ul{display:flex; gap:34px; list-style:none;}
.nile-nav a{
  color:var(--nile-paper-dim);
  text-decoration:none;
  font-size:14.5px;
  font-weight:500;
  position:relative;
  padding:6px 0;
  transition:color .25s ease;
}
.nile-nav a::after{
  content:'';
  position:absolute;
  bottom:0; right:0;
  width:0; height:1px;
  background:var(--nile-copper);
  transition:width .3s ease;
}
.nile-nav a:hover{color:var(--nile-paper);}
.nile-nav a:hover::after{width:100%;}

.nile-lang-cta{display:flex; align-items:center; gap:18px;}
.nile-lang-switch{
  display:flex;
  border:1px solid var(--nile-line);
  border-radius:30px;
  overflow:hidden;
  font-size:12px;
  background:none;
  padding:0;
}
.nile-lang-switch button{
  padding:6px 14px;
  cursor:pointer;
  color:var(--nile-paper-dim);
  font-family:'JetBrains Mono', monospace;
  letter-spacing:1px;
  background:transparent;
  border:none;
}
.nile-lang-switch button.is-active{background:var(--nile-copper); color:#fff; font-weight:600;}

.btn-nile-primary{
  background:var(--nile-copper);
  color:#FFFFFF;
  padding:10px 24px;
  border-radius:3px;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  border:1px solid var(--nile-copper);
  transition:all .25s ease;
  white-space:nowrap;
  display:inline-block;
}
.btn-nile-primary:hover{background:transparent; color:var(--nile-copper);}

.btn-nile-ghost{
  border:1px solid var(--nile-line);
  color:var(--nile-paper);
  padding:10px 24px;
  border-radius:3px;
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  transition:all .25s ease;
  white-space:nowrap;
  display:inline-block;
  background:transparent;
}
.btn-nile-ghost:hover{border-color:var(--nile-copper); color:var(--nile-copper);}

.nile-burger{display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:60; background:none; border:none; padding:8px;}
.nile-burger span{width:24px; height:2px; background:var(--nile-paper); display:block;}

.nile-mobile-nav{
  position:fixed; inset:0; z-index:55;
  background:var(--nile-ink);
  display:flex; flex-direction:column;
  padding:100px 32px 40px;
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
  overflow-y:auto;
}
.nile-mobile-nav.is-open{transform:translateX(0);}
.nile-mobile-nav ul{list-style:none;}
.nile-mobile-nav a{
  color:var(--nile-paper);
  text-decoration:none;
  font-size:22px;
  font-weight:600;
  padding:16px 0;
  border-bottom:1px solid var(--nile-line);
  display:block;
}

/* ====================================================================
   3) HERO SECTION
   ==================================================================== */
.nile-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:140px 48px 80px;
  z-index:1;
}
.nile-hero-split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:64px;
  align-items:center;
}

/* moving brand name strip — above headline */
.nile-hero-name-strip{
  position:relative;
  height:64px;
  margin-bottom:18px;
  overflow:hidden;
}
.nile-hero-name-strip .nile-marquee-track{
  display:flex;
  align-items:center;
  height:100%;
  white-space:nowrap;
  direction:ltr;
  animation:nileMarquee 7s linear infinite;
}
.nile-hero-name-strip .nile-marquee-track span{
  font-family:'IBM Plex Sans Arabic', sans-serif;
  font-weight:700;
  font-size:clamp(26px, 3.4vw, 38px);
  color:var(--nile-paper);
  letter-spacing:.5px;
  white-space:nowrap;
}
@keyframes nileMarquee{
  0%{transform:translateX(100%);}
  100%{transform:translateX(-100%);}
}

.nile-hero-eyebrow{display:flex; align-items:center; gap:14px; margin-bottom:28px;}
.nile-hero-eyebrow .nile-dim-line{width:48px; height:1px; background:var(--nile-copper);}
.nile-hero-eyebrow span{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  letter-spacing:3px;
  color:var(--nile-copper);
  text-transform:uppercase;
}

.nile-hero-title{
  font-size:clamp(32px, 4.6vw, 60px);
  font-weight:700;
  line-height:1.18;
  color:var(--nile-paper);
  letter-spacing:-.5px;
}
.nile-hero-title .accent{color:var(--nile-copper);}

.nile-hero-sub{
  margin-top:32px;
  font-size:clamp(15px, 1.4vw, 18px);
  color:var(--nile-paper-dim);
  max-width:560px;
  line-height:1.85;
  font-weight:300;
}
.nile-hero-cta-row{display:flex; gap:18px; margin-top:48px; flex-wrap:wrap;}

.nile-hero-visual{
  position:relative;
  aspect-ratio:4/5;
  border:1px solid var(--nile-line);
  border-radius:4px;
  background:
    repeating-linear-gradient(45deg, var(--nile-panel-2) 0 2px, transparent 2px 18px),
    var(--nile-panel-2);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.nile-hero-visual img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.nile-placeholder-label{
  position:relative; z-index:2;
  font-family:'JetBrains Mono', monospace;
  font-size:12px; color:var(--nile-paper-dim);
  letter-spacing:1px; background:var(--nile-ink);
  padding:8px 18px; border:1px dashed var(--nile-line);
  border-radius:30px;
}
.nile-corner-tag{
  position:absolute; top:16px; right:16px;
  font-family:'JetBrains Mono', monospace; font-size:10px;
  letter-spacing:1px; color:var(--nile-copper);
  border:1px solid var(--nile-line); padding:5px 12px;
  border-radius:30px; background:var(--nile-ink); z-index:2;
}

/* dimension line stats */
.nile-dim-track{margin-top:90px; border-top:1px solid var(--nile-line);}
.nile-dim-stats{display:grid; grid-template-columns:repeat(4,1fr);}
.nile-dim-stat{position:relative; padding:28px 28px 0; border-right:1px solid var(--nile-line);}
.nile-dim-stat:first-child{padding-right:0;}
.nile-dim-stat:last-child{border-right:none;}
.nile-dim-stat::before{
  content:''; position:absolute; top:-1px; right:0;
  width:0; height:2px; background:var(--nile-copper);
  transition:width 1.2s cubic-bezier(.16,1,.3,1);
}
.nile-dim-stat.is-active::before{width:100%;}
.nile-dim-stat .num{
  font-family:'JetBrains Mono', monospace;
  font-size:clamp(28px,3.2vw,42px); font-weight:600; color:var(--nile-paper);
  display:flex; align-items:baseline; gap:4px;
}
.nile-dim-stat .num .unit{font-size:18px; color:var(--nile-copper);}
.nile-dim-stat .label{margin-top:8px; font-size:13px; color:var(--nile-paper-dim); line-height:1.5;}

.nile-scroll-hint{
  position:absolute; bottom:36px; left:48px;
  display:flex; align-items:center; gap:10px;
  color:var(--nile-paper-dim); font-size:12px;
  font-family:'JetBrains Mono', monospace; letter-spacing:1px;
}
.nile-scroll-hint .line{width:1px; height:34px; background:var(--nile-line); position:relative; overflow:hidden;}
.nile-scroll-hint .line::after{
  content:''; position:absolute; top:0; left:0; width:100%; height:10px;
  background:var(--nile-copper); animation:nileScrollMove 1.8s ease-in-out infinite;
}
@keyframes nileScrollMove{0%{top:-10px;} 100%{top:34px;}}

/* ====================================================================
   4) SECTION SHARED STYLES
   ==================================================================== */
.nile-section{position:relative; z-index:1; padding:140px 48px;}
.nile-section-tight{padding:90px 48px;}
.nile-section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:72px; flex-wrap:wrap;}
.nile-eyebrow{
  font-family:'JetBrains Mono', monospace; font-size:13px; letter-spacing:3px;
  color:var(--nile-copper); text-transform:uppercase;
  display:flex; align-items:center; gap:12px; margin-bottom:18px;
}
.nile-eyebrow .nile-dim-line{width:32px; height:1px; background:var(--nile-copper);}
.nile-section-title{font-size:clamp(30px,4vw,52px); font-weight:700; line-height:1.15; max-width:680px; letter-spacing:-.5px;}
.nile-section-desc{max-width:380px; color:var(--nile-paper-dim); font-size:15.5px; line-height:1.8; font-weight:300;}
.nile-bg-alt{background:var(--nile-panel);}

/* ====================================================================
   5) SERVICES SECTION
   ==================================================================== */
.nile-services-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--nile-line); border:1px solid var(--nile-line);}
.nile-service-card{background:var(--nile-ink); padding:0; position:relative; transition:background .35s ease; display:flex; flex-direction:column;}
.nile-service-card:hover{background:var(--nile-panel-2);}
.nile-service-thumb{
  height:170px;
  background:repeating-linear-gradient(45deg, var(--nile-panel-2) 0 2px, transparent 2px 18px), var(--nile-panel-2);
  position:relative; display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid var(--nile-line); overflow:hidden;
}
.nile-service-thumb img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.nile-service-body{padding:28px 28px 32px; display:flex; flex-direction:column; flex-grow:1;}
.nile-service-num{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--nile-copper-dim); margin-bottom:14px;}
.nile-service-card h3{font-size:18px; font-weight:600; margin-bottom:10px; color:var(--nile-paper);}
.nile-service-card p{font-size:13.5px; color:var(--nile-paper-dim); line-height:1.75; font-weight:300; flex-grow:1;}
.nile-service-tag{margin-top:18px; font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--nile-copper); letter-spacing:1px;}

/* ====================================================================
   6) TRUST / WHY US SECTION
   ==================================================================== */
.nile-trust-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--nile-line); border:1px solid var(--nile-line);}
.nile-trust-card{background:var(--nile-ink); padding:36px 26px; text-align:center;}
.nile-trust-card .icon{margin:0 auto 18px; color:var(--nile-copper);}
.nile-trust-card h4{font-size:15px; font-weight:600; margin-bottom:8px;}
.nile-trust-card p{font-size:12.5px; color:var(--nile-paper-dim); line-height:1.6; font-weight:300;}

/* ====================================================================
   7) GROWTH CHART SECTION
   ==================================================================== */
.nile-growth-wrap{display:grid; grid-template-columns:1fr 1.3fr; gap:80px; align-items:center;}
.nile-growth-chart{position:relative; height:340px; display:flex; align-items:flex-end; gap:28px; padding-bottom:40px; border-bottom:1px solid var(--nile-line);}
.nile-growth-bar-col{flex:1; display:flex; flex-direction:column; align-items:center; height:100%; justify-content:flex-end;}
.nile-growth-bar{width:100%; background:linear-gradient(180deg, var(--nile-copper-bright), var(--nile-copper-dim)); position:relative; height:0; transition:height 1.4s cubic-bezier(.16,1,.3,1); border-radius:2px 2px 0 0;}
.nile-growth-bar .val{position:absolute; top:-28px; left:0; right:0; text-align:center; font-family:'JetBrains Mono', monospace; font-size:13px; color:var(--nile-paper); font-weight:500; opacity:0; transition:opacity .6s ease 1.1s;}
.nile-growth-bar.is-active .val{opacity:1;}
.nile-growth-year{margin-top:14px; font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--nile-paper-dim);}
.nile-growth-note{margin-top:24px; font-size:13px; color:var(--nile-paper-dim); font-family:'JetBrains Mono', monospace;}
.nile-growth-text h3{font-size:clamp(26px,3vw,38px); font-weight:700; line-height:1.3; margin-bottom:24px;}
.nile-growth-text p{color:var(--nile-paper-dim); line-height:1.9; font-size:15.5px; font-weight:300; margin-bottom:18px;}
.nile-growth-pillrow{display:flex; gap:14px; margin-top:28px; flex-wrap:wrap;}
.nile-growth-pill{border:1px solid var(--nile-line); padding:8px 16px; border-radius:30px; font-size:13px; color:var(--nile-paper); display:flex; align-items:center; gap:8px;}
.nile-growth-pill .dot{width:6px; height:6px; border-radius:50%; background:var(--nile-copper);}

/* ====================================================================
   8) TEAM / CONSULTANTS CAROUSEL
   ==================================================================== */
.nile-team-carousel{position:relative; overflow:hidden;}
.nile-team-track{display:flex; gap:24px; transition:transform .5s cubic-bezier(.16,1,.3,1);}
.consultant-card{
  background:var(--nile-panel); border:1px solid var(--nile-line); border-radius:4px;
  flex:0 0 calc(25% - 18px); min-width:240px; overflow:hidden;
}
.consultant-image{
  aspect-ratio:1/1; position:relative; overflow:hidden;
  background:repeating-linear-gradient(45deg, var(--nile-panel-2) 0 2px, transparent 2px 18px), var(--nile-panel-2);
  display:flex; align-items:center; justify-content:center;
}
.consultant-image img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.consultant-info{padding:22px;}
.consultant-info h3{font-size:16.5px; font-weight:600; margin-bottom:6px;}
.consultant-info .specialty{font-size:13px; color:var(--nile-copper); font-weight:500; margin-bottom:10px;}
.consultant-info .bio{font-size:13px; color:var(--nile-paper-dim); line-height:1.7; font-weight:300; margin-bottom:14px;}
.consultant-info .appointment-time{font-size:12px; color:var(--nile-paper-dim); border-top:1px solid var(--nile-line); padding-top:12px;}
.consultant-info .appointment-time strong{color:var(--nile-paper); display:block; margin-bottom:4px;}

.nile-carousel-nav{display:flex; justify-content:center; gap:14px; margin-top:36px;}
.nile-carousel-btn{
  width:42px; height:42px; border-radius:50%; border:1px solid var(--nile-line);
  background:var(--nile-ink); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .25s ease; color:var(--nile-paper);
}
.nile-carousel-btn:hover{background:var(--nile-copper); color:#fff; border-color:var(--nile-copper);}

/* ====================================================================
   9) LEADERSHIP PROFILES SECTION
   ==================================================================== */
.nile-leadership-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:32px;}
.nile-leadership-card{display:flex; gap:28px; padding:32px; border:1px solid var(--nile-line); border-radius:4px; background:var(--nile-panel);}
.nile-leadership-photo{
  width:120px; height:120px; flex:0 0 120px; border-radius:4px; position:relative; overflow:hidden;
  background:repeating-linear-gradient(45deg, var(--nile-panel-2) 0 2px, transparent 2px 18px), var(--nile-panel-2);
  display:flex; align-items:center; justify-content:center;
}
.nile-leadership-photo img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.nile-leadership-content h4{font-size:18px; font-weight:700; margin-bottom:4px;}
.nile-leadership-content .role{font-size:13px; color:var(--nile-copper); font-weight:600; margin-bottom:12px;}
.nile-leadership-content p{font-size:13.5px; color:var(--nile-paper-dim); line-height:1.75; font-weight:300;}
.nile-leadership-content .qualification{margin-top:12px; font-family:'JetBrains Mono', monospace; font-size:11.5px; color:var(--nile-paper-dim);}

.nile-announcement-strip{margin-top:48px; display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.nile-announcement-card{padding:24px; border:1px dashed var(--nile-line); border-radius:4px; text-align:center;}
.nile-announcement-card .tag{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--nile-copper); letter-spacing:1px; margin-bottom:10px; display:block;}
.nile-announcement-card p{font-size:13.5px; color:var(--nile-paper-dim);}

/* ====================================================================
   10) TESTIMONIALS CAROUSEL
   ==================================================================== */
.nile-testimonial-carousel{position:relative; max-width:780px; margin:0 auto; text-align:center; overflow:hidden;}
.nile-testimonial-track{display:flex; transition:transform .5s cubic-bezier(.16,1,.3,1);}
.nile-testimonial-slide{flex:0 0 100%; padding:0 20px;}
.nile-testimonial-slide .stars{color:var(--nile-copper); font-size:18px; margin-bottom:18px; letter-spacing:3px;}
.nile-testimonial-slide blockquote{font-size:clamp(17px,2vw,22px); line-height:1.7; font-weight:400; margin-bottom:24px; color:var(--nile-paper);}
.nile-testimonial-slide .author{font-size:14px; font-weight:600; color:var(--nile-copper);}
.nile-testimonial-slide .project-ref{font-size:12px; color:var(--nile-paper-dim); font-family:'JetBrains Mono', monospace; margin-top:4px;}
.nile-testimonial-dots{display:flex; justify-content:center; gap:10px; margin-top:32px;}
.nile-testimonial-dot{width:8px; height:8px; border-radius:50%; background:var(--nile-line); cursor:pointer; transition:background .25s ease;}
.nile-testimonial-dot.is-active{background:var(--nile-copper);}

/* ====================================================================
   11) PROJECTS GRID
   ==================================================================== */
.nile-projects-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.nile-project-card{border:1px solid var(--nile-line); border-radius:4px; overflow:hidden; background:var(--nile-panel); transition:transform .4s cubic-bezier(.16,1,.3,1), border-color .4s ease;}
.nile-project-card:hover{transform:translateY(-6px); border-color:var(--nile-copper-dim);}
.nile-project-thumb{
  height:200px; position:relative; display:flex; align-items:center; justify-content:center;
  background:repeating-linear-gradient(45deg, var(--nile-panel-2) 0 2px, transparent 2px 18px), var(--nile-panel-2);
  border-bottom:1px solid var(--nile-line);
}
.nile-project-thumb img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.nile-project-body{padding:26px 26px 30px;}
.nile-project-tag{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--nile-copper); letter-spacing:1px; margin-bottom:10px; display:block;}
.nile-project-body h4{font-size:18px; font-weight:600; margin-bottom:10px;}
.nile-project-body p{font-size:13.5px; color:var(--nile-paper-dim); line-height:1.7; font-weight:300;}
.nile-project-meta{display:flex; justify-content:space-between; margin-top:18px; padding-top:18px; border-top:1px solid var(--nile-line); font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--nile-paper-dim);}

/* ====================================================================
   12) TRACK RECORD TABLES (project category tabs + tables)
   ==================================================================== */
.nile-track-tabs{display:flex; gap:10px; margin-bottom:36px; flex-wrap:wrap;}
.nile-track-tab{
  padding:9px 20px; border:1px solid var(--nile-line); border-radius:30px;
  font-size:13px; cursor:pointer; background:var(--nile-ink); color:var(--nile-paper-dim);
  transition:all .25s ease;
}
.nile-track-tab.is-active{background:var(--nile-copper); color:#fff; border-color:var(--nile-copper);}
.nile-track-table-wrap{overflow-x:auto; border:1px solid var(--nile-line); border-radius:4px;}
.nile-track-table{width:100%; border-collapse:collapse; min-width:640px;}
.nile-track-table thead th{
  background:var(--nile-panel); text-align:right; padding:14px 18px;
  font-family:'JetBrains Mono', monospace; font-size:11.5px; letter-spacing:1px;
  color:var(--nile-copper); text-transform:uppercase; border-bottom:1px solid var(--nile-line);
}
.nile-track-table tbody td{padding:16px 18px; font-size:14px; border-bottom:1px solid var(--nile-line); color:var(--nile-paper);}
.nile-track-table tbody tr:last-child td{border-bottom:none;}
.nile-track-table tbody tr:hover{background:var(--nile-panel-2);}
.nile-status-badge{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-family:'JetBrains Mono', monospace;}
.nile-status-badge::before{content:''; width:7px; height:7px; border-radius:50%; background:var(--nile-ok);}
.nile-track-panel{display:none;}
.nile-track-panel.is-active{display:block;}

/* ====================================================================
   13) CLIENTS / TRUST STRIP
   ==================================================================== */
.nile-trust-strip{display:flex; border-top:1px solid var(--nile-line); border-bottom:1px solid var(--nile-line); flex-wrap:wrap;}
.nile-trust-strip-item{flex:1 1 20%; padding:36px 24px; text-align:center; border-right:1px solid var(--nile-line); display:flex; flex-direction:column; gap:6px; align-items:center;}
.nile-trust-strip-item:last-child{border-right:none;}
.nile-trust-strip-item .t-name{font-size:14.5px; font-weight:600; color:var(--nile-paper);}
.nile-trust-strip-item .t-sector{font-size:12px; color:var(--nile-paper-dim); font-family:'JetBrains Mono', monospace;}

/* ====================================================================
   14) QUOTE REQUEST FORM
   ==================================================================== */
.nile-quote-form-wrap{max-width:720px; margin:0 auto; background:var(--nile-panel); border:1px solid var(--nile-line); border-radius:6px; padding:48px;}
.nile-form-row{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px;}
.nile-form-group{display:flex; flex-direction:column; gap:8px;}
.nile-form-group.full{grid-column:1/-1;}
.nile-form-group label{font-size:13px; color:var(--nile-paper-dim); font-weight:500;}
.nile-form-group input, .nile-form-group select, .nile-form-group textarea{
  padding:13px 16px; border:1px solid var(--nile-line); border-radius:3px;
  background:var(--nile-ink); color:var(--nile-paper); font-size:14px; font-family:inherit;
}
.nile-form-group input:focus, .nile-form-group select:focus, .nile-form-group textarea:focus{
  outline:none; border-color:var(--nile-copper);
}
.nile-form-group textarea{resize:vertical; min-height:110px;}
.nile-form-error{font-size:12px; color:#B23B3B; display:none;}
.nile-form-group.has-error input, .nile-form-group.has-error textarea, .nile-form-group.has-error select{border-color:#B23B3B;}
.nile-form-group.has-error .nile-form-error{display:block;}
.nile-form-submit{width:100%; padding:16px; font-size:15px; margin-top:6px;}
.nile-form-success{display:none; text-align:center; padding:40px; color:var(--nile-ok); font-weight:600;}
.nile-form-success.is-visible{display:block;}

/* ====================================================================
   15) URGENT CONTACT BAR
   ==================================================================== */
.nile-urgent-bar{
  position:fixed; bottom:24px; left:24px; z-index:45;
  display:flex; align-items:center; gap:14px;
  background:var(--nile-paper); color:var(--nile-ink);
  padding:14px 22px; border-radius:40px; box-shadow:0 10px 30px rgba(0,0,0,.15);
}
.nile-urgent-bar a{color:var(--nile-ink); text-decoration:none; font-size:13px; font-weight:600; display:flex; align-items:center; gap:8px;}
.nile-urgent-bar .pulse-dot{width:8px; height:8px; border-radius:50%; background:#C0453B; animation:nilePulse 1.6s ease-in-out infinite;}
@keyframes nilePulse{0%,100%{opacity:1;} 50%{opacity:.3;}}

/* ====================================================================
   16) CTA BAND
   ==================================================================== */
.nile-cta-band{position:relative; padding:120px 48px; text-align:center; border-top:1px solid var(--nile-line); border-bottom:1px solid var(--nile-line); overflow:hidden;}
.nile-cta-band h2{font-size:clamp(32px,5vw,64px); font-weight:700; max-width:780px; margin:0 auto 28px; line-height:1.2;}
.nile-cta-band h2 .accent{color:var(--nile-copper);}
.nile-cta-band p{color:var(--nile-paper-dim); font-size:16px; margin-bottom:44px; font-weight:300;}
.nile-cta-buttons{display:flex; justify-content:center; gap:18px; flex-wrap:wrap;}

/* ====================================================================
   17) FOOTER
   ==================================================================== */
.nile-footer{padding:80px 48px 36px; position:relative; z-index:1;}
.nile-footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:48px; padding-bottom:56px; border-bottom:1px solid var(--nile-line);}
.nile-footer-brand p{color:var(--nile-paper-dim); font-size:14px; line-height:1.8; margin-top:18px; font-weight:300; max-width:300px;}
.nile-footer-col h5{font-size:13px; letter-spacing:2px; color:var(--nile-copper); font-family:'JetBrains Mono', monospace; margin-bottom:22px; text-transform:uppercase;}
.nile-footer-col a{display:block; color:var(--nile-paper-dim); text-decoration:none; font-size:14.5px; margin-bottom:14px; transition:color .25s ease;}
.nile-footer-col a:hover{color:var(--nile-copper);}
.nile-footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:28px; font-size:12.5px; color:var(--nile-paper-dim); flex-wrap:wrap; gap:12px;}
.nile-social-row{display:flex; gap:12px; margin-top:18px;}
.nile-social-row a{width:36px; height:36px; border:1px solid var(--nile-line); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--nile-paper-dim); transition:all .25s ease;}
.nile-social-row a:hover{background:var(--nile-copper); color:#fff; border-color:var(--nile-copper);}

/* ====================================================================
   18) BACK TO TOP BUTTON
   ==================================================================== */
.nile-back-to-top{
  position:fixed; bottom:24px; right:24px; z-index:45;
  width:48px; height:48px; border-radius:50%; border:1px solid var(--nile-line);
  background:var(--nile-ink); color:var(--nile-paper); display:flex; align-items:center; justify-content:center;
  cursor:pointer; opacity:0; pointer-events:none; transition:all .3s ease;
}
.nile-back-to-top.is-visible{opacity:1; pointer-events:auto;}
.nile-back-to-top:hover{background:var(--nile-copper); color:#fff; border-color:var(--nile-copper);}

/* ====================================================================
   19) RESPONSIVE
   ==================================================================== */
@media (max-width:1100px){
  .nile-services-grid{grid-template-columns:repeat(2,1fr);}
  .nile-trust-grid{grid-template-columns:repeat(2,1fr);}
  .nile-growth-wrap{grid-template-columns:1fr; gap:48px;}
  .nile-projects-grid{grid-template-columns:repeat(2,1fr);}
  .nile-footer-grid{grid-template-columns:1fr 1fr;}
  .nile-dim-stats{grid-template-columns:repeat(2,1fr);}
  .nile-dim-stat:nth-child(2n){border-right:none;}
  .nile-hero-split{grid-template-columns:1fr; gap:40px;}
  .nile-hero-visual{aspect-ratio:16/9; max-width:560px;}
  .nile-leadership-grid{grid-template-columns:1fr;}
  .consultant-card{flex:0 0 calc(50% - 12px);}
  .nile-announcement-strip{grid-template-columns:1fr;}
  .nile-trust-strip-item{flex:1 1 33.33%;}
}
@media (max-width:760px){
  .nile-nav, .nile-lang-switch{display:none;}
  .nile-burger{display:flex;}
  .nile-topbar{padding:16px 24px;}
  .nile-hero{padding:120px 24px 60px;}
  .nile-section{padding:80px 24px;}
  .nile-services-grid, .nile-trust-grid{grid-template-columns:1fr;}
  .nile-projects-grid{grid-template-columns:1fr;}
  .nile-footer-grid{grid-template-columns:1fr;}
  .nile-dim-stats{grid-template-columns:1fr 1fr;}
  .consultant-card{flex:0 0 100%;}
  .nile-form-row{grid-template-columns:1fr;}
  .nile-trust-strip-item{flex:1 1 50%;}
}
