/* ============================================================
   TECHNOCIL — PREMIUM UI SYSTEM v2
   Font: Plus Jakarta Sans | Style: Enterprise Gateway / Trust & Authority
   ============================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── Design Tokens ── */
:root {
  /* Brand Gold */
  --gold:        #d4a843;
  --gold-bright: #f0c468;
  --gold-dim:    #a07820;
  --gold-pale:   rgba(212,168,67,0.10);
  --gold-glow:   rgba(212,168,67,0.22);
  --gold-border: rgba(212,168,67,0.28);

  /* Dark Surfaces */
  --dark-1: #06080f;
  --dark-2: #0b0f1e;
  --dark-3: #111827;
  --dark-4: #1a2236;
  --glass:  rgba(11,15,30,0.72);

  /* Light Surfaces */
  --bg:      #ffffff;
  --bg-off:  #f8f9fe;
  --bg-tint: #f0f4ff;
  --bg-grey: #f2f5fa;
  --border:  #e2e8f0;

  /* Text */
  --text:   #0f172a;
  --text-2: #475569;
  --text-3: #94a3b8;

  /* Typography */
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Shadows */
  --sh-xs:   0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  --sh-sm:   0 4px 12px rgba(0,0,0,0.07), 0 2px 6px rgba(0,0,0,0.05);
  --sh-md:   0 8px 24px rgba(0,0,0,0.09), 0 3px 10px rgba(0,0,0,0.06);
  --sh-lg:   0 20px 60px rgba(0,0,0,0.14), 0 8px 24px rgba(0,0,0,0.08);
  --sh-gold: 0 8px 32px rgba(212,168,67,0.22), 0 2px 8px rgba(212,168,67,0.12);
  --sh-dark: 0 32px 80px rgba(0,0,0,0.55);

  /* Border Radii */
  --r-xs: 6px;
  --r-sm: 8px;
  --r:    8px;
  --r-lg: 8px;
  --r-xl: 40px;

  /* Site imagery */
  --hero-image: url('https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=2200&q=82');

  /* Transitions */
  --t-fast: 150ms cubic-bezier(0.4,0,0.2,1);
  --t:      250ms cubic-bezier(0.4,0,0.2,1);
  --t-slow: 400ms cubic-bezier(0.4,0,0.2,1);

  /* Layout */
  --nav-h: 72px;
  --mw:    1440px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ── Typography ── */
h1{font-size:3.65rem;font-weight:800;line-height:1.12;letter-spacing:0}
h2{font-size:2.65rem;font-weight:700;line-height:1.18;letter-spacing:0}
h3{font-size:1.55rem;font-weight:700;line-height:1.3;letter-spacing:0}
h4{font-size:1.15rem;font-weight:700;line-height:1.4;letter-spacing:0}
h5{font-size:1rem;font-weight:600;line-height:1.5}
p{font-size:1rem;line-height:1.75;color:var(--text-2)}
.lead{font-size:1.12rem;line-height:1.8;color:var(--text-2)}
.eyebrow{font-size:0.75rem;font-weight:700;letter-spacing:0;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:14px}
.text-center{text-align:center}
.text-white{color:#fff}

/* Gradient text */
.gradient-text{
  background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 50%,var(--gold-dim) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Utility — gold colour (used by legacy <span class="gold"> in hero h1s) */
.gold{color:var(--gold)}
/* line-gold: block display variant used in some heroes */
.line-gold{display:block;color:var(--gold)}

/* Hero gradient overlay class (alias — hero already has dark bg) */
.hero-gradient{background-color:var(--dark-2)}

/* Filtered grid — used by JS filter tabs */
.filtered-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

/* Featured card variant */
.card-featured{
  background:linear-gradient(145deg,var(--dark-3) 0%,var(--dark-2) 100%);
  border:1px solid rgba(212,168,67,0.25);color:#fff;
}
.card-featured .card-icon{background:rgba(212,168,67,0.15);border-color:rgba(212,168,67,0.3)}
.card-featured .card-title{color:#fff}
.card-featured .card-desc{color:rgba(255,255,255,0.6)}
.card-featured .card-link{color:var(--gold-bright)}

/* ── Layout ── */
.container{max-width:var(--mw);margin:0 auto;padding:0 48px}
.section{padding:104px 0}
.section-sm{padding:64px 0}
.section-off{background:var(--bg-off)}
.section-tint{background:var(--bg-tint)}
.section-dark{background:var(--dark-2);color:#fff}
.section-dark p{color:rgba(255,255,255,0.65)}
.section-darkest{background:var(--dark-1);color:#fff}

/* Grid */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.two-col.reversed{direction:rtl}
.two-col.reversed>*{direction:ltr}

/* Spacing */
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}.mt-56{margin-top:56px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-40{margin-bottom:40px}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:9px;padding:14px 28px;
  border-radius:var(--r-xl);font-size:0.9rem;font-weight:700;
  transition:all var(--t);white-space:nowrap;cursor:pointer;
  position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:rgba(255,255,255,0.12);opacity:0;transition:opacity var(--t-fast);
}
.btn:hover::before{opacity:1}

.btn-gold{
  background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%);
  color:var(--dark-1);font-weight:800;
  box-shadow:0 2px 8px rgba(212,168,67,0.3);
}
.btn-gold:hover{
  box-shadow:var(--sh-gold),0 0 0 1px rgba(212,168,67,0.4);
  transform:translateY(-2px);
}
.btn-gold:active{transform:translateY(0)}

.btn-outline{
  border:2px solid var(--gold-border);color:var(--gold);background:transparent;
}
.btn-outline:hover{
  background:var(--gold-pale);border-color:var(--gold);
  transform:translateY(-2px);box-shadow:var(--sh-gold);
}

.btn-ghost-white{
  border:1.5px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.9);background:rgba(255,255,255,0.06);
  backdrop-filter:blur(8px);
}
.btn-ghost-white:hover{
  background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.35);
  transform:translateY(-2px);
}

.btn-dark{background:var(--dark-3);color:#fff}
.btn-dark:hover{background:var(--dark-4);transform:translateY(-2px);box-shadow:var(--sh-md)}

.btn-white{background:#fff;color:var(--dark-1);font-weight:700}
.btn-white:hover{background:rgba(255,255,255,0.92);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.18)}

.btn-sm{padding:10px 20px;font-size:0.85rem}
.btn-lg{padding:17px 36px;font-size:1rem}
.btn-group{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* ── Navigation ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);transition:all var(--t);
}
.nav.scrolled{
  background:rgba(255,255,255,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--border),var(--sh-xs);
}
.nav-transparent.scrolled .nav-logo .logo-text{color:var(--text)}
.nav-transparent.scrolled .nav-link:not(.btn-nav){color:var(--text-2)}

.nav-container{max-width:var(--mw);margin:0 auto;padding:0 48px;height:100%;display:flex;align-items:center;justify-content:space-between}

.nav-logo{display:flex;align-items:center;gap:10px}
.logo-text{font-size:1.35rem;font-weight:800;letter-spacing:0;color:var(--dark-2)}
.logo-text span{color:var(--gold)}
/* Dark hero logo */
.nav-transparent:not(.scrolled) .logo-text{color:#fff}
.nav-transparent:not(.scrolled) .logo-text span{color:var(--gold)}

.nav-menu{display:flex;align-items:center;gap:2px}
.nav-item{display:flex;align-items:center;position:relative}
.nav-link{
  padding:8px 13px;border-radius:var(--r-sm);
  font-size:0.88rem;font-weight:600;color:var(--text-2);
  transition:all var(--t-fast);position:relative;display:inline-flex;align-items:center;gap:7px;
}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link::after{
  content:'';position:absolute;bottom:2px;left:13px;right:13px;
  height:2px;background:var(--gold);border-radius:2px;
  transform:scaleX(0);transform-origin:center;transition:transform var(--t-fast);
}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-transparent:not(.scrolled) .nav-link:not(.btn-nav){color:rgba(255,255,255,0.75)}
.nav-transparent:not(.scrolled) .nav-link:not(.btn-nav):hover{color:var(--gold)}

.btn-nav{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--dark-1) !important;padding:10px 22px;
  border-radius:var(--r-xl);margin-left:8px;font-weight:800;font-size:0.85rem;
  box-shadow:0 2px 12px rgba(212,168,67,0.3);
}
.btn-nav:hover{box-shadow:var(--sh-gold);transform:translateY(-1px)}
.btn-nav::after{display:none}

/* Mega menu */
.mega-menu{
  position:fixed;top:calc(var(--nav-h) - 2px);left:50%;
  width:min(1120px,calc(100vw - 96px));
  transform:translate(-50%,18px) scale(0.98);
  opacity:0;visibility:hidden;pointer-events:none;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border:1px solid rgba(212,168,67,0.22);border-radius:14px;
  box-shadow:0 26px 70px rgba(15,23,42,0.18),0 1px 0 rgba(255,255,255,0.8) inset;
  padding:22px;transition:opacity var(--t),transform var(--t),visibility var(--t);
}
.nav-item.has-mega:hover .mega-menu,.nav-item.has-mega:focus-within .mega-menu,.nav-item.has-mega.open .mega-menu{
  opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0) scale(1);
}
.mega-menu::before{
  content:'';position:absolute;top:-8px;left:0;right:0;height:10px;
}
.mega-shell{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.mega-panel{
  background:linear-gradient(180deg,#fff 0%,#fbfcff 100%);
  border:1px solid var(--border);border-radius:10px;padding:18px;
}
.mega-panel.featured{
  background:linear-gradient(145deg,rgba(214,180,108,0.14),#fff 58%);
  border-color:rgba(214,180,108,0.34);
}
.mega-kicker{font-size:0.72rem;font-weight:800;text-transform:uppercase;color:var(--gold-dim);margin-bottom:12px}
.mega-link{
  display:grid;grid-template-columns:38px 1fr;gap:12px;align-items:start;
  padding:11px;border-radius:8px;transition:background var(--t-fast),transform var(--t-fast);
}
.mega-link:hover{background:var(--gold-pale);transform:translateX(4px)}
.mega-link i{
  width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  color:var(--gold);background:#fff;border:1px solid var(--gold-border);
}
.mega-title{font-size:0.92rem;font-weight:800;color:var(--text);line-height:1.3}
.mega-desc{font-size:0.78rem;color:var(--text-2);line-height:1.45;margin-top:2px}
.mega-cta{
  display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;
  background:var(--dark-1);color:#fff;border-radius:10px;padding:14px 16px;overflow:hidden;position:relative;
}
.mega-cta::after{
  content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(214,180,108,0.18),transparent 60%);
  pointer-events:none;
}
.mega-cta span{position:relative;font-size:0.88rem;font-weight:700}
.mega-cta i{position:relative;color:var(--gold-bright)}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:var(--r-sm);transition:background var(--t-fast)}
.nav-toggle:hover{background:rgba(255,255,255,0.1)}
.nav-toggle span{display:block;width:21px;height:2px;background:currentColor;border-radius:2px;transition:all var(--t)}
.nav-transparent:not(.scrolled) .nav-toggle span{background:#fff}

/* ── Hero ── */
.hero{
  min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;
  padding-top:var(--nav-h);
  background:
    linear-gradient(90deg,rgba(6,8,15,0.88) 0%,rgba(6,8,15,0.74) 46%,rgba(6,8,15,0.38) 100%),
    linear-gradient(180deg,rgba(6,8,15,0.28),rgba(6,8,15,0.82)),
    var(--hero-image) center/cover no-repeat;
}
.hero::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(212,168,67,0.12),transparent 42%),
    linear-gradient(180deg,transparent 70%,rgba(6,8,15,0.84));
}

.hero-inner{
  min-height:680px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding-top:96px;padding-bottom:96px;position:relative;z-index:2;width:100%;
}
.home-hero-inner{
  flex-direction:row;align-items:center;justify-content:space-between;gap:56px;
}
.home-hero-copy{max-width:760px;flex:1;min-width:0}
.hero-sm{min-height:520px;padding:118px 0 88px}
.hero-sm .hero-inner{min-height:auto;padding-top:0;padding-bottom:0}

.hero-orb{display:none}

.hero-tag{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(212,168,67,0.1);border:1px solid var(--gold-border);
  color:var(--gold);padding:8px 18px;border-radius:var(--r-xl);
  font-size:0.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase;
  margin-bottom:28px;backdrop-filter:blur(8px);
}

.hero-title{margin-bottom:24px;color:#fff}
.hero-title .line-gold{display:block}

.hero-desc{
  font-size:1.12rem;line-height:1.85;max-width:560px;
  color:rgba(255,255,255,0.65);margin-bottom:40px;
}

/* Hero stats */
.hero-stats{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin-top:50px;padding-top:34px;
  border-top:1px solid rgba(255,255,255,0.08);width:100%;max-width:760px;
}
.hero-stat{padding:0 22px;border-right:1px solid rgba(255,255,255,0.08);min-width:0}
.hero-stat:first-child{padding-left:0}
.hero-stat:last-child{border-right:none;padding-right:0}
.hero-stat-num{font-size:2.4rem;font-weight:800;color:var(--gold);line-height:1;letter-spacing:0}
.hero-stat-label{font-size:0.8rem;color:rgba(255,255,255,0.5);margin-top:6px;font-weight:500;line-height:1.35}

/* Hero right visual */
.hero-visual{
  position:relative;flex-shrink:0;
}
.hero-card-float{
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-lg);padding:24px;
  box-shadow:var(--sh-dark);
}
.hero-card-float:hover{border-color:rgba(212,168,67,0.2)}

.hero-media-panel{
  width:360px;flex-shrink:0;display:none;
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-dark);background:rgba(255,255,255,0.08);
}
.hero-media-panel img{width:100%;height:430px;object-fit:cover}
.hero-media-panel figcaption{
  display:flex;align-items:center;gap:10px;justify-content:space-between;
  padding:14px 16px;color:rgba(255,255,255,0.8);font-size:0.82rem;
  background:rgba(6,8,15,0.78);border-top:1px solid rgba(255,255,255,0.12);
}
.hero-media-panel b{color:var(--gold-bright)}

