/* =========================================================
   FORWARD FORENSICS — Brand Design System
   ========================================================= */
:root{
  --bg-primary:#F2F4F7;
  --bg-secondary:#E6EAF0;
  --card-bg:#FFFFFF;
  --nav-bg:#FFFFFF;
  --accent:#F58220;
  --accent-2:#FF9D3C;
  --text-primary:#1E293B;
  --text-secondary:#64748B;
  --border:#D9E2EC;
  --btn:#F58220;
  --btn-hover:#E86F00;
  --dark-bg:#1A1E27;
  --dark-bg-2:#222838;
  --radius:12px;
  --shadow-sm:0 2px 8px rgba(30,41,59,0.06);
  --shadow-md:0 10px 30px rgba(30,41,59,0.10);
  --shadow-lg:0 18px 46px rgba(30,41,59,0.16);
  --container:1200px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--text-primary);
  background:var(--bg-primary);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;font-weight:800;margin:0 0 16px;line-height:1.2;color:var(--text-primary);}
p{margin:0 0 14px;color:var(--text-secondary);line-height:1.7;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}

.icon{width:20px;height:20px;flex-shrink:0;}
.icon-sm{width:16px;height:16px;}
.icon-xs{width:12px;height:12px;}
.icon-lg{width:30px;height:30px;}
.icon-xl{width:46px;height:46px;}
.icon-accent{color:var(--accent);}

.eyebrow{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:0.78rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:14px;
}
.eyebrow--center{text-align:center;}
.section-title{font-size:2.1rem;letter-spacing:-0.01em;}
.section-title--center{text-align:center;max-width:680px;margin-left:auto;margin-right:auto;}
.section-text{font-size:1.02rem;max-width:560px;}
.section-text--center{text-align:center;margin-left:auto;margin-right:auto;}
.section-head{margin-bottom:48px;}
.section-cta{text-align:center;margin-top:36px;}

