/* =====================================================
   DREAM PETROLEUM BV — MASTER STYLESHEET
   Theme: Jet Black + Vivid Orange
   Font: DM Sans + Space Grotesk
   ===================================================== */

/* ---- Google Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;700&family=Space+Grotesk:wght@400;500;600;700;800&display=swap');

/* ---- CSS Variables ---- */
:root {
  --black:       #0a0a0a;
  --black-2:     #111111;
  --black-3:     #1a1a1a;
  --black-4:     #222222;
  --orange:      #FF6600;
  --orange-dark: #CC5200;
  --orange-glow: rgba(255,102,0,0.15);
  --orange-glow2:rgba(255,102,0,0.06);
  --white:       #ffffff;
  --white-80:    rgba(255,255,255,0.80);
  --white-50:    rgba(255,255,255,0.50);
  --white-20:    rgba(255,255,255,0.20);
  --white-10:    rgba(255,255,255,0.10);
  --white-05:    rgba(255,255,255,0.05);
  --border:      rgba(255,255,255,0.08);
  --border-o:    rgba(255,102,0,0.30);
  --font-head:  'Space Grotesk', sans-serif;
  --font-body:  'DM Sans', sans-serif;
  --ease:        cubic-bezier(.25,.8,.25,1);
  --radius:      12px;
  --radius-lg:   20px;
  --shadow:      0 20px 60px rgba(0,0,0,0.5);
  --shadow-o:    0 10px 40px rgba(255,102,0,0.2);
}

/* ---- Reset ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); background:var(--black); color:var(--white); line-height:1.7; overflow-x:hidden; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; font-family:inherit; }
input, textarea, select { font-family:inherit; }

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--black-2); }
::-webkit-scrollbar-thumb { background:var(--orange); border-radius:3px; }

/* ===================== LAYOUT ===================== */
.container { width:90%; max-width:1240px; margin:0 auto; }
.section { padding:100px 0; }
.section--dark { background:var(--black-2); }
.section--darker { background:var(--black-3); }
.section--orange { background:var(--orange); }

/* ===================== TYPOGRAPHY ===================== */
.tag {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--orange-glow); border:1px solid var(--border-o);
  color:var(--orange); font-family:var(--font-head);
  font-size:.75rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; padding:5px 14px; border-radius:50px;
  margin-bottom:16px;
}
.tag i { font-size:.7rem; }

h1,h2,h3,h4,h5 { font-family:var(--font-head); font-weight:700; line-height:1.15; }
h1 { font-size:clamp(2.5rem,5vw,4.5rem); }
h2 { font-size:clamp(2rem,4vw,3.2rem); }
h3 { font-size:clamp(1.2rem,2vw,1.6rem); }

.text-o { color:var(--orange); }
.text-muted { color:var(--white-50); }
.text-sm { font-size:.9rem; }
.text-center { text-align:center; }
.fw-700 { font-weight:700; }

/* ===================== BUTTONS ===================== */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-head); font-size:.9rem; font-weight:600;
  padding:13px 28px; border-radius:50px;
  transition:all .3s var(--ease); white-space:nowrap; cursor:pointer;
}
.btn i { transition:transform .3s var(--ease); }
.btn:hover i { transform:translateX(4px); }

.btn-primary {
  background:var(--orange); color:var(--white);
  box-shadow:var(--shadow-o);
}
.btn-primary:hover { background:var(--orange-dark); transform:translateY(-2px); box-shadow:0 14px 40px rgba(255,102,0,0.35); }

.btn-outline {
  background:transparent; color:var(--white);
  border:1.5px solid var(--white-20);
}
.btn-outline:hover { border-color:var(--orange); color:var(--orange); transform:translateY(-2px); }

.btn-outline-o {
  background:transparent; color:var(--orange);
  border:1.5px solid var(--orange);
}
.btn-outline-o:hover { background:var(--orange); color:var(--white); transform:translateY(-2px); }

.btn-lg { padding:16px 36px; font-size:1rem; }