@media(min-width:1101px){
  .hero-media-panel{display:block}
}

.service-media{
  height:170px;border-radius:var(--r);overflow:hidden;margin-bottom:20px;
  border:1px solid var(--border);background:var(--bg-off);
}
.service-media img{width:100%;height:100%;object-fit:cover}

/* ── Breadcrumb ── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:rgba(255,255,255,0.45);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,0.45);transition:color var(--t-fast)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(255,255,255,0.2)}

/* ── Cards ── */
.card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px;
  transition:all var(--t);position:relative;overflow:hidden;
}
/* Gradient border on hover via ::before */
.card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  padding:1px;
  background:linear-gradient(145deg,var(--gold),rgba(212,168,67,0.3) 40%,transparent 65%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity var(--t);pointer-events:none;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:rgba(212,168,67,0.15)}
.card:hover::before{opacity:1}

/* Subtle shimmer on hover */
.card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(212,168,67,0.04) 0%,transparent 70%);
  opacity:0;transition:opacity var(--t);pointer-events:none;
}
.card:hover::after{opacity:1}

.card-icon{
  width:52px;height:52px;
  background:linear-gradient(135deg,rgba(212,168,67,0.15) 0%,rgba(212,168,67,0.06) 100%);
  border:1px solid var(--gold-border);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;color:var(--gold);margin-bottom:22px;
  transition:all var(--t);
}
.card:hover .card-icon{background:linear-gradient(135deg,rgba(212,168,67,0.25),rgba(212,168,67,0.1));box-shadow:0 0 20px rgba(212,168,67,0.15)}
.card-title{font-size:1.05rem;font-weight:700;margin-bottom:10px;letter-spacing:0}
.card-desc{font-size:0.92rem;line-height:1.75;color:var(--text-2);margin-bottom:20px}
.card-link{
  font-size:0.88rem;font-weight:700;color:var(--gold);
  display:inline-flex;align-items:center;gap:6px;transition:all var(--t-fast);
  letter-spacing:0;
}
.card-link:hover{gap:10px;color:var(--gold-bright)}