section{padding:96px 0;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:0.92rem;
  padding:14px 26px;border-radius:8px;border:1.5px solid transparent;
  cursor:pointer;transition:all 0.22s ease;white-space:nowrap;
}
.btn-primary{background:var(--btn);color:#fff;}
.btn-primary:hover{background:var(--btn-hover);transform:translateY(-2px);box-shadow:0 10px 24px rgba(245,130,32,0.32);}
.btn-outline{background:transparent;border-color:var(--text-primary);color:var(--text-primary);}
.btn-outline:hover{background:var(--text-primary);color:#fff;transform:translateY(-2px);}
.btn-sm{padding:10px 18px;font-size:0.84rem;}

/* ---------- Fade-in on scroll ---------- */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity 0.7s ease, transform 0.7s ease;}
.fade-in.visible{opacity:1;transform:translateY(0);}

/* =========================================================
   NAVBAR
   ========================================================= */
.navbar{
  position:sticky;top:0;z-index:1000;
  background:var(--nav-bg);
  box-shadow:0 1px 0 var(--border), 0 4px 16px rgba(30,41,59,0.04);
  transition:box-shadow 0.25s ease;
}
.navbar.scrolled{box-shadow:0 2px 24px rgba(30,41,59,0.12);}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:78px;gap:16px;}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-mark{height:32px;width:auto;display:block;}
.logo-text{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1rem;letter-spacing:0.02em;color:var(--text-primary);white-space:nowrap;}
.footer .logo-text{color:#fff;}

.nav-links{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;}
.nav-links a{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:0.73rem;
  letter-spacing:0.03em;text-transform:uppercase;color:var(--text-primary);
  position:relative;padding:6px 0;transition:color 0.2s ease;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);
  transition:width 0.2s ease;
}
.nav-links a:hover{color:var(--accent);}
.nav-links a:hover::after{width:100%;}
.nav-shop-btn{background:var(--accent)!important;color:#fff!important;padding:7px 16px!important;border-radius:7px!important;letter-spacing:0.02em!important;}
.nav-shop-btn:hover{background:var(--btn-hover)!important;color:#fff!important;transform:translateY(-1px);}
.nav-shop-btn::after{display:none!important;}

.navbar-right{display:flex;align-items:center;gap:16px;flex-shrink:0;}
.lang-select{position:relative;}
.lang-btn{
  display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);
  border-radius:6px;padding:8px 10px;color:var(--text-primary);font-family:'Inter',sans-serif;
  font-size:0.82rem;cursor:pointer;
}
.lang-btn:hover{border-color:var(--accent);color:var(--accent);}
.lang-menu{
  position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);
  border-radius:8px;box-shadow:var(--shadow-md);min-width:140px;padding:6px;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all 0.18s ease;
}
.lang-select.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0);}
.lang-menu li{padding:9px 12px;border-radius:6px;font-size:0.86rem;cursor:pointer;color:var(--text-primary);}
.lang-menu li:hover{background:var(--bg-primary);color:var(--accent);}
.lang-menu li.active{background:rgba(245,130,32,0.1);color:var(--accent);font-weight:600;}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--text-primary);padding:6px;}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;background:#0D1017;padding:120px 0 110px;overflow:hidden;min-height:560px;
  display:flex;align-items:center;
}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;transform:scale(1.08);transform-origin:center center;z-index:0;}
.hero-bg-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg, rgba(11,14,20,0.8) 0%, rgba(11,14,20,0.68) 36%, rgba(11,14,20,0.4) 62%, rgba(11,14,20,0.08) 100%);
}
.hero .container{position:relative;z-index:2;}
.hero-left{max-width:640px;}
.hero .eyebrow{color:var(--accent-2);margin-bottom:20px;letter-spacing:0.16em;}
.hero-title{font-size:2.7rem;letter-spacing:0.01em;line-height:1.18;margin-bottom:28px;color:#fff;}
.hero-sub{font-size:1.08rem;max-width:520px;line-height:1.75;margin-bottom:40px;color:#C3C9D9;}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap;}
.hero-buttons .btn-outline{border-color:rgba(255,255,255,0.55);color:#fff;}
.hero-buttons .btn-outline:hover{border-color:#fff;background:rgba(255,255,255,0.08);}

/* =========================================================
   ABOUT STRIP
   ========================================================= */
.about-strip{background:var(--card-bg);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.about-points{display:flex;flex-direction:column;gap:22px;}
.about-point{display:flex;gap:16px;align-items:flex-start;padding:20px;border:1px solid var(--border);border-radius:var(--radius);transition:all 0.2s ease;}
.about-point:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);}
.about-point svg{color:var(--accent);flex-shrink:0;margin-top:2px;}
.about-point h3{font-size:1rem;margin-bottom:4px;}
.about-point p{font-size:0.9rem;margin:0;}

/* =========================================================
   MISSION
   ========================================================= */
.mission{background:var(--bg-primary);}
.mission-grid{margin-top:44px;}
.mission-card{
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:34px 28px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform 0.25s ease,box-shadow 0.25s ease,border-color 0.25s ease;
}
.mission-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--accent);}
.mission-icon{
  display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;
  background:rgba(245,130,32,0.1);color:var(--accent);margin:0 auto 18px;
}
.mission-card h3{font-size:1.08rem;margin-bottom:8px;}
.mission-card p{font-size:0.92rem;margin:0;}

/* =========================================================
   STATS BAR
   ========================================================= */
.stats-bar{background:var(--bg-secondary);padding:64px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.stat-card{
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;
  box-shadow:var(--shadow-sm);transition:transform 0.25s ease,box-shadow 0.25s ease;
}
.stat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.stat-number{font-family:'Montserrat',sans-serif;font-weight:800;font-size:2.1rem;color:var(--text-primary);}
.stat-label{font-size:0.82rem;color:var(--text-secondary);font-weight:500;}

/* =========================================================
   CARD GRIDS (shared)
   ========================================================= */
.card-grid{display:grid;gap:24px;}
.card-grid--3{grid-template-columns:repeat(3,1fr);}
.card-grid--4{grid-template-columns:repeat(4,1fr);}

/* ---------- Solutions ---------- */
.solutions{background:var(--bg-primary);}
.solution-card{
  display:block;color:inherit;text-decoration:none;
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform 0.25s ease,box-shadow 0.25s ease,border-color 0.25s ease;
}
.solution-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--accent);}
.solution-card-media{
  height:210px;display:flex;align-items:center;justify-content:center;color:#fff;
  background:var(--card-bg);border-bottom:1px solid var(--border);overflow:hidden;padding:10px;
}
.solution-card-media img{max-width:92%;max-height:92%;width:auto;height:auto;object-fit:contain;}
.solution-card-media--compact img{max-width:74%;max-height:74%;}
.solution-card-media--white{background:#ffffff;}
.solution-card-body{padding:24px;}
.solution-card-body h3{font-size:1.1rem;margin-bottom:10px;text-align:center;}
.solution-card-body p{font-size:0.92rem;margin-bottom:16px;}

/* ---------- Training course cards (Training Courses page) ---------- */
.page-head{padding:56px 0 12px;text-align:center;}
.page-head .breadcrumb{font-size:0.85rem;color:var(--text-secondary);margin-bottom:16px;}
.page-head .breadcrumb a{color:var(--accent);}
.course-filters{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:36px;}
.course-filters label{font-size:0.85rem;color:var(--text-secondary);}
.course-filters select{
  font-family:'Inter',sans-serif;font-size:0.88rem;color:var(--text-primary);background:var(--card-bg);
  border:1px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer;
}
.course-card-tag{margin-bottom:12px;}
.solution-card-meta{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-size:0.85rem;color:var(--text-secondary);}
.solution-card-meta span{display:flex;align-items:center;gap:7px;}
.solution-card-meta svg{flex-shrink:0;color:var(--accent);}
.course-cards-empty{text-align:center;color:var(--text-secondary);padding:40px 0;}
.card-link{
  display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:0.84rem;transition:gap 0.2s ease;
}
.card-link:hover{gap:10px;color:var(--btn-hover);}

/* =========================================================
   CAPABILITY DEVELOPMENT
   ========================================================= */
.capability{background:var(--bg-secondary);}
.capability-grid{display:grid;grid-template-columns:1.4fr 0.85fr;gap:48px;align-items:start;}
.timeline{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:40px;position:relative;
}
.timeline--4{grid-template-columns:repeat(4,1fr);}
.timeline::before{
  content:"";position:absolute;top:24px;left:0;right:0;height:2px;background:var(--border);z-index:0;
}
.timeline-step{position:relative;z-index:1;text-align:left;padding-right:8px;}
.timeline-icon{
  display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;
  background:var(--card-bg);border:2px solid var(--accent);color:var(--accent);margin-bottom:16px;
}
.timeline-step h3{font-size:0.98rem;margin-bottom:6px;}
.timeline-step p{font-size:0.82rem;margin:0;}

.capability-panel{
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow-sm);
}
.capability-panel-graphic{
  width:72px;height:72px;border-radius:50%;background:rgba(245,130,32,0.1);color:var(--accent);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.capability-panel h3{font-size:1.15rem;}
.capability-panel p{font-size:0.92rem;}

/* =========================================================
   GLOBAL IMPACT / INTERACTIVE GLOBE
   ========================================================= */
.global-impact{background:var(--dark-bg);position:relative;overflow:hidden;}
.global-impact::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 60% 35%, rgba(245,130,32,0.10) 0%, rgba(245,130,32,0) 55%);
  pointer-events:none;
}
.global-impact .eyebrow{color:var(--accent-2);}
.global-impact .section-title{color:#fff;font-size:2.15rem;}
.global-impact .section-text{color:#A7AEC1;}
.text-accent{color:var(--accent);}

.globe-layout{
  position:relative;z-index:1;display:grid;grid-template-columns:260px 1fr 260px;gap:32px;align-items:start;
}

.globe-intro{padding-top:4px;}
.globe-stats{margin-top:28px;display:flex;flex-direction:column;gap:18px;}
.globe-stat-row{display:flex;align-items:center;gap:14px;}
.globe-stat-row svg{flex-shrink:0;}
.globe-stat-number{display:block;font-family:'Montserrat',sans-serif;font-weight:800;color:#fff;font-size:1.3rem;line-height:1.2;}
.globe-stat-label{display:block;color:#8A91A6;font-size:0.84rem;}

.globe-stage{display:flex;flex-direction:column;gap:14px;}
.globe-canvas{
  position:relative;width:100%;max-width:560px;height:440px;max-height:440px;margin:0 auto;border-radius:var(--radius);overflow:hidden;
  background:radial-gradient(circle at 50% 45%, #1F2738 0%, #0A0D14 72%);
  border:1px solid rgba(255,255,255,0.08);box-shadow:var(--shadow-lg);
}
.globe-canvas canvas{border-radius:var(--radius);}

.globe-side{display:flex;flex-direction:column;gap:20px;}
.globe-panel{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.09);border-radius:var(--radius);
  padding:22px 24px;
}
.globe-panel h3{color:#fff;font-size:1.02rem;margin-bottom:14px;}
.globe-panel--callout svg{margin-bottom:14px;display:block;}
.globe-panel--callout h3{margin-bottom:8px;}
.globe-panel--callout p{color:#A7AEC1;font-size:0.88rem;margin-bottom:0;}

.region-list{padding:0;}
.region-list li{
  display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.08);
  cursor:pointer;transition:padding-left 0.18s ease;outline:none;
}
.region-list li:last-child{border-bottom:none;}
.region-list li:hover,.region-list li:focus,.region-list li.active{padding-left:6px;}
.region-list li.active .region-name{color:var(--accent-2);}
.region-list svg{color:var(--accent);flex-shrink:0;}
.region-name{flex:1;font-size:0.92rem;color:#E4E7EE;font-weight:500;}
.region-count{font-family:'Montserrat',sans-serif;font-weight:800;color:var(--accent);font-size:1rem;}
.globe-view-all{width:100%;justify-content:center;margin-top:18px;border-color:rgba(255,255,255,0.3);color:#fff;}
.globe-view-all:hover{background:rgba(255,255,255,0.1);color:#fff;}

/* =========================================================
   TRAINING ACADEMY
   ========================================================= */
.training{background:var(--bg-secondary);}
.training-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:28px;align-items:stretch;}
.training-banner{
  position:relative;border-radius:var(--radius);overflow:hidden;min-height:420px;
  background:
    radial-gradient(circle at 85% 15%, rgba(245,130,32,0.28), transparent 45%),
    linear-gradient(180deg, rgba(26,30,39,0.12) 0%, rgba(26,30,39,0.22) 38%, rgba(26,30,39,0.7) 75%, rgba(26,30,39,0.9) 100%),
    url('../assets/img/training-session.png');
  background-size:auto, auto, cover;
  background-position:center, center, center 28%;
  background-repeat:no-repeat, no-repeat, no-repeat;
  display:flex;align-items:flex-end;
}
.training-banner-overlay{position:relative;z-index:1;padding:44px;color:#fff;}
.training-banner-overlay .eyebrow{color:var(--accent-2);}
.training-banner-overlay .section-title{color:#fff;}
.training-banner-overlay .section-text{color:#C3C9D9;max-width:480px;}

.courses-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;}
.courses-panel h3{font-size:1.1rem;margin-bottom:18px;}
.course-list{display:flex;flex-direction:column;gap:14px;margin-bottom:18px;}
.course-list li{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.course-list li:last-child{border-bottom:none;padding-bottom:0;}
.course-date{
  display:flex;flex-direction:column;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0;
  background:rgba(245,130,32,0.1);color:var(--accent);border-radius:8px;font-family:'Montserrat',sans-serif;
  font-size:0.62rem;font-weight:700;letter-spacing:0.04em;line-height:1.3;
}
.course-date strong{font-size:1.05rem;line-height:1.1;}
.course-info{display:flex;flex-direction:column;gap:2px;font-size:0.86rem;color:var(--text-secondary);}
.course-info strong{color:var(--text-primary);font-size:0.92rem;font-weight:600;}
.course-list li{cursor:pointer;border-radius:8px;transition:background 0.15s ease;}
.course-list li:hover{background:var(--bg-primary);}
.course-list-empty{color:var(--text-secondary);font-size:0.86rem;font-style:italic;cursor:default;}
.course-list-empty:hover{background:none;}

/* ---------- Training calendar ---------- */
.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;}
.calendar-head h3{margin:0;}
.calendar-nav{display:flex;align-items:center;gap:6px;}
.calendar-nav-btn{
  display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;
  transition:border-color 0.18s ease,color 0.18s ease;
}
.calendar-nav-btn:hover{border-color:var(--accent);color:var(--accent);}
.calendar-nav-btn svg{width:13px;height:13px;transform:rotate(90deg);}
.calendar-nav-btn--next svg{transform:rotate(-90deg);}
.calendar-month-label{font-family:'Montserrat',sans-serif;font-weight:700;font-size:0.8rem;min-width:96px;text-align:center;}

.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px;}
.calendar-weekday{font-size:0.62rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--text-secondary);text-align:center;padding-bottom:4px;}
.calendar-day{
  position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  font-size:0.78rem;color:var(--text-primary);border-radius:8px;background:var(--bg-primary);
}
.calendar-day--outside{color:var(--text-secondary);opacity:0.4;}
.calendar-day--today{box-shadow:inset 0 0 0 1.5px var(--accent-2);font-weight:700;}
.calendar-day--has-course{
  cursor:pointer;background:rgba(245,130,32,0.12);font-weight:700;color:var(--accent);
  transition:transform 0.15s ease,background 0.15s ease;
}
.calendar-day--has-course:hover{background:rgba(245,130,32,0.24);transform:translateY(-1px);}
.calendar-day--has-course::after{
  content:"";position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--accent);
}
.calendar-hint{font-size:0.76rem;color:var(--text-secondary);margin:0 0 16px;}

/* ---------- Booking modal ---------- */
.booking-modal-overlay{
  position:fixed;inset:0;background:rgba(15,18,26,0.6);display:flex;align-items:center;justify-content:center;
  padding:20px;z-index:200;
}
.booking-modal-overlay[hidden]{display:none;}
.booking-modal{
  position:relative;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  max-width:440px;width:100%;max-height:90vh;overflow-y:auto;padding:36px 30px 30px;
}
.booking-modal-close{
  position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;
}
.booking-modal-close:hover{color:var(--accent);}
.booking-modal-close svg{width:18px;height:18px;}
.booking-modal h3{font-size:1.15rem;margin-bottom:10px;}
.booking-course-meta{display:flex;align-items:center;gap:8px;font-size:0.86rem;color:var(--text-secondary);margin:0 0 6px;}
.booking-course-meta svg{width:15px;height:15px;color:var(--accent);flex-shrink:0;}
.booking-course-desc{font-size:0.86rem;color:var(--text-secondary);margin:10px 0 18px;}
.booking-course-select-wrap{margin-bottom:18px;}
.booking-course-select-wrap label{display:block;font-size:0.8rem;font-weight:600;margin-bottom:6px;}
.booking-course-select-wrap select{
  width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--card-bg);
  font-family:'Inter',sans-serif;font-size:0.88rem;color:var(--text-primary);
}
.booking-form{display:flex;flex-direction:column;gap:14px;}
.booking-form label{font-size:0.8rem;font-weight:600;color:var(--text-primary);display:flex;flex-direction:column;gap:6px;}
.booking-form input,.booking-form textarea{
  padding:10px 12px;border-radius:8px;border:1px solid var(--border);font-family:'Inter',sans-serif;
  font-size:0.88rem;color:var(--text-primary);background:var(--card-bg);resize:vertical;
}
.booking-form input:focus,.booking-form textarea:focus,.booking-course-select-wrap select:focus{outline:none;border-color:var(--accent);}
.booking-form button{justify-content:center;margin-top:4px;}
.booking-form-msg{font-size:0.8rem;color:#C0392B;margin:0;}
.booking-modal-success{text-align:center;padding:20px 0 4px;}
.booking-modal-success svg{margin-bottom:10px;}
.booking-modal-success p{margin-bottom:18px;color:var(--text-secondary);}
body.modal-open{overflow:hidden;}

/* =========================================================
   TECHNOLOGY & EQUIPMENT
   ========================================================= */
.technology{background:var(--bg-primary);}
.tech-card{
  display:block;color:inherit;text-decoration:none;cursor:pointer;
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform 0.25s ease,box-shadow 0.25s ease,border-color 0.25s ease;
}
.tech-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--accent);}
.tech-card svg{margin-bottom:18px;}
.tech-card h3{font-size:1.02rem;margin-bottom:8px;}
.tech-card p{font-size:0.86rem;margin:0;}

/* =========================================================
   INSIGHTS
   ========================================================= */
.insights{background:var(--bg-secondary);}
.insight-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform 0.25s ease,box-shadow 0.25s ease;}
.insight-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.insight-card-media{height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--accent);}
.insight-card-body{padding:22px 24px;}
.tag{display:inline-block;font-family:'Montserrat',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:var(--accent);background:rgba(245,130,32,0.1);padding:4px 10px;border-radius:20px;margin-bottom:12px;}
.insight-card-body h3{font-size:1.02rem;margin-bottom:6px;}
.insight-card-source{font-size:0.82rem;color:var(--text-secondary);margin-bottom:14px;}

/* =========================================================
   TRUSTED BY
   ========================================================= */
.trusted{background:var(--bg-primary);text-align:center;}
.badge-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;margin-top:40px;}
.badge-grid--4{grid-template-columns:repeat(4,1fr);}
.badge-card{
  display:flex;flex-direction:column;align-items:center;gap:12px;padding:26px 12px;
  border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);
  transition:all 0.2s ease;
}
.badge-card:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px);}
.badge-card svg{color:inherit;}
.badge-card span{font-size:0.78rem;font-weight:500;line-height:1.3;}