/* ===================== NAVBAR ===================== */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  padding:18px 0;
  transition:all .4s var(--ease);
  background:transparent;
}
.navbar.scrolled {
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:12px 0;
}
.nav__inner {
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.nav__logo {
  font-family:var(--font-head); font-size:1.5rem; font-weight:800;
  letter-spacing:-.02em; white-space:nowrap;
}
.nav__logo span { color:var(--orange); }
.nav__logo sub { font-size:.55rem; color:var(--white-50); letter-spacing:.05em; vertical-align:top; margin-top:4px; display:inline-block; }

.nav__links {
  display:flex; align-items:center; gap:4px;
  position:relative;
}
.nav__links > li { position:relative; }
.nav__links > li > a {
  display:flex; align-items:center; gap:5px;
  font-size:.875rem; font-weight:500; padding:8px 14px;
  border-radius:8px; color:var(--white-80);
  transition:all .25s;
}
.nav__links > li > a:hover,
.nav__links > li.active > a { color:var(--white); background:var(--white-05); }
.nav__links > li.active > a { color:var(--orange); }

/* Dropdown */
.nav__links .has-drop { cursor:pointer; }
.nav__links .drop-icon { font-size:.65rem; transition:transform .3s; }
.nav__links li:hover .drop-icon { transform:rotate(180deg); }

.nav__dropdown {
  position:absolute; top:calc(100% + 10px); left:0;
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius); padding:8px;
  min-width:220px; opacity:0; visibility:hidden;
  transform:translateY(10px); transition:all .3s var(--ease);
  box-shadow:var(--shadow);
}
.nav__links li:hover .nav__dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.nav__dropdown a {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:8px;
  font-size:.875rem; color:var(--white-80);
  transition:all .2s;
}
.nav__dropdown a:hover { background:var(--orange-glow); color:var(--orange); }
.nav__dropdown a i { font-size:.75rem; color:var(--orange); width:14px; }

.nav__right { display:flex; align-items:center; gap:12px; }
.nav__hamburger {
  display:none; font-size:1.3rem; color:var(--white);
  background:var(--white-10); border:1px solid var(--border);
  padding:8px 12px; border-radius:8px; cursor:pointer;
}

/* Mobile Nav */
.mobile-nav {
  position:fixed; top:0; right:-100%; width:min(320px,90vw); height:100vh;
  background:var(--black-2); border-left:1px solid var(--border);
  z-index:99999; padding:24px;
  transition:right .4s var(--ease);
  overflow-y:auto;
}
.mobile-nav.open { right:0; }
.mobile-nav__header { display:flex; justify-content:space-between; align-items:center; margin-bottom:32px; }
.mobile-nav__close { font-size:1.2rem; cursor:pointer; color:var(--white-50); }
.mobile-nav__link {
  display:block; padding:12px 0; border-bottom:1px solid var(--border);
  font-size:1rem; font-weight:500; color:var(--white-80);
  transition:color .2s;
}
.mobile-nav__link:hover { color:var(--orange); }
.mobile-nav__sub { padding-left:16px; display:none; }
.mobile-nav__sub.open { display:block; }
.mobile-nav__sub a { display:block; padding:8px 0; color:var(--white-50); font-size:.875rem; }
.mobile-nav__sub a:hover { color:var(--orange); }
.mobile-nav__overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:99998;
}
.mobile-nav__overlay.open { display:block; }

/* ===================== PAGE HEADER ===================== */
.page-hero {
  padding:160px 0 80px;
  background:var(--black-2);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 60% 50%, rgba(255,102,0,.08) 0%, transparent 70%);
  pointer-events:none;
}
.page-hero__inner { position:relative; z-index:1; }
.page-hero__tag { margin-bottom:12px; }
.page-hero h1 { margin-bottom:12px; }
.page-hero p { color:var(--white-50); max-width:600px; font-size:1.1rem; margin-bottom:20px; }
.breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-size:.85rem; color:var(--white-50);
}
.breadcrumb a { color:var(--orange); }
.breadcrumb span { font-size:.65rem; }