/* Dark cards (glass morphism) */
.card-dark{
  background:rgba(255,255,255,0.03);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.07);
}
.card-dark .card-title{color:#fff}
.card-dark .card-desc{color:rgba(255,255,255,0.55)}
.card-dark:hover{border-color:rgba(212,168,67,0.25);background:rgba(255,255,255,0.05)}

/* Featured / highlighted card */
.card-gold{
  background:linear-gradient(145deg,rgba(212,168,67,0.08),rgba(212,168,67,0.03));
  border-color:var(--gold-border);
}

/* ── Platform Cards ── */
.platform-card{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:36px 28px;
  transition:all var(--t);text-align:center;position:relative;overflow:hidden;
}
.platform-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  padding:1.5px;
  background:linear-gradient(145deg,var(--gold-bright),transparent 55%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity var(--t);pointer-events:none;
}
.platform-card:hover{transform:translateY(-8px);box-shadow:var(--sh-gold);border-color:rgba(212,168,67,0.2)}
.platform-card:hover::before{opacity:1}
.platform-card .p-icon{
  width:64px;height:64px;
  background:linear-gradient(135deg,rgba(212,168,67,0.15),rgba(212,168,67,0.05));
  border:1.5px solid var(--gold-border);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-size:1.55rem;color:var(--gold);
  transition:all var(--t);
}
.platform-card:hover .p-icon{box-shadow:0 0 28px rgba(212,168,67,0.2);transform:scale(1.05)}
.platform-card h4{font-size:1.15rem;margin-bottom:8px;letter-spacing:0}
.platform-card p{font-size:0.88rem;line-height:1.65}
.platform-tag{
  display:inline-block;background:rgba(212,168,67,0.1);
  color:var(--gold-dim);border:1px solid var(--gold-border);
  border-radius:var(--r-xl);padding:4px 14px;font-size:0.78rem;font-weight:700;
  margin-top:16px;letter-spacing:0;
}

/* ── Industry Tiles ── */
.industry-tile{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:28px 20px;text-align:center;
  transition:all var(--t);cursor:pointer;position:relative;overflow:hidden;
}
.industry-tile::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,var(--gold-pale) 0%,transparent 100%);
  opacity:0;transition:opacity var(--t);pointer-events:none;
}
.industry-tile:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--sh-gold)}
.industry-tile:hover::after{opacity:1}
.industry-tile .ind-icon{
  width:58px;height:58px;
  background:var(--bg-off);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:1.5rem;color:var(--gold);
  transition:all var(--t);position:relative;z-index:1;
}
.industry-tile:hover .ind-icon{background:rgba(212,168,67,0.15);box-shadow:0 0 20px rgba(212,168,67,0.15)}
.industry-tile h4{font-size:0.93rem;font-weight:700;position:relative;z-index:1;transition:color var(--t)}
.industry-tile:hover h4{color:var(--gold-dim)}