/* =========================================================
   CONTACT CTA
   ========================================================= */
.contact-cta{background:linear-gradient(135deg,#1A1E27,#262C3C);color:#fff;}
.contact-cta-inner{text-align:center;max-width:680px;margin:0 auto;}
.contact-cta-inner h2{color:#fff;font-size:2rem;}
.contact-cta-inner p{color:#C3C9D9;font-size:1.02rem;margin-bottom:32px;}
.contact-cta-actions{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;}
.contact-cta-info{display:flex;align-items:center;gap:8px;color:#C3C9D9;font-size:0.9rem;transition:color 0.2s ease;}
.contact-cta-info svg{color:var(--accent-2);}
a.contact-cta-info:hover,a.contact-cta-info:focus-visible{color:#fff;}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--dark-bg);color:#AAB2C5;padding-top:72px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:48px;}
.footer h4{color:#fff;font-size:0.92rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:18px;}
.footer-col p{color:#8B93A7;font-size:0.9rem;margin-top:14px;}
.footer-col ul{display:flex;flex-direction:column;gap:11px;}
.footer-col a{color:#AAB2C5;font-size:0.9rem;transition:color 0.2s ease;}
.footer-col a:hover{color:var(--accent-2);}
.footer-social{display:flex;gap:12px;margin-top:18px;}
.footer-social a{
  display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,0.06);color:#fff;
}
.footer-social a:hover{background:var(--accent);}
.footer-contact{gap:13px;margin-bottom:24px;}
.footer-contact li{font-size:0.88rem;color:#AAB2C5;}
.footer-contact a{display:flex;align-items:center;gap:10px;color:#AAB2C5;transition:color 0.2s ease;}
.footer-contact a:hover,.footer-contact a:focus-visible{color:var(--accent-2);}
.footer-contact svg{color:var(--accent-2);flex-shrink:0;}
.newsletter-form{display:flex;gap:8px;}
.newsletter-form input{
  flex:1;min-width:0;padding:11px 12px;border-radius:6px;border:1px solid #313851;
  background:rgba(255,255,255,0.04);color:#fff;font-family:'Inter',sans-serif;font-size:0.86rem;
}
.newsletter-form input::placeholder{color:#6B7387;}
.newsletter-form input:focus{outline:none;border-color:var(--accent);}
.newsletter-msg{color:var(--accent-2);font-size:0.84rem;margin-top:10px;}

.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding:22px 0;}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:0.82rem;color:#76809A;}
.footer-bottom-links{display:flex;gap:20px;}
.footer-bottom-links a:hover{color:var(--accent-2);}

/* =========================================================
   LABORATORY SOLUTIONS PAGE
   ========================================================= */
.page-head-subtitle{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.05rem;color:var(--accent);
  margin:0 auto 18px;text-align:center;
}
.section-text--wide{max-width:760px;}

.lab-intro{background:var(--card-bg);}
.lab-intro .container{max-width:820px;}
.lab-intro p{font-size:1rem;}

.lab-feature{padding:40px 0;border-bottom:1px solid var(--border);}
.lab-feature:first-of-type{padding-top:0;}
.lab-feature:last-of-type{border-bottom:none;padding-bottom:0;}
.lab-feature-head{display:flex;align-items:center;gap:16px;margin-bottom:16px;}
.lab-feature-icon{
  display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;
  background:rgba(245,130,32,0.1);color:var(--accent);flex-shrink:0;
}
.lab-feature-head h3{margin:0;font-size:1.3rem;}
.lab-feature-lead{font-size:0.96rem;max-width:760px;margin-bottom:22px;}

.lab-feature-image{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);margin-bottom:28px;}
.lab-feature-image img{display:block;width:100%;height:auto;}

.lab-list{display:grid;grid-template-columns:1fr 1fr;gap:11px 32px;}
.lab-list--single{grid-template-columns:1fr;max-width:640px;margin-left:auto;margin-right:auto;}
.lab-list li{display:flex;gap:10px;align-items:flex-start;font-size:0.92rem;color:var(--text-secondary);line-height:1.5;}
.lab-list li svg{color:var(--accent);flex-shrink:0;margin-top:3px;}

.lab-suite-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:6px;}
.lab-suite-card{
  display:block;color:inherit;text-decoration:none;cursor:pointer;
  background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:22px;
  transition:transform 0.22s ease,box-shadow 0.22s ease,border-color 0.22s ease;
}
.lab-suite-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--accent);}
.lab-suite-card-media{
  height:170px;display:flex;align-items:center;justify-content:center;
  background:var(--card-bg);border:1px solid var(--border);border-radius:calc(var(--radius) - 4px);
  overflow:hidden;margin-bottom:16px;padding:8px;
}
.lab-suite-card-media img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;}
.lab-suite-card-media--fill{height:auto;aspect-ratio:2/3;padding:0;background:transparent;}
.lab-suite-card-media--fill img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;}
.lab-suite-card--static{cursor:default;}
.lab-suite-card-actions{display:flex;flex-direction:column;align-items:flex-start;}
.lab-suite-card h4{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:0.94rem;margin:0 0 12px;
  display:flex;align-items:center;gap:10px;color:var(--text-primary);
}
.lab-suite-card h4 svg{color:var(--accent);flex-shrink:0;}
.lab-suite-card p{font-size:0.84rem;color:var(--text-secondary);line-height:1.55;margin:0 0 12px;}
.lab-suite-card ul{display:flex;flex-direction:column;gap:7px;}
.lab-suite-card li{font-size:0.82rem;color:var(--text-secondary);line-height:1.5;padding-left:14px;position:relative;}
.lab-suite-card li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--accent);}
.lab-suite-card .card-link{margin-top:14px;}

/* ── Spec panel ─────────────────────────────────────── */
.spec-panel{max-height:0;overflow:hidden;transition:max-height 0.32s ease;}
.spec-panel.is-open{max-height:700px;}
.spec-inner{
  margin-top:16px;border-top:1px solid var(--border);padding-top:14px;
}
.spec-table{display:grid;grid-template-columns:1fr 1.4fr;gap:0;}
.spec-row{
  display:contents;
}
.spec-row span{
  font-size:0.78rem;line-height:1.45;padding:5px 6px 5px 0;
  border-bottom:1px solid var(--border);
}
.spec-row:last-child span{border-bottom:none;}
.spec-label{color:var(--text-secondary);font-weight:600;}
.spec-value{color:var(--text-primary);}
.spec-note{
  font-size:0.73rem;color:var(--text-secondary);line-height:1.5;
  margin:10px 0 0;font-style:italic;
}
.spec-trigger{background:none;border:none;padding:0;cursor:pointer;}
.spec-trigger svg{transition:transform 0.22s ease;}
.spec-trigger.is-open svg{transform:rotate(90deg);}

.standards-tags{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0 28px;}
.standards-tags .tag{margin-bottom:0;}

.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:4px;}
.split-col h4{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1rem;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;color:var(--text-primary);
}
.split-col h4 svg{color:var(--accent);}

.lab-flex{background:var(--bg-secondary);}
.checklist-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:8px;}
.checklist-item{
  display:flex;align-items:center;gap:10px;padding:16px 18px;background:var(--card-bg);
  border:1px solid var(--border);border-radius:10px;font-family:'Montserrat',sans-serif;font-weight:600;
  font-size:0.86rem;color:var(--text-primary);
}
.checklist-item svg{color:var(--accent);flex-shrink:0;}