/* ===================== HERO (Homepage) ===================== */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; overflow:hidden;
  background:var(--black);
}
.hero__bg-video-wrap {
  position:absolute; inset:0; z-index:0;
  background:url('assets/img/hero-bg.jpg') center/cover no-repeat;
}
.hero__bg-video-wrap::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(10,10,10,.97) 0%, rgba(10,10,10,.7) 55%, rgba(10,10,10,.3) 100%);
}
.hero__content { position:relative; z-index:2; max-width:720px; }
.hero__tag { margin-bottom:20px; }
.hero__title { font-size:clamp(2.8rem,6vw,5.5rem); margin-bottom:24px; line-height:1.05; }
.hero__desc { font-size:1.15rem; color:var(--white-80); margin-bottom:40px; max-width:580px; }
.hero__btns { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:60px; }
.hero__stats {
  display:flex; flex-wrap:wrap; gap:30px;
  border-top:1px solid var(--border); padding-top:40px;
}
.hero__stat-num { font-family:var(--font-head); font-size:2.4rem; font-weight:800; color:var(--orange); line-height:1; }
.hero__stat-label { font-size:.8rem; color:var(--white-50); margin-top:4px; }

/* Scrolling badge strip */
.hero__strip {
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  background:var(--orange); overflow:hidden;
  padding:10px 0; white-space:nowrap;
}
.hero__strip-inner { display:inline-flex; gap:40px; animation:scrollTicker 25s linear infinite; }
.hero__strip-item {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-head); font-size:.8rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; color:var(--white);
}
.hero__strip-item::after { content:'●'; color:rgba(255,255,255,.5); }
@keyframes scrollTicker {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ===================== ABOUT STRIP (Homepage) ===================== */
.about-strip { padding:80px 0; }
.about-strip__grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.about-strip__img-wrap { position:relative; }
.about-strip__img {
  border-radius:var(--radius-lg); overflow:hidden; height:500px;
  background:var(--black-3);
}
.about-strip__img img { width:100%; height:100%; object-fit:cover; }
.about-strip__badge {
  position:absolute; bottom:-28px; right:-28px;
  background:var(--orange); padding:28px 32px;
  border-radius:var(--radius-lg); text-align:center;
  box-shadow:var(--shadow-o);
}
.about-strip__badge-num { font-family:var(--font-head); font-size:2.8rem; font-weight:800; color:#fff; line-height:1; }
.about-strip__badge-text { font-size:.75rem; color:rgba(255,255,255,.8); margin-top:4px; text-transform:uppercase; letter-spacing:.05em; }

.about-strip__content { }
.about-strip__content p { color:var(--white-80); margin-bottom:20px; font-size:1.05rem; }
.about-strip__points { margin:28px 0 32px; display:flex; flex-direction:column; gap:14px; }
.about-strip__point {
  display:flex; align-items:flex-start; gap:14px;
  padding:16px; background:var(--white-05); border-radius:var(--radius);
  border:1px solid var(--border);
  transition:border-color .3s;
}
.about-strip__point:hover { border-color:var(--border-o); }
.about-strip__point-icon {
  width:40px; height:40px; min-width:40px;
  background:var(--orange-glow); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:var(--orange); font-size:.9rem;
}
.about-strip__point-title { font-weight:600; font-size:.95rem; margin-bottom:2px; }
.about-strip__point-text { font-size:.85rem; color:var(--white-50); }

/* ===================== SERVICES GRID ===================== */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px; }
.service-card {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px 28px;
  transition:all .35s var(--ease); position:relative; overflow:hidden;
}
.service-card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:var(--orange); transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.service-card:hover { border-color:var(--border-o); transform:translateY(-8px); box-shadow:var(--shadow-o); }
.service-card:hover::before { transform:scaleX(1); }
.service-card__icon {
  width:60px; height:60px; background:var(--orange-glow);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  color:var(--orange); font-size:1.5rem; margin-bottom:24px;
  transition:background .35s;
}
.service-card:hover .service-card__icon { background:var(--orange); color:#fff; }
.service-card h3 { margin-bottom:12px; font-size:1.2rem; }
.service-card p { color:var(--white-50); font-size:.9rem; line-height:1.65; }
.service-card__link {
  display:inline-flex; align-items:center; gap:6px; margin-top:20px;
  color:var(--orange); font-size:.85rem; font-weight:600;
  transition:gap .25s;
}
.service-card:hover .service-card__link { gap:10px; }

/* ===================== COUNTERS ===================== */
.counters-section {
  padding:80px 0;
  background:var(--black-3);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.counters-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); }
.counter-item {
  background:var(--black-3); padding:50px 30px; text-align:center;
}
.counter-num {
  font-family:var(--font-head); font-size:3.5rem; font-weight:800;
  color:var(--orange); line-height:1; margin-bottom:8px;
}
.counter-label { font-size:.875rem; color:var(--white-50); font-weight:500; }

/* ===================== PRODUCTS CARDS ===================== */
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px; }
.product-card {
  background:var(--black-3); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; transition:all .35s var(--ease);
}
.product-card:hover { transform:translateY(-8px); border-color:var(--border-o); box-shadow:var(--shadow-o); }
.product-card__img { height:220px; background:var(--black-4); overflow:hidden; }
.product-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.product-card:hover .product-card__img img { transform:scale(1.05); }
.product-card__body { padding:28px; }
.product-card__tag { color:var(--orange); font-size:.75rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px; }
.product-card__title { font-size:1.15rem; font-weight:700; margin-bottom:10px; }
.product-card__desc { color:var(--white-50); font-size:.875rem; line-height:1.65; margin-bottom:20px; }
.product-card__link {
  display:inline-flex; align-items:center; gap:6px;
  color:var(--orange); font-size:.85rem; font-weight:600; transition:gap .25s;
}
.product-card:hover .product-card__link { gap:10px; }