/* ── Capabilities Strip ── */
.caps-strip{
  padding:0;background:var(--bg);border-bottom:1px solid var(--border);
  overflow:hidden;
}
.caps-inner{
  display:flex;gap:0;
  animation:marqueeScroll 28s linear infinite;
  width:max-content;
}
.caps-inner:hover{animation-play-state:paused}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.caps-marquee{padding:20px 0;overflow:hidden;cursor:default}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 22px;border-radius:var(--r-xl);
  border:1.5px solid var(--border);font-size:0.83rem;font-weight:600;
  color:var(--text-2);transition:all var(--t-fast);background:var(--bg);
  cursor:pointer;white-space:nowrap;flex-shrink:0;margin:0 5px;
}
.chip:hover,.chip.active{border-color:var(--gold);color:var(--gold);background:var(--gold-pale)}
.chip i{font-size:0.88rem}

/* Fallback chips (non-marquee) */
.caps-chips{display:flex;gap:10px;flex-wrap:wrap;padding:20px 0}

/* ── Stats Bar ── */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:40px 24px;text-align:center;border-right:1px solid var(--border)}
.stat-item:last-child{border-right:none}
.stats-bar.dark-bar{border-color:rgba(255,255,255,0.06)}
.stats-bar.dark-bar .stat-item{border-color:rgba(255,255,255,0.06)}
.stat-num{font-size:2.6rem;font-weight:800;color:var(--gold);line-height:1;letter-spacing:0}
.stat-lbl{font-size:0.83rem;color:var(--text-2);margin-top:7px;font-weight:500}
.stat-dark .stat-lbl{color:rgba(255,255,255,0.5)}

/* ── Process Flow ── */
.process-flow{display:flex;align-items:flex-start;gap:0;padding:4px 0 24px;overflow-x:auto}
.process-step{flex:1;min-width:130px;text-align:center;position:relative;padding:0 8px}
.process-step::after{
  content:'';position:absolute;top:23px;left:50%;width:100%;
  height:2px;background:linear-gradient(90deg,var(--gold),rgba(212,168,67,0.2));z-index:0;
}
.process-step:last-child::after{display:none}
.step-num{
  width:48px;height:48px;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--dark-1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:0.92rem;margin:0 auto 16px;
  position:relative;z-index:1;
  box-shadow:0 0 0 6px rgba(212,168,67,0.1),var(--sh-gold);
  transition:all var(--t);
}
.process-step:hover .step-num{transform:scale(1.1);box-shadow:0 0 0 10px rgba(212,168,67,0.1),var(--sh-gold)}
.step-label{font-weight:700;font-size:0.9rem;color:var(--text);margin-bottom:6px;letter-spacing:0}
.step-desc{font-size:0.8rem;color:var(--text-2);line-height:1.6;padding:0 6px}
/* Dark variant */
.section-dark .step-label,.section-darkest .step-label{color:#fff}
.section-dark .step-desc,.section-darkest .step-desc{color:rgba(255,255,255,0.5)}

/* ── Proof / Case Study ── */
.proof-card{
  background:var(--bg);border-radius:var(--r-lg);padding:36px;
  border:1px solid var(--border);position:relative;overflow:hidden;
  transition:all var(--t);
}
.proof-card::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold-dim));
  border-radius:4px 0 0 4px;
}
.proof-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(212,168,67,0.15)}
.proof-metric{font-size:3.2rem;font-weight:800;color:var(--gold);line-height:1;margin-bottom:10px;letter-spacing:0}
.proof-title{font-weight:700;margin-bottom:10px;font-size:1.05rem;letter-spacing:0}
.proof-desc{font-size:0.9rem;color:var(--text-2);line-height:1.75}
.proof-tag{
  display:inline-block;background:var(--gold-pale);
  color:var(--gold-dim);border:1px solid var(--gold-border);
  border-radius:var(--r-xl);padding:5px 14px;font-size:0.78rem;font-weight:700;
  margin-top:18px;letter-spacing:0;
}