.lab-why p{max-width:760px;margin-left:auto;margin-right:auto;}

.lab-callout{
  background:linear-gradient(135deg,rgba(245,130,32,0.08),rgba(245,130,32,0.02));
  border:1px solid var(--border);border-radius:var(--radius);padding:44px;text-align:center;margin-top:48px;
}
.lab-callout h3{font-size:1.35rem;margin-bottom:14px;}
.lab-callout p{font-size:1rem;max-width:720px;margin:0 auto;color:var(--text-secondary);}

/* =========================================================
   LEGAL PAGES (Privacy Policy / Terms of Use)
   ========================================================= */
.legal-content{padding:8px 0 80px;}
.legal-content .container{max-width:780px;}
.legal-updated{font-size:0.85rem;color:var(--text-secondary);text-align:center;margin-bottom:40px;}
.legal-disclaimer{
  background:var(--card-bg);border:1px solid var(--border);border-left:3px solid var(--accent);
  border-radius:8px;padding:18px 20px;margin-bottom:40px;
}
.legal-disclaimer p{font-size:0.86rem;margin:0;color:var(--text-secondary);}
.legal-block{margin-bottom:34px;}
.legal-block:last-child{margin-bottom:0;}
.legal-block h2{font-size:1.28rem;margin-bottom:14px;}
.legal-block h3{font-size:1.02rem;margin:20px 0 10px;}
.legal-block p{font-size:0.95rem;}
.legal-block ul,.legal-block ol{margin:0 0 14px;padding-left:22px;color:var(--text-secondary);}
.legal-block li{font-size:0.95rem;line-height:1.65;margin-bottom:8px;color:var(--text-secondary);}
.legal-block a{color:var(--accent);text-decoration:underline;}
.legal-toc{
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px 26px;margin-bottom:44px;
}
.legal-toc h2{font-size:0.95rem;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:12px;}
.legal-toc ol{margin:0;padding-left:20px;columns:2;column-gap:24px;}
.legal-toc li{font-size:0.88rem;margin-bottom:8px;}
.legal-toc a{color:var(--text-secondary);}
.legal-toc a:hover{color:var(--accent);}