/* Grade Table */
.grade-table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--border); }
.grade-table { width:100%; border-collapse:collapse; }
.grade-table th {
  background:var(--orange); color:#fff;
  font-family:var(--font-head); font-size:.8rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; padding:14px 20px; text-align:left;
}
.grade-table td { padding:13px 20px; border-bottom:1px solid var(--border); font-size:.875rem; }
.grade-table tr:last-child td { border-bottom:none; }
.grade-table tr:hover td { background:var(--orange-glow2); }

/* ===================== MARKETS / REGIONS ===================== */
.markets-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:50px; }
.market-card {
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  height:280px; cursor:pointer;
}
.market-card__img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.market-card:hover .market-card__img { transform:scale(1.08); }
.market-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.2) 60%, transparent 100%);
}
.market-card__body {
  position:absolute; bottom:0; left:0; right:0; z-index:1;
  padding:24px 20px;
}
.market-card__sub { font-size:.75rem; color:var(--orange); font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.market-card__title { font-family:var(--font-head); font-size:1.3rem; font-weight:700; }

/* ===================== FAQ ACCORDION ===================== */
.faq-list { max-width:860px; margin:0 auto; }
.faq-item {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:12px; overflow:hidden;
  transition:border-color .3s;
}
.faq-item.active { border-color:var(--border-o); }
.faq-q {
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 24px; cursor:pointer;
  font-weight:600; font-size:1rem;
  transition:color .25s;
}
.faq-q:hover { color:var(--orange); }
.faq-item.active .faq-q { color:var(--orange); }
.faq-q i { transition:transform .3s; font-size:.75rem; color:var(--orange); min-width:14px; }
.faq-item.active .faq-q i { transform:rotate(180deg); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height .4s ease, padding .4s ease;
  color:var(--white-50); line-height:1.75;
}
.faq-item.active .faq-a { max-height:500px; padding:0 24px 20px; }

/* ===================== BLOG CARDS ===================== */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:60px; }
.blog-card {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; transition:all .35s var(--ease);
}
.blog-card:hover { transform:translateY(-8px); border-color:var(--border-o); box-shadow:var(--shadow); }
.blog-card__img { height:220px; overflow:hidden; background:var(--black-4); position:relative; }
.blog-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.blog-card:hover .blog-card__img img { transform:scale(1.05); }
.blog-card__date {
  position:absolute; top:16px; left:16px;
  background:var(--orange); color:#fff; padding:4px 12px;
  border-radius:50px; font-size:.75rem; font-weight:700;
}
.blog-card__body { padding:24px; }
.blog-card__tag { color:var(--orange); font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-bottom:10px; }
.blog-card__title { font-size:1.05rem; font-weight:700; margin-bottom:12px; line-height:1.4; }
.blog-card__title a { color:var(--white); transition:color .25s; }
.blog-card__title a:hover { color:var(--orange); }
.blog-card__desc { color:var(--white-50); font-size:.85rem; line-height:1.65; margin-bottom:20px; }
.blog-card__footer { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--border); padding-top:16px; }
.blog-card__read { display:flex; align-items:center; gap:6px; color:var(--orange); font-size:.85rem; font-weight:600; transition:gap .25s; }
.blog-card:hover .blog-card__read { gap:10px; }