/* ── Before/After Table ── */
.ba-table{width:100%;border-collapse:collapse;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}
.ba-table th{padding:16px 24px;font-size:0.88rem;font-weight:700;letter-spacing:0}
.ba-table th:first-child{background:#f8f9fe;color:var(--text-2)}
.ba-table th:nth-child(2){background:#fef5f5;color:#b91c1c}
.ba-table th:nth-child(3){background:var(--dark-2);color:var(--gold)}
.ba-table td{padding:14px 24px;font-size:0.9rem;border-bottom:1px solid var(--border);transition:background var(--t-fast)}
.ba-table tr:hover td{background:var(--bg-off)}
.ba-table td:nth-child(2){color:#dc2626;background:#fef5f5}
.ba-table td:nth-child(3){color:#16a34a;background:#f0fdf4;font-weight:600}
.ba-table tr:last-child td{border-bottom:none}

/* ── FAQ ── */
.faq-item{border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;overflow:hidden;transition:border-color var(--t)}
.faq-item:hover{border-color:rgba(212,168,67,0.25)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px;font-weight:600;font-size:0.96rem;text-align:left;
  transition:all var(--t-fast);background:var(--bg);cursor:pointer;letter-spacing:0;
}
.faq-q:hover{background:var(--bg-off);color:var(--gold)}
.faq-q.open{color:var(--gold);background:var(--gold-pale)}
.faq-q i{transition:transform var(--t);color:var(--text-3);font-size:0.85rem;flex-shrink:0}
.faq-q.open i{transform:rotate(45deg);color:var(--gold)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:max-height 0.45s cubic-bezier(0.4,0,0.2,1),padding 0.3s}
.faq-a.open{max-height:400px;padding:0 24px 22px}
.faq-a p{font-size:0.93rem;color:var(--text-2);line-height:1.8}

/* ── Forms ── */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:0.85rem;font-weight:700;margin-bottom:8px;color:var(--text);letter-spacing:0}
.form-input{
  width:100%;padding:13px 18px;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-size:0.94rem;color:var(--text);background:var(--bg);
  transition:all var(--t-fast);
}
.form-input:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(212,168,67,0.12);
}
.form-input::placeholder{color:var(--text-3)}
textarea.form-input{min-height:130px;resize:vertical;line-height:1.7}
select.form-input{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:44px;cursor:pointer;
}

/* ── Tags ── */
.tag{display:inline-block;padding:5px 14px;border-radius:var(--r-xl);font-size:0.78rem;font-weight:700;letter-spacing:0}
.tag-gold{background:var(--gold-pale);color:var(--gold-dim);border:1px solid var(--gold-border)}
.tag-dark{background:var(--dark-3);color:rgba(255,255,255,0.75)}
.tag-green{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}
.tags{display:flex;flex-wrap:wrap;gap:8px}

/* ── Filter Tabs ── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}
.filter-btn{
  padding:9px 20px;border-radius:var(--r-xl);font-size:0.86rem;font-weight:600;
  border:1.5px solid var(--border);color:var(--text-2);background:var(--bg);
  transition:all var(--t-fast);cursor:pointer;
}
.filter-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-pale)}
.filter-btn.active{border-color:var(--gold);color:var(--dark-1);background:linear-gradient(135deg,var(--gold-bright),var(--gold));box-shadow:var(--sh-gold)}

/* ── Icon List ── */
.icon-list{display:flex;flex-direction:column;gap:14px}
.icon-list-item{display:flex;align-items:flex-start;gap:14px;font-size:0.95rem;line-height:1.6}
.icon-list-item i{color:var(--gold);font-size:0.95rem;margin-top:3px;flex-shrink:0}

/* ── Challenges ── */
.challenges-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.challenge-item{
  background:var(--bg);border:1px solid var(--border);
  border-left:3px solid var(--gold);border-radius:var(--r);
  padding:24px;transition:all var(--t);
}
.challenge-item:hover{box-shadow:var(--sh-sm);transform:translateY(-2px)}
.challenge-item h5{margin-bottom:10px;font-size:0.97rem;display:flex;align-items:center;gap:8px}
.challenge-item p{font-size:0.88rem;line-height:1.7}

/* ── Engagement Cards ── */
.engage-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.engage-card{
  border:2px solid var(--border);border-radius:var(--r-lg);
  padding:36px 28px;transition:all var(--t);position:relative;overflow:hidden;
}
.engage-card:hover{border-color:var(--gold-border);transform:translateY(-4px);box-shadow:var(--sh-md)}
.engage-card.featured{
  border-color:var(--gold);
  background:linear-gradient(155deg,rgba(212,168,67,0.07) 0%,transparent 60%);
}
.engage-card.featured::after{
  content:'★ Most Popular';position:absolute;top:16px;right:-28px;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--dark-1);font-size:0.7rem;font-weight:800;letter-spacing:0;
  padding:5px 40px;transform:rotate(35deg);
}
.engage-card h4{margin-bottom:6px;letter-spacing:0}
.engage-card .engage-badge{font-size:0.73rem;font-weight:800;text-transform:uppercase;letter-spacing:0;color:var(--gold);margin-bottom:18px;display:block}
.engage-card ul li{
  font-size:0.9rem;color:var(--text-2);padding:8px 0;
  border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:10px;line-height:1.5;
}
.engage-card ul li:last-child{border-bottom:none}
.engage-card ul li::before{content:'✓';color:var(--gold);font-weight:800;font-size:0.82rem;flex-shrink:0;margin-top:1px}

/* ── Department Map ── */
.dept-map{
  background:var(--dark-1);border-radius:var(--r-lg);padding:56px 40px;
  text-align:center;position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,0.05);
}
.dept-map::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(212,168,67,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,67,0.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.dept-map-center{
  width:110px;height:110px;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-dim));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 44px;font-weight:800;font-size:0.85rem;color:var(--dark-1);
  text-align:center;line-height:1.3;position:relative;z-index:1;
  box-shadow:0 0 0 16px rgba(212,168,67,0.07),0 0 0 32px rgba(212,168,67,0.03),var(--sh-gold);
  animation:pulseSoft 3s ease-in-out infinite;
}
@keyframes pulseSoft{0%,100%{box-shadow:0 0 0 16px rgba(212,168,67,0.07),0 0 0 32px rgba(212,168,67,0.03),var(--sh-gold)}50%{box-shadow:0 0 0 24px rgba(212,168,67,0.1),0 0 0 48px rgba(212,168,67,0.04),var(--sh-gold)}}
.dept-map-nodes{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;position:relative;z-index:1}
.dept-node{
  background:rgba(255,255,255,0.04);border:1px solid rgba(212,168,67,0.2);
  border-radius:var(--r);padding:20px 16px;width:176px;text-align:center;
  transition:all var(--t);cursor:pointer;
}
.dept-node:hover{background:rgba(212,168,67,0.08);border-color:var(--gold);transform:translateY(-3px)}
.dept-node i{font-size:1.35rem;color:var(--gold);margin-bottom:10px;display:block}
.dept-node span{font-size:0.8rem;font-weight:600;color:rgba(255,255,255,0.75);line-height:1.4}