/* =========================================================
   CONTACT PAGE
   ========================================================= */
.contact-section{padding:8px 0 90px;}
.contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:start;}
.contact-form-card,.contact-info-card{
  background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:36px;box-shadow:var(--shadow-sm);
}
.contact-form-card h2,.contact-info-card h2{font-size:1.3rem;margin-bottom:10px;}
.contact-form-card>div>p,.contact-info-card>p{font-size:0.92rem;color:var(--text-secondary);margin-bottom:24px;}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-form label{font-size:0.8rem;font-weight:600;color:var(--text-primary);display:flex;flex-direction:column;gap:6px;}
.contact-form input,.contact-form textarea,.contact-form select{
  padding:11px 13px;border-radius:8px;border:1px solid var(--border);font-family:'Inter',sans-serif;
  font-size:0.9rem;color:var(--text-primary);background:var(--card-bg);resize:vertical;width:100%;
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--accent);}
.contact-form-select-wrap{display:flex;flex-direction:column;gap:6px;}
.contact-form-select-wrap label{font-size:0.8rem;font-weight:600;color:var(--text-primary);}
.contact-form button{justify-content:center;margin-top:4px;}
.contact-form-msg{font-size:0.82rem;color:#C0392B;margin:0;}
.contact-form-success{text-align:center;padding:46px 12px;}
.contact-form-success h3{font-size:1.25rem;margin:14px 0 10px;}
.contact-form-success p{font-size:0.92rem;color:var(--text-secondary);max-width:380px;margin:0 auto 22px;}
.contact-info-list{display:flex;flex-direction:column;gap:14px;margin-bottom:28px;}
.contact-info-list li{font-size:0.9rem;}
.contact-info-list a{display:flex;align-items:flex-start;gap:10px;color:var(--text-secondary);transition:color 0.2s ease;line-height:1.5;}
.contact-info-list a:hover,.contact-info-list a:focus-visible{color:var(--accent);}
.contact-info-list svg{color:var(--accent);flex-shrink:0;margin-top:2px;}
.contact-info-card h3{font-size:0.95rem;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:14px;color:var(--text-secondary);}
.contact-info-social{display:flex;gap:12px;}
.contact-info-social a{
  display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;
  background:var(--bg-secondary);color:var(--text-primary);transition:background 0.2s ease,color 0.2s ease;
}
.contact-info-social a:hover{background:var(--accent);color:#fff;}

/* =========================================================
   RTL SUPPORT (Arabic)
   Mirrors layout, spacing, and directional icons when
   <html dir="rtl"> is applied by js/i18n.js. Grid and flex
   children reorder automatically with the `direction`
   property; the rules below cover physical left/right
   values that don't flip on their own.
   ========================================================= */
[dir="rtl"] body{direction:rtl;}

/* Nav underline grows from the trailing edge */
[dir="rtl"] .nav-links a::after{left:auto;right:0;}

/* Language dropdown opens toward the trailing edge */
[dir="rtl"] .lang-menu{right:auto;left:0;}

/* Mobile nav drawer slides in from the trailing edge */
[dir="rtl"] .nav-links{transform:translateX(100%);}
[dir="rtl"] .nav-links.open{transform:translateX(0);}

/* Capability timeline steps read right-to-left */
[dir="rtl"] .timeline-step{text-align:right;padding-right:0;padding-left:8px;}

/* Region list hover/active indent flips side */
[dir="rtl"] .region-list li{transition:padding-right 0.18s ease;}
[dir="rtl"] .region-list li:hover,[dir="rtl"] .region-list li:focus,[dir="rtl"] .region-list li.active{padding-left:0;padding-right:6px;}

/* Booking modal close button */
[dir="rtl"] .booking-modal-close{right:auto;left:16px;}

/* Lab suite card bullet markers */
[dir="rtl"] .lab-suite-card li{padding-left:0;padding-right:14px;}
[dir="rtl"] .lab-suite-card li::before{left:auto;right:0;}

/* Legal page accent border + list indents */
[dir="rtl"] .legal-disclaimer{border-left:none;border-right:3px solid var(--accent);}
[dir="rtl"] .legal-block ul,[dir="rtl"] .legal-block ol{padding-left:0;padding-right:22px;}
[dir="rtl"] .legal-toc ol{padding-left:0;padding-right:20px;}

/* Calendar prev/next chevrons mirror direction */
[dir="rtl"] .calendar-nav-btn svg{transform:rotate(-90deg);}
[dir="rtl"] .calendar-nav-btn--next svg{transform:rotate(90deg);}

/* Directional arrow icons (CTA buttons, "Learn More" / "Read More" links) */
[dir="rtl"] .btn svg.icon,
[dir="rtl"] .card-link svg.icon{transform:scaleX(-1);}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1280px){
  .nav-links{
    position:fixed;top:78px;left:0;right:0;bottom:0;background:#fff;flex-direction:column;
    align-items:flex-start;padding:28px 24px;gap:6px;overflow-y:auto;
    transform:translateX(-100%);transition:transform 0.28s ease;z-index:999;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{font-size:0.95rem;padding:14px 0;width:100%;border-bottom:1px solid var(--border);}
  .nav-toggle{display:flex;}
  .lang-select{display:none;}
  .stats-grid{grid-template-columns:repeat(3,1fr);}
  .card-grid--4{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width:920px){
  .hero{min-height:460px;padding:90px 0 80px;}
  .hero-left{max-width:100%;}
  .hero-bg-overlay{background:linear-gradient(100deg, rgba(11,14,20,0.84) 0%, rgba(11,14,20,0.72) 55%, rgba(11,14,20,0.42) 85%, rgba(11,14,20,0.15) 100%);}
  .about-grid{grid-template-columns:1fr;}
  .capability-grid{grid-template-columns:1fr;}
  .timeline{grid-template-columns:repeat(5,1fr);}
  .globe-layout{grid-template-columns:1fr;}
  .globe-stats{flex-direction:row;flex-wrap:wrap;gap:22px 28px;}
  .globe-stat-row{flex:1 1 45%;}
  .globe-canvas{height:420px;max-width:480px;}
  .globe-side{flex-direction:row;}
  .globe-panel{flex:1;}
  .training-grid{grid-template-columns:1fr;}
  .training-banner{min-height:320px;}
  .card-grid--3{grid-template-columns:repeat(2,1fr);}
  .badge-grid{grid-template-columns:repeat(3,1fr);}
  .badge-grid--4{grid-template-columns:repeat(2,1fr);}
  .booking-modal{padding:30px 22px 24px;}
  .lab-suite-grid{grid-template-columns:repeat(2,1fr);}
  .split-grid{grid-template-columns:1fr;gap:28px;}
  .lab-list{grid-template-columns:1fr;}
  .timeline--4{grid-template-columns:repeat(4,1fr);}
  .contact-grid{grid-template-columns:1fr;}
}

@media (max-width:680px){
  section{padding:64px 0;}
  .hero-title{font-size:2.05rem;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .card-grid--3,.card-grid--4{grid-template-columns:1fr;}
  .timeline{grid-template-columns:1fr;gap:24px;}
  .timeline--4{grid-template-columns:1fr;}
  .timeline::before{display:none;}
  .badge-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr;}
  .legal-toc ol{columns:1;}
  .contact-cta-actions{flex-direction:column;gap:16px;}
  .hero{min-height:380px;padding:80px 0 64px;}
  .hero-bg-overlay{background:linear-gradient(180deg, rgba(11,14,20,0.86) 0%, rgba(11,14,20,0.8) 60%, rgba(11,14,20,0.55) 100%);}
  .navbar-inner{height:68px;}
  .logo-text{font-size:0.82rem;letter-spacing:0.01em;}
  .globe-stats{flex-direction:column;gap:16px;}
  .globe-stat-row{flex:1 1 100%;}
  .globe-canvas{height:320px;max-width:380px;}
  .globe-side{flex-direction:column;}
  .lab-suite-grid{grid-template-columns:1fr;}
  .lab-feature-head{align-items:flex-start;}
  .contact-form-card,.contact-info-card{padding:26px;}
  .contact-form .form-row{grid-template-columns:1fr;}
}