/* ===================== CONTACT SECTION ===================== */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:start; }
.contact-info-item {
  display:flex; align-items:flex-start; gap:18px;
  padding:24px; background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:16px; transition:border-color .3s;
}
.contact-info-item:hover { border-color:var(--border-o); }
.contact-info-item i {
  width:48px; height:48px; min-width:48px;
  background:var(--orange-glow); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  color:var(--orange); font-size:1rem;
}
.contact-info-item h4 { font-size:.85rem; color:var(--white-50); margin-bottom:4px; }
.contact-info-item p { font-weight:600; font-size:.95rem; }

.contact-form { background:var(--black-3); border:1px solid var(--border); border-radius:var(--radius-lg); padding:40px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:.8rem; font-weight:600; color:var(--white-50); margin-bottom:8px; text-transform:uppercase; letter-spacing:.05em; }
.form-control {
  width:100%; padding:14px 18px;
  background:var(--black-4); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--white);
  font-size:.95rem; font-family:var(--font-body);
  transition:border-color .3s;
  -webkit-appearance:none;
}
.form-control:focus { outline:none; border-color:var(--orange); }
.form-control::placeholder { color:var(--white-20); }
textarea.form-control { min-height:150px; resize:vertical; }

/* ===================== SIDEBAR (Inner pages) ===================== */
.inner-layout { display:grid; grid-template-columns:1fr 330px; gap:50px; align-items:start; }
.sidebar { }
.sidebar-widget {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:30px; margin-bottom:24px;
}
.sidebar-widget h3 {
  font-size:1.05rem; font-weight:700; margin-bottom:20px;
  padding-bottom:14px; border-bottom:1px solid var(--border);
  position:relative;
}
.sidebar-widget h3::after {
  content:''; position:absolute; bottom:-1px; left:0;
  width:40px; height:2px; background:var(--orange);
}
.sidebar-nav li { margin-bottom:4px; }
.sidebar-nav a {
  display:flex; align-items:center; justify-content:space-between;
  padding:11px 16px; border-radius:8px; font-size:.875rem; font-weight:500;
  color:var(--white-80); transition:all .25s;
  border:1px solid transparent;
}
.sidebar-nav a:hover, .sidebar-nav a.active {
  background:var(--orange-glow); border-color:var(--border-o); color:var(--orange);
}
.sidebar-nav a i { font-size:.7rem; }