/* ── CTA Band ── */
.cta-band{
  background:var(--dark-1);padding:96px 0;text-align:center;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(212,168,67,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,67,0.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
}
.cta-band h2{color:#fff;margin-bottom:18px}
.cta-band p{color:rgba(255,255,255,0.6);font-size:1.05rem;margin-bottom:40px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-band .orb{display:none}
.cta-band .orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(212,168,67,0.15),transparent 70%);right:-150px;top:-100px}
.cta-band .orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(99,102,241,0.1),transparent 70%);left:-80px;bottom:-80px}
.cta-split{
  display:grid;grid-template-columns:1fr 0.9fr;gap:44px;align-items:center;text-align:left;
}
.cta-split h2,.cta-split p{margin-left:0;margin-right:0}
.cta-mini-form{
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-lg);padding:24px;backdrop-filter:blur(14px);
}
.cta-mini-form .form-input{
  background:rgba(255,255,255,0.95);border-color:rgba(255,255,255,0.16);
}

/* ── Client Logos ── */
.clients-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.client-logo{
  font-size:0.98rem;font-weight:800;letter-spacing:0;color:var(--text-3);
  padding:12px 24px;border:1.5px solid var(--border);border-radius:var(--r);
  transition:all var(--t);cursor:default;
}
.client-logo:hover{color:var(--gold);border-color:var(--gold-border);background:var(--gold-pale)}

/* ── Resource Cards ── */
.resource-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:all var(--t);
}
.resource-card:hover{border-color:var(--gold-border);box-shadow:var(--sh-lg);transform:translateY(-5px)}
.resource-card .rc-img{
  height:180px;background:var(--bg-off);
  display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--gold);
  position:relative;overflow:hidden;
}
.resource-card .rc-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--gold-pale) 0%,transparent 100%);opacity:0;
  transition:opacity var(--t);
}
.resource-card:hover .rc-img::after{opacity:1}
.resource-card .rc-body{padding:24px}
.resource-card .rc-type{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0;color:var(--gold);margin-bottom:12px}
.resource-card h4{font-size:1.03rem;margin-bottom:10px;letter-spacing:0;line-height:1.4}
.resource-card p{font-size:0.9rem;color:var(--text-2);line-height:1.7}

/* ── Contact Info ── */
.contact-info-item{display:flex;align-items:flex-start;gap:18px;padding:24px 0;border-bottom:1px solid var(--border)}
.contact-info-item:last-child{border-bottom:none}
.ci-icon{
  width:46px;height:46px;flex-shrink:0;
  background:var(--gold-pale);border:1px solid var(--gold-border);
  border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:1.05rem;transition:all var(--t);
}
.contact-info-item:hover .ci-icon{background:rgba(212,168,67,0.2);transform:scale(1.05)}
.ci-label{font-size:0.8rem;color:var(--text-3);margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:0}
.ci-value{font-weight:700;font-size:0.97rem;letter-spacing:0}

.section-image{
  min-height:360px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);
  box-shadow:var(--sh-md);background:var(--bg-off);
}
.section-image img{width:100%;height:100%;min-height:360px;object-fit:cover}

/* ── Divider ── */
.divider{height:1px;background:var(--border);margin:32px 0}
.divider-gold{background:linear-gradient(90deg,transparent,var(--gold),transparent);height:1.5px}

/* ── Misc ── */
.section-title{margin-bottom:16px}
.section-sub{font-size:1.08rem;color:var(--text-2);max-width:580px;margin-bottom:52px;line-height:1.8}
.section-sub.center{margin-left:auto;margin-right:auto;text-align:center}

/* Section label line */
.section-label{
  display:flex;align-items:center;gap:14px;margin-bottom:14px;
}
.section-label::before{
  content:'';display:block;width:32px;height:3px;
  background:linear-gradient(90deg,var(--gold-bright),var(--gold));
  border-radius:3px;flex-shrink:0;
}