.sidebar-cta {
  background:linear-gradient(135deg, var(--orange-dark), var(--orange));
  border-radius:var(--radius-lg); padding:30px;
  text-align:center; margin-bottom:24px;
}
.sidebar-cta h3 { color:#fff; font-size:1.1rem; margin-bottom:10px; }
.sidebar-cta p { color:rgba(255,255,255,.85); font-size:.875rem; margin-bottom:20px; }
.sidebar-cta .btn { background:#fff; color:var(--orange); width:100%; justify-content:center; }

/* ===================== TESTIMONIALS ===================== */
.testimonials-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:50px; }
.testimonial-card {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:32px;
  transition:border-color .3s;
}
.testimonial-card:hover { border-color:var(--border-o); }
.testimonial-card__quote { font-size:2rem; color:var(--orange); line-height:1; margin-bottom:16px; }
.testimonial-card p { color:var(--white-80); font-size:.95rem; line-height:1.75; margin-bottom:24px; font-style:italic; }
.testimonial-card__author { display:flex; align-items:center; gap:14px; border-top:1px solid var(--border); padding-top:20px; }
.testimonial-card__avatar { width:48px; height:48px; border-radius:50%; background:var(--black-4); overflow:hidden; }
.testimonial-card__name { font-weight:700; font-size:.95rem; }
.testimonial-card__role { font-size:.8rem; color:var(--white-50); }

/* ===================== TEAM ===================== */
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:50px; }
.team-card {
  background:var(--black-3); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; text-align:center;
  transition:all .35s var(--ease);
}
.team-card:hover { transform:translateY(-8px); border-color:var(--border-o); }
.team-card__img { height:250px; background:var(--black-4); overflow:hidden; }
.team-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.team-card:hover .team-card__img img { transform:scale(1.05); }
.team-card__body { padding:20px 16px; }
.team-card__name { font-weight:700; font-size:1rem; margin-bottom:4px; }
.team-card__role { font-size:.8rem; color:var(--orange); font-weight:600; margin-bottom:12px; }
.team-card__dept { font-size:.75rem; color:var(--white-50); background:var(--white-05); padding:3px 10px; border-radius:20px; display:inline-block; }

/* ===================== CTA BANNER ===================== */
.cta-banner {
  background:var(--orange);
  padding:80px 0;
}
.cta-banner__inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:30px; }
.cta-banner h2 { color:#fff; font-size:clamp(1.6rem,3vw,2.5rem); max-width:600px; }
.cta-banner p { color:rgba(255,255,255,.85); margin-top:10px; max-width:500px; }
.cta-banner .btn-primary { background:#fff; color:var(--orange); }
.cta-banner .btn-primary:hover { background:var(--black); color:#fff; box-shadow:none; }

/* ===================== FOOTER ===================== */
.footer {
  background:var(--black-2);
  border-top:1px solid var(--border);
  padding:80px 0 0;
}
.footer__grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:50px;
  padding-bottom:60px; border-bottom:1px solid var(--border);
}
.footer__logo { font-family:var(--font-head); font-size:1.5rem; font-weight:800; margin-bottom:16px; }
.footer__logo span { color:var(--orange); }
.footer__about-text { color:var(--white-50); font-size:.875rem; line-height:1.75; margin-bottom:24px; max-width:280px; }
.footer__social { display:flex; gap:10px; }
.footer__social a {
  width:38px; height:38px; border-radius:8px;
  background:var(--white-05); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--white-50); font-size:.85rem; transition:all .25s;
}
.footer__social a:hover { background:var(--orange); border-color:var(--orange); color:#fff; }
.footer__col h4 { font-size:.85rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--orange); margin-bottom:20px; }
.footer__links li { margin-bottom:10px; }
.footer__links a { color:var(--white-50); font-size:.875rem; transition:color .25s; display:flex; align-items:center; gap:8px; }
.footer__links a:hover { color:var(--orange); }
.footer__links a i { font-size:.7rem; color:var(--orange); }
.footer__contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:16px; }
.footer__contact-item i { color:var(--orange); font-size:.85rem; margin-top:3px; }
.footer__contact-item span { color:var(--white-50); font-size:.875rem; line-height:1.5; }
.footer__contact-item a { color:var(--white-80); font-weight:600; font-size:.95rem; display:block; margin-bottom:2px; }
.footer__bottom {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding:20px 0; color:var(--white-50); font-size:.8rem;
}
.footer__bottom a { color:var(--white-50); transition:color .25s; }
.footer__bottom a:hover { color:var(--orange); }

/* ===================== MISC / UTILITIES ===================== */
.divider { height:1px; background:var(--border); margin:60px 0; }
.spacer { padding:40px 0; }
.highlight-box {
  background:var(--orange-glow); border:1px solid var(--border-o);
  border-radius:var(--radius); padding:24px 28px; margin:24px 0;
}
.highlight-box p { color:var(--white-80); font-size:1.05rem; font-style:italic; }
.check-list { display:flex; flex-direction:column; gap:12px; }
.check-list li {
  display:flex; align-items:flex-start; gap:12px;
  font-size:.95rem; color:var(--white-80);
}
.check-list li i { color:var(--orange); margin-top:3px; font-size:.85rem; }
.feature-boxes { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:24px 0; }
.feature-box {
  background:var(--black-4); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px;
  transition:border-color .3s;
}
.feature-box:hover { border-color:var(--border-o); }
.feature-box i { color:var(--orange); font-size:1.3rem; margin-bottom:12px; display:block; }
.feature-box h4 { font-size:.95rem; margin-bottom:6px; }
.feature-box p { font-size:.8rem; color:var(--white-50); }
.pillar-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.pillar-card {
  background:var(--black-3); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:28px; transition:all .3s;
}
.pillar-card:hover { border-color:var(--border-o); transform:translateY(-4px); }
.pillar-card i { color:var(--orange); font-size:1.6rem; margin-bottom:16px; display:block; }
.pillar-card h3 { font-size:1.1rem; margin-bottom:8px; }
.pillar-card p { font-size:.875rem; color:var(--white-50); }

/* Back to top */
#back-to-top {
  position:fixed; bottom:30px; right:30px; z-index:9998;
  width:44px; height:44px; border-radius:50%;
  background:var(--orange); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; cursor:pointer; opacity:0; visibility:hidden;
  transition:all .3s; box-shadow:var(--shadow-o);
}
#back-to-top.show { opacity:1; visibility:visible; }
#back-to-top:hover { background:var(--orange-dark); transform:translateY(-3px); }

/* Progress bar (about page) */
.progress-item { margin-bottom:20px; }
.progress-label { display:flex; justify-content:space-between; font-size:.875rem; font-weight:600; margin-bottom:8px; }
.progress-label span:last-child { color:var(--orange); }
.progress-bar { height:6px; background:var(--border); border-radius:3px; overflow:hidden; }
.progress-fill { height:100%; background:linear-gradient(90deg, var(--orange-dark), var(--orange)); border-radius:3px; transition:width 1.5s ease; }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1100px) {
  .services-grid { grid-template-columns:1fr 1fr; }
  .counters-grid { grid-template-columns:repeat(2,1fr); }
  .markets-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .blog-grid { grid-template-columns:1fr 1fr; }
  .footer__grid { grid-template-columns:1fr 1fr; gap:36px; }
  .inner-layout { grid-template-columns:1fr; }
  .sidebar { order:-1; display:grid; grid-template-columns:1fr 1fr; gap:16px; }
}
@media (max-width:850px) {
  .about-strip__grid { grid-template-columns:1fr; }
  .about-strip__badge { bottom:-20px; right:20px; }
  .contact-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:1fr; }
  .feature-boxes { grid-template-columns:1fr; }
  .pillar-cards { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .cta-banner__inner { flex-direction:column; text-align:center; }
}
@media (max-width:768px) {
  .nav__links, .nav__right { display:none; }
  .nav__hamburger { display:flex; }
  .hero__stats { gap:20px; }
  .hero__strip-inner { gap:24px; }
  .section { padding:70px 0; }
  .services-grid { grid-template-columns:1fr; }
  .markets-grid { grid-template-columns:1fr 1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .blog-grid { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr; }
  .footer__bottom { flex-direction:column; text-align:center; }
  .sidebar { grid-template-columns:1fr; }
}
@media (max-width:500px) {
  .markets-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .hero__btns { flex-direction:column; }
  .counters-grid { grid-template-columns:1fr 1fr; }
}