/* Social buttons */
.social-btn{
  width:40px;height:40px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:0.95rem;transition:all var(--t);background:rgba(255,255,255,0.07);
  color:rgba(255,255,255,0.6);
}
.social-btn:hover{background:var(--gold);color:var(--dark-1);transform:translateY(-2px)}

/* ── Footer ── */
.footer{background:var(--dark-1);color:rgba(255,255,255,0.65);padding:80px 0 0;position:relative;overflow:hidden}
.footer::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(212,168,67,0.04) 0%,transparent 60%);
}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.06);position:relative}
.footer-brand .logo-text{color:#fff;font-size:1.5rem}
.footer-brand p{font-size:0.9rem;line-height:1.75;margin-top:16px;max-width:280px;color:rgba(255,255,255,0.5)}
.footer-social{display:flex;gap:10px;margin-top:24px}
.footer-heading{font-size:0.75rem;font-weight:800;letter-spacing:0;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:0.9rem;color:rgba(255,255,255,0.55);transition:all var(--t-fast)}
.footer-links a:hover{color:var(--gold);padding-left:4px}
.footer-links span{color:rgba(255,255,255,0.35);font-size:0.87rem;line-height:1.75}
.footer-bottom{
  padding:24px 0;display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;font-size:0.83rem;color:rgba(255,255,255,0.3);
  position:relative;
}
.footer-bottom a{color:rgba(255,255,255,0.35);transition:color var(--t-fast)}
.footer-bottom a:hover{color:var(--gold)}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.94)}to{opacity:1;transform:scale(1)}}
@keyframes slideRight{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}

.animate-up{opacity:0;transform:translateY(28px);transition:opacity 0.65s cubic-bezier(0.4,0,0.2,1),transform 0.65s cubic-bezier(0.4,0,0.2,1)}
.animate-up.visible{opacity:1;transform:translateY(0)}
.animate-delay-1{transition-delay:0.1s}
.animate-delay-2{transition-delay:0.2s}
.animate-delay-3{transition-delay:0.3s}
.animate-delay-4{transition-delay:0.4s}
.animate-delay-5{transition-delay:0.5s}

/* Hover lift */
.hover-lift{transition:transform var(--t),box-shadow var(--t)}
.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}

/* ── Preloader ── */
.tc-preloader{
  position:fixed;inset:0;z-index:3000;display:grid;place-items:center;
  background:
    radial-gradient(circle at 50% 42%,rgba(214,180,108,0.16),transparent 32%),
    linear-gradient(180deg,#fff 0%,#f8f9fe 100%);
  transition:opacity 0.7s ease,visibility 0.7s ease;
}
.tc-preloader.done{opacity:0;visibility:hidden}
.tc-preloader-stage{position:relative;width:min(360px,86vw);height:min(360px,86vw);display:grid;place-items:center}
.tc-preloader-ring{
  position:absolute;border-radius:50%;border:1px solid rgba(214,180,108,0.28);
  animation:tcSpin 8s linear infinite;
}
.tc-preloader-ring.one{inset:16px;border-top-color:var(--gold);border-right-color:var(--gold-bright)}
.tc-preloader-ring.two{inset:54px;animation-duration:6s;animation-direction:reverse;border-bottom-color:var(--gold)}
.tc-preloader-ring.three{inset:92px;animation-duration:4.5s;border-left-color:var(--gold-bright)}
.tc-loader-core{
  width:118px;height:118px;border-radius:50%;display:grid;place-items:center;text-align:center;
  background:linear-gradient(145deg,#fff,#fff8e8);border:1px solid var(--gold-border);
  box-shadow:0 18px 50px rgba(214,180,108,0.24),inset 0 0 0 10px rgba(214,180,108,0.08);
  color:var(--dark-1);font-weight:900;font-size:1rem;line-height:1.2;
}
.tc-loader-core span{display:block;color:var(--gold-dim);font-size:0.72rem;font-weight:800}
.tc-loader-chip{
  position:absolute;display:flex;align-items:center;gap:7px;background:rgba(255,255,255,0.9);
  border:1px solid var(--gold-border);border-radius:999px;padding:8px 12px;
  color:var(--text);font-size:0.78rem;font-weight:800;box-shadow:var(--sh-sm);
  animation:tcFloat 2.4s ease-in-out infinite;
}
.tc-loader-chip i{color:var(--gold)}
.tc-loader-chip:nth-child(5){top:18px;left:22px}
.tc-loader-chip:nth-child(6){top:54px;right:4px;animation-delay:0.2s}
.tc-loader-chip:nth-child(7){bottom:54px;left:0;animation-delay:0.4s}
.tc-loader-chip:nth-child(8){bottom:20px;right:28px;animation-delay:0.6s}
.tc-loader-line{
  position:absolute;bottom:0;left:50%;width:180px;height:3px;transform:translateX(-50%);
  background:rgba(214,180,108,0.18);border-radius:999px;overflow:hidden;
}
.tc-loader-line::after{
  content:'';position:absolute;inset:0;width:46%;border-radius:inherit;
  background:linear-gradient(90deg,var(--gold-bright),var(--gold));
  animation:tcLoad 1.5s ease-in-out infinite;
}
@keyframes tcSpin{to{transform:rotate(360deg)}}
@keyframes tcFloat{50%{transform:translateY(-8px)}}
@keyframes tcLoad{0%{transform:translateX(-110%)}100%{transform:translateX(230%)}}

/* ── Sticky contact widget ── */
.sticky-contact{
  position:fixed;right:24px;bottom:24px;z-index:1200;
  display:flex;flex-direction:column;align-items:flex-end;gap:12px;
}
.sticky-contact-panel{
  display:flex;flex-direction:column;gap:10px;opacity:0;visibility:hidden;
  transform:translateY(12px) scale(0.96);transform-origin:bottom right;
  transition:opacity var(--t),transform var(--t),visibility var(--t);
}
.sticky-contact.open .sticky-contact-panel{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.sticky-contact-link{
  width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:#fff;color:var(--text);border:1px solid var(--gold-border);box-shadow:var(--sh-md);
  transition:transform var(--t-fast),background var(--t-fast),color var(--t-fast);
}
.sticky-contact-link:hover{transform:translateY(-3px);background:var(--gold);color:var(--dark-1)}
.sticky-contact-toggle{
  width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:var(--dark-1);
  box-shadow:0 16px 42px rgba(214,180,108,0.38);font-size:1.35rem;position:relative;
}
.sticky-contact-toggle::before{
  content:'';position:absolute;inset:-7px;border:1px solid rgba(214,180,108,0.42);
  border-radius:inherit;animation:tcPulse 1.8s ease-out infinite;
}
.sticky-contact.open .sticky-contact-toggle i{transform:rotate(45deg)}
.sticky-contact-toggle i{transition:transform var(--t)}
@keyframes tcPulse{0%{transform:scale(0.86);opacity:0.85}100%{transform:scale(1.2);opacity:0}}

/* ── Responsive ── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-5{grid-template-columns:repeat(3,1fr)}
  .filtered-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .stats-bar .stat-item:nth-child(2){border-right:none}
  .two-col{gap:44px}
  .home-hero-inner{gap:36px}
  .hero-media-panel{width:300px}
  .hero-media-panel img{height:380px}
  .hero-stats{grid-template-columns:repeat(2,minmax(0,1fr));max-width:560px;row-gap:20px}
  .hero-stat:nth-child(2){border-right:none;padding-right:0}
  .hero-stat:nth-child(3){padding-left:0}
}
@media(max-width:1100px){
  .nav-menu{
    position:fixed;top:var(--nav-h);left:0;right:0;
    background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
    flex-direction:column;align-items:stretch;padding:18px 28px 24px;gap:4px;
    transform:translateY(-115%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
    box-shadow:var(--sh-lg);max-height:calc(100vh - var(--nav-h));overflow:auto;
  }
  .nav-menu.open{transform:translateY(0)}
  .nav-item{width:100%;display:block}
  .nav-link{width:100%;padding:13px 16px;border-radius:var(--r-sm);color:var(--text-2) !important}
  .nav-link::after{display:none}
  .btn-nav{text-align:center;margin:8px 0 0;width:100%;justify-content:center;color:var(--dark-1) !important}
  .nav-toggle{display:flex}
  .hero-media-panel{display:none !important}
  .mega-menu{
    position:static;width:100%;padding:0;border:0;border-radius:0;box-shadow:none;background:transparent;
    opacity:1;visibility:visible;pointer-events:auto;transform:none;max-height:0;overflow:hidden;
    transition:max-height 0.35s ease;
  }
  .nav-item.has-mega:hover .mega-menu,.nav-item.has-mega:focus-within .mega-menu,.nav-item.has-mega.open .mega-menu{
    transform:none;
  }
  .nav-item.has-mega.open .mega-menu{max-height:1600px}
  .mega-shell{grid-template-columns:1fr;gap:10px;padding:8px 0 14px}
  .mega-panel{padding:12px;background:#fff}
  .mega-link{grid-template-columns:34px 1fr;padding:9px}
  .mega-link i{width:34px;height:34px}
}
@media(max-width:768px){
  :root{--nav-h:64px}
  h1{font-size:2.45rem}
  h2{font-size:2rem}
  h3{font-size:1.35rem}
  .section{padding:72px 0}
  .container,.nav-container{padding-left:24px;padding-right:24px}
  .hero{background-position:center}
  .home-hero-inner{display:flex;flex-direction:column;align-items:flex-start;gap:28px}
  .home-hero-copy{max-width:100%;width:100%}
  .hero-title{width:100%}
  .hero-inner{padding-top:72px;padding-bottom:72px;min-height:auto}
  .hero-sm{padding:112px 0 72px;min-height:auto}
  .hero-desc{font-size:1rem;line-height:1.75;max-width:100%}
  .hero-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 0;margin-top:36px;padding-top:28px;max-width:100%}
  .hero-stat{padding:0 16px;border-right:1px solid rgba(255,255,255,0.08)}
  .hero-stat:first-child{padding-left:0}
  .hero-stat:nth-child(2){border-right:none;padding-right:0}
  .hero-stat:nth-child(3){padding-left:0}
  .grid-2,.grid-3,.grid-5,.filtered-grid{grid-template-columns:1fr}
  .engage-cards,.challenges-list{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .two-col.reversed{direction:ltr}
  .process-step{min-width:100px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .engage-card.featured::after{display:none}
  .hero-stat-num{font-size:1.8rem}
  .dept-map-nodes{flex-direction:column;align-items:center}
  .cta-split{grid-template-columns:1fr;text-align:center}
  .cta-split h2,.cta-split p{margin-left:auto;margin-right:auto}
  .sticky-contact{right:18px;bottom:18px}
  .sticky-contact-toggle{width:56px;height:56px}
}
@media(max-width:480px){
  h1{font-size:2rem}
  h2{font-size:1.6rem}
  .btn{padding:12px 22px;font-size:0.88rem}
  .btn-group{flex-direction:column;align-items:stretch}
  .btn-group .btn{justify-content:center}
  .stats-bar{grid-template-columns:1fr}
  .stats-bar .stat-item{border-right:none;border-bottom:1px solid var(--border)}
  .container,.nav-container{padding-left:20px;padding-right:20px}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr}
  .hero-stat{border:none;padding:16px 0}
  .hero-stat:nth-child(odd){padding-left:0}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}

/* ── Reduced Motion ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
  .caps-inner{animation:none}
  .dept-map-center{animation:none}
}
