/* =========================================================
   Technuell Services – Shared Stylesheet (Multi-Page)
   Brand: Gold #E8A000 | Dark Navy #1A1A2E
   Design inspiration: technobell.eu (Gilroy-style → Plus Jakarta Sans)
   ========================================================= */

:root {
  --accent:       #E8A000;
  --accent-light: #FFB800;
  --accent-dark:  #C47F00;
  --dark:         #1A1A2E;
  --dark-2:       #2a2a3a;
  --dark-3:       #2e2e42;
  --light-bg:     #ffffff;
  --light-alt:    #f7f6f3;
  --text-main:    #1a1a2e;
  --text-muted:   #6b7280;
  --white:        #ffffff;
  --border:       #e5e7eb;
  --shadow-sm:    0 2px 10px rgba(0,0,0,0.06);
  --shadow-md:    0 8px 32px rgba(0,0,0,0.10);
  --shadow-lg:    0 20px 56px rgba(0,0,0,0.14);
  --radius:       10px;
  --radius-lg:    16px;
  --transition:   all 0.3s cubic-bezier(0.4,0,0.2,1);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Plus Jakarta Sans', sans-serif; color: var(--text-main); background: var(--white); overflow-x: hidden; line-height: 1.78; font-size: 18px; font-weight: 500; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }
img { max-width: 100%; }
a { text-decoration: none; color: inherit; }
.text-accent { color: var(--accent) !important; }

/* ── Buttons ─────────────────────────────────── */
.btn-accent {
  background: var(--accent);
  color: #111;
  border: 2px solid var(--accent);
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .04em;
  border-radius: var(--radius);
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-accent:hover, .btn-accent:focus {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232,160,0,.35);
}
.btn-outline-accent {
  background: transparent;
  color: var(--accent);
  border: 2px solid var(--accent);
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .04em;
  border-radius: var(--radius);
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-outline-accent:hover {
  background: var(--accent);
  color: #111;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232,160,0,.3);
}

/* ── Section typography ──────────────────────── */
.section-padding { padding: 108px 0; }
.section-label {
  display: inline-block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.section-label.light { color: rgba(232,160,0,.9); }
.section-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -.02em;
  color: var(--dark);
  margin-bottom: 18px;
}
.section-title.text-white { color: #fff; }
.section-desc { color: var(--text-muted); font-size: 1rem; max-width: 640px; margin: 0 auto; line-height: 1.78; }

/* ── Dark CTA Strip (technobell "Want to know more?") ── */
.cta-strip {
  background: var(--dark);
  padding: 72px 0;
}
.cta-strip .cta-strip-label {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.cta-strip h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.02em;
  color: #fff;
  margin-bottom: 10px;
}
.cta-strip p {
  color: rgba(255,255,255,.55);
  font-size: 1rem;
  max-width: 520px;
  margin: 0 auto 28px;
  line-height: 1.75;
}
.btn-cta-strip {
  background: var(--accent);
  color: #111;
  border: 2px solid var(--accent);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .04em;
  border-radius: var(--radius);
  padding: 13px 30px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  transition: var(--transition);
}
.btn-cta-strip:hover {
  background: transparent;
  color: var(--accent);
  transform: translateY(-2px);
}

/* ── Page banner ─────────────────────────── */
/* Add top offset on inner pages to clear the fixed white nav */
body:not(.home-page) { padding-top: 72px; }
.page-banner { position: relative; min-height: 320px; display: flex; align-items: flex-end; overflow: hidden; padding-top: 48px; padding-bottom: 48px; margin-top: 0; }
.page-banner-bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: brightness(.38); }
.page-banner-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(26,26,46,.78) 0%, rgba(26,26,46,.62) 100%); }
.page-banner-content { position: relative; z-index: 2; }
.page-banner h1 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: clamp(2rem,5vw,3rem); font-weight: 800; letter-spacing: -.025em; color: #fff; margin-bottom: 10px; }
.page-banner p { color: rgba(255,255,255,.75); font-size: 1.05rem; margin: 0; }
.breadcrumb-bar { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); display: inline-flex; gap: 6px; align-items: center; padding: 5px 14px; border-radius: 50px; margin-bottom: 14px; }
.breadcrumb-bar a, .breadcrumb-bar span { font-size: .78rem; font-weight: 500; color: rgba(255,255,255,.7); }
.breadcrumb-bar a:hover { color: var(--accent); }
.breadcrumb-bar .sep { color: rgba(255,255,255,.3); }

/* ── Animations ─────────────────────────── */
@keyframes fadeIn  { from { opacity:0; transform:translateY(20px) } to { opacity:1; transform:none } }
@keyframes slideUp { from { opacity:0; transform:translateY(40px) } to { opacity:1; transform:none } }
@keyframes pulseRing { 0% { transform:scale(.95); box-shadow:0 0 0 0 rgba(232,160,0,.5) } 70% { transform:scale(1); box-shadow:0 0 0 14px rgba(232,160,0,0) } 100% { transform:scale(.95); box-shadow:0 0 0 0 rgba(232,160,0,0) } }
@keyframes scrollBounce { 0%,100% { transform:translateY(0); opacity:1 } 50% { transform:translateY(10px); opacity:.4 } }
.animate-fade-in  { animation: fadeIn  .8s ease both; }
.animate-slide-up { animation: slideUp .85s ease both; }
.delay-1 { animation-delay: .2s; }
.delay-2 { animation-delay: .4s; }
.delay-3 { animation-delay: .6s; }
.reveal { opacity:0; transform:translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity:1; transform:none; }

/* =========================================================
   NAVBAR — always white, Technobell-style
   ========================================================= */
#mainNav {
  background: #ffffff !important;
  border-bottom: 1px solid #eeecea;
  transition: var(--transition);
  padding: 0;
  z-index: 1050;
  box-shadow: 0 2px 16px rgba(0,0,0,.07);
}

/* Logo-only navbar brand */
.nav-logo-img {
  height: 48px;
  width: auto;
  display: block;
  transition: var(--transition);
}

/* Footer logo (kept for any footer refs) */
.brand-logo { width: 46px; height: 46px; border-radius: 50%; overflow: hidden; border: 2px solid var(--accent); flex-shrink: 0; background: var(--dark); display: flex; align-items: center; justify-content: center; }
.brand-logo img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.brand-logo.sm { width: 36px; height: 36px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.1rem; font-weight: 800; color: var(--dark); }
.brand-sub  { font-size: .68rem; font-weight: 500; color: var(--accent); letter-spacing: .12em; text-transform: uppercase; }

/* Vertically center all items (needed so the Contact button aligns with the text links) */
.navbar-nav { align-items: center; }

/* Nav links — dark text on white */
.navbar-nav .nav-link {
  font-size: .9rem;
  font-weight: 600;
  color: var(--dark) !important;
  padding: 28px 14px !important;
  border-radius: 0;
  transition: var(--transition);
  position: relative;
  letter-spacing: .01em;
}
/* Underline hover effect like Technobell */
.navbar-nav .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 14px; right: 14px;
  height: 3px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .25s ease;
  border-radius: 3px 3px 0 0;
}
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { transform: scaleX(1); }
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active { color: var(--dark) !important; background: transparent; }

/* "Contact" CTA button on the right */
.navbar-nav .btn-nav-contact {
  background: var(--accent) !important;
  color: #111 !important;
  font-weight: 700 !important;
  padding: 10px 22px !important;
  border-radius: var(--radius) !important;
  margin-left: 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .88rem !important;
  letter-spacing: .02em;
}
.navbar-nav .btn-nav-contact::after { display: none; }
.navbar-nav .btn-nav-contact:hover {
  background: var(--accent-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(232,160,0,.35);
}

/* Mobile collapse — white background, dark text, full width */
@media (max-width: 991.98px) {
  .navbar-collapse,
  .navbar-collapse.show,
  .navbar-collapse.collapsing,
  #navbarNav,
  #navbarNav.show {
    background: #ffffff !important;
    border-radius: 0 0 var(--radius) var(--radius) !important;
    padding: 12px 16px 16px !important;
    border-top: 2px solid var(--accent) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
    width: 100% !important;
  }
  .navbar-nav {
    align-items: stretch !important;
    width: 100% !important;
  }
  .navbar-nav .nav-link {
    padding: 13px 16px !important;
    color: var(--dark) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: var(--radius) !important;
    width: 100% !important;
    display: block !important;
    background: transparent !important;
  }
  .navbar-nav .nav-link:hover,
  .navbar-nav .nav-link.active {
    background: rgba(232,160,0,.1) !important;
    color: var(--dark) !important;
  }
  .navbar-nav .nav-link::after { display: none !important; }
  .navbar-nav .btn-nav-contact { margin-left: 0 !important; margin-top: 8px !important; width: 100% !important; justify-content: center !important; }
}

/* =========================================================
   HERO (Home) — clean split layout, friendly size
   ========================================================= */
.hero-section {
  min-height: 600px;
  margin-top: 72px; /* clear fixed white nav */
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  background: var(--dark);
}

.hero-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center 30%;
  transform: scale(1.04);
  transition: transform 8s ease;
}
.hero-section:hover .hero-bg { transform: scale(1); }

.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(105deg, rgba(26,26,46,.97) 0%, rgba(26,26,46,.88) 55%, rgba(26,26,46,.45) 100%);
}

.hero-content { position: relative; z-index: 2; padding-top: 60px; padding-bottom: 60px; }
@media (max-width: 991.98px) {
  .hero-content { padding-top: 48px; padding-bottom: 48px; }
}
@media (max-width: 575.98px) {
  .hero-content { padding-top: 36px; padding-bottom: 40px; }
}

/* badge */
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(232,160,0,.12);
  border: 1px solid rgba(232,160,0,.35);
  color: var(--accent-light);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .08em;
  padding: 8px 18px;
  border-radius: 50px;
}
.hero-badge-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(232,160,0,.5);
  animation: badgePulse 2s infinite;
  flex-shrink: 0;
}
@keyframes badgePulse {
  0%   { box-shadow: 0 0 0 0 rgba(232,160,0,.5); }
  70%  { box-shadow: 0 0 0 8px rgba(232,160,0,0); }
  100% { box-shadow: 0 0 0 0 rgba(232,160,0,0); }
}

/* title */
.hero-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(2.4rem, 5.5vw, 3.8rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 22px;
  letter-spacing: -.03em;
}

.hero-desc {
  color: rgba(255,255,255,.72);
  font-size: 1.1rem;
  max-width: 480px;
  margin-bottom: 32px;
  line-height: 1.75;
}

.btn-hero-outline {
  background: transparent;
  border: 2px solid rgba(255,255,255,.3);
  color: #fff;
  border-radius: 8px;
  font-weight: 600;
  transition: var(--transition);
}
.btn-hero-outline:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(232,160,0,.08);
}

/* Right-side product image */
.hero-img-wrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 2px solid rgba(255,255,255,.1);
  height: 420px;
}
.hero-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .6s ease;
}
.hero-img-wrap:hover img { transform: scale(1.04); }
.hero-img-label {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(26,26,46,.92) 0%, transparent 100%);
  color: #fff;
  font-size: .85rem;
  font-weight: 600;
  padding: 32px 20px 16px;
}

/* scroll cue */
.hero-scroll {
  position: absolute;
  bottom: 36px; left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 3;
}
.hero-scroll-mouse {
  width: 24px; height: 38px;
  border: 2px solid rgba(255,255,255,.35);
  border-radius: 12px;
  display: flex;
  justify-content: center;
  padding-top: 6px;
}
.hero-scroll-wheel {
  width: 4px; height: 8px;
  background: var(--accent);
  border-radius: 4px;
  animation: wheelScroll 1.6s ease infinite;
}
@keyframes wheelScroll {
  0%   { transform: translateY(0);   opacity: 1; }
  80%  { transform: translateY(12px); opacity: 0; }
  100% { transform: translateY(0);   opacity: 0; }
}
.hero-scroll-text {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
}

/* responsive hero */
@media (max-width: 1199.98px) {
  .hero-mosaic { height: 440px; grid-template-columns: 1fr 150px; }
}
@media (max-width: 991.98px) {
  .hero-title { font-size: 2.2rem; }
  .hero-stats { padding: 16px 20px; }
  .hero-stat { padding: 0 14px; }
  .hero-stat-num { font-size: 1.6rem; }
}
@media (max-width: 767.98px) {
  .hero-title { font-size: 2rem; }
  .hero-desc { font-size: 1rem; }
  .hero-stats { flex-wrap: wrap; gap: 10px; justify-content: center; width: 100%; }
  .hero-divider { display: none; }
  .hero-stat { padding: 8px 16px; border: 1px solid rgba(255,255,255,.1); border-radius: 8px; }
}

/* =========================================================
   GENERIC CARDS
   ========================================================= */
.feature-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px 28px; transition:var(--transition); position:relative; overflow:hidden; height:100%; }
.feature-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--accent),var(--accent-light)); transform:scaleX(0); transform-origin:left; transition:var(--transition); }
.feature-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:rgba(232,160,0,.25); }
.feature-card:hover::before { transform:scaleX(1); }
.feature-icon { width:52px; height:52px; background:rgba(232,160,0,.1); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; transition:var(--transition); }
.feature-card:hover .feature-icon { background:var(--accent); }
.feature-icon i { font-size:1.4rem; color:var(--accent); transition:var(--transition); }
.feature-card:hover .feature-icon i { color:#111; }
.feature-card h5 { font-weight:700; margin-bottom:10px; letter-spacing:-.01em; }
.feature-card p  { color:var(--text-muted); font-size:.92rem; margin-bottom:14px; }
.feature-link { font-size:.84rem; font-weight:700; color:var(--accent); display:inline-flex; align-items:center; gap:4px; transition:var(--transition); letter-spacing:.02em; }
.feature-link:hover { gap:8px; color:var(--accent-dark); }

.img-card { border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); transition:var(--transition); }
.img-card:hover { transform:scale(1.015); box-shadow:var(--shadow-lg); }
.img-card img { width:100%; height:100%; object-fit:cover; display:block; }

.check-list { list-style:none; padding:0; margin:20px 0; }
.check-list li { display:flex; align-items:center; gap:10px; padding:7px 0; font-size:.95rem; border-bottom:1px solid var(--border); }
.check-list li:last-child { border-bottom:none; }
.check-list li i { color:var(--accent); flex-shrink:0; }

.info-card-dark { background: var(--white); border: 1px solid var(--border); border-radius:var(--radius-lg); padding:40px 36px; color:var(--dark); position:relative; overflow:hidden; box-shadow: var(--shadow-sm); }
.info-card-dark::after { content:''; position:absolute; top:-40px; right:-40px; width:180px; height:180px; border-radius:50%; background:rgba(232,160,0,.06); }
.info-card-dark h4 { font-weight:700; margin-bottom:12px; color: var(--dark); }
.info-card-dark p  { color: var(--text-muted); font-size:.94rem; }

.mini-stat { background: rgba(232,160,0,.07); border:1px solid rgba(232,160,0,.2); border-radius:10px; padding:14px 10px; display:flex; flex-direction:column; align-items:center; gap:6px; text-align:center; transition:var(--transition); }
.mini-stat:hover { background:rgba(232,160,0,.15); border-color:rgba(232,160,0,.4); }
.mini-stat i { font-size:1.2rem; color:var(--accent); }
.mini-stat span { font-size:.75rem; color: var(--text-muted); }

.skill-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:18px 20px; display:flex; align-items:center; gap:14px; transition:var(--transition); height:100%; }
.skill-card:hover { border-color:var(--accent); box-shadow:var(--shadow-sm); }
.skill-card i { font-size:1.4rem; color:var(--accent); flex-shrink:0; }
.skill-card span { font-size:.88rem; font-weight:500; }

.design-card { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); transition:var(--transition); background:var(--white); height:100%; }
.design-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.design-card-img { height:180px; overflow:hidden; }
.design-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.design-card:hover .design-card-img img { transform:scale(1.06); }
.design-card-header { padding:20px 24px 14px; display:flex; flex-direction:column; gap:8px; color:#fff; }
.design-card-header.architectural { background:linear-gradient(135deg,#2D4A22,#4A7A3A); }
.design-card-header.civil          { background:linear-gradient(135deg,#3a3a3a,#5a5a5a); }
.design-card-header.mechanical     { background:linear-gradient(135deg,#5C1A1A,#9E3D2D); }
.design-card-header.computational  { background:linear-gradient(135deg,#4a3000,#8a6000); }
.design-card-header i { font-size:1.6rem; opacity:.9; }
.design-card-header h5 { font-weight:700; margin:0; }
.design-card-body { padding:18px 24px; }
.design-card-body p { font-size:.9rem; color:var(--text-muted); margin:0; }

.tag-pill { display:inline-flex; align-items:center; gap:5px; background:rgba(232,160,0,.1); border:1px solid rgba(232,160,0,.3); color:var(--text-main); font-size:.78rem; font-weight:500; padding:5px 12px; border-radius:50px; }
.tag-pill.white { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.2); color:#fff; }
.tag-pill i { color:var(--accent); }

.service-pill { background:var(--white); border:2px solid var(--accent); color:var(--dark); border-radius:10px; padding:16px 18px; font-weight:600; font-size:.9rem; display:flex; align-items:center; gap:10px; justify-content:center; transition:var(--transition); }
.service-pill i { color:var(--accent); font-size:1.2rem; }
.service-pill:hover { background:var(--accent); color:#111; transform:translateY(-3px); box-shadow:0 6px 20px rgba(232,160,0,.3); }
.service-pill:hover i { color:#111; }

.feature-dark-card { background: var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px 32px; transition:var(--transition); height:100%; }
.feature-dark-card:hover { background: rgba(232,160,0,.03); border-color:rgba(232,160,0,.4); transform:translateY(-4px); box-shadow: var(--shadow-md); }
.feature-dark-icon { width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.feature-dark-icon.uvp    { background:rgba(232,160,0,.12); }
.feature-dark-icon.thermo { background:rgba(220,80,40,.12); }
.feature-dark-icon i { font-size:1.8rem; color:var(--accent); }
.feature-dark-icon.thermo i { color:#FF6B35; }
.feature-dark-card h4 { color: var(--dark); font-weight:700; margin-bottom:12px; }
.feature-dark-card p  { color: var(--text-muted); font-size:.93rem; margin-bottom:18px; }
.feature-dark-list { list-style:none; padding:0; margin:0; }
.feature-dark-list li { display:flex; align-items:center; gap:10px; color: var(--text-muted); font-size:.88rem; padding:6px 0; border-bottom:1px solid var(--border); }
.feature-dark-list li:last-child { border-bottom:none; }

.pub-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 26px; transition:var(--transition); display:flex; flex-direction:column; height:100%; }
.pub-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--accent); }
.pub-icon { width:48px; height:48px; background:rgba(232,160,0,.1); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.pub-icon i { font-size:1.4rem; color:var(--accent); }
.pub-journal { font-size:.75rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; background:rgba(232,160,0,.1); padding:3px 10px; border-radius:50px; display:inline-block; }
.pub-card h6 { font-size:.93rem; font-weight:600; color:var(--dark); flex:1; margin-bottom:18px; line-height:1.5; }
.pub-link { font-size:.83rem; font-weight:600; color:var(--accent); display:inline-flex; align-items:center; gap:5px; margin-top:auto; transition:var(--transition); }
.pub-link:hover { color:var(--accent-dark); gap:8px; }

.team-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition); height:100%; }
.team-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.team-avatar { height:340px; overflow:hidden; position:relative; }
.team-avatar img { width:100%; height:100%; object-fit:cover; object-position:center 20%; transition:transform .4s ease; }
.team-card:hover .team-avatar img { transform:scale(1.05); }

/* Horizontal team card — full photo, no crop */
.team-card-h {
  display: flex;
  align-items: stretch;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: var(--transition);
}
.team-card-h:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.team-card-h.reverse { flex-direction: row-reverse; }
.team-card-h-img {
  width: 340px;
  flex-shrink: 0;
  background: var(--dark);
}
.team-card-h-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-fit: contain;
  object-position: center top;
  display: block;
  background: var(--dark);
}
.team-card-h-body {
  flex: 1;
  padding: 40px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.team-card-h-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--dark);
  margin: 8px 0 18px;
  line-height: 1.2;
  letter-spacing: -.02em;
}
/* mobile: stack vertically */
@media (max-width: 767.98px) {
  .team-card-h, .team-card-h.reverse { flex-direction: column; }
  .team-card-h-img { width: 100%; height: auto; max-height: 420px; }
  .team-card-h-img img { object-fit: contain; object-position: center top; max-height: 420px; }
  .team-card-h-body { padding: 28px 24px; }
  .team-card-h-name { font-size: 1.35rem; }
}
.team-avatar-overlay { position:absolute; bottom:0; left:0; right:0; height:80px; background:linear-gradient(to top,rgba(26,26,46,.8),transparent); }
.team-avatar-bg  { background:linear-gradient(135deg,var(--dark),var(--dark-2)); display:flex; align-items:center; justify-content:center; }
.team-avatar-bg2 { background:linear-gradient(135deg,#1B4332,#2D6A4F); display:flex; align-items:center; justify-content:center; }
.team-avatar-fallback { font-size:6rem; color:var(--accent); opacity:.5; }
.team-info { padding:28px; }
.team-info h5 { font-weight:700; margin-bottom:4px; }
.team-role { font-size:.82rem; font-weight:600; color:var(--accent); text-transform:uppercase; letter-spacing:.06em; margin-bottom:12px; display:block; }
.team-bio { font-size:.88rem; color:var(--text-muted); margin-bottom:16px; line-height:1.65; }
.team-orgs { display:flex; flex-wrap:wrap; gap:6px; }
.team-orgs span { font-size:.75rem; background:var(--light-bg); border:1px solid var(--border); color:var(--text-muted); padding:4px 10px; border-radius:50px; display:inline-flex; align-items:center; gap:4px; }

.community-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 26px; text-align:center; transition:var(--transition); height:100%; }
.community-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.community-card.featured { border-color:var(--accent); background:rgba(232,160,0,.04); }
.community-icon { width:64px; height:64px; background:rgba(232,160,0,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 18px; }
.community-icon.featured { background:var(--accent); }
.community-icon i { font-size:1.6rem; color:var(--accent); }
.community-icon.featured i { color:#111; }
.community-card h5 { font-weight:700; margin-bottom:12px; }
.community-card p  { color:var(--text-muted); font-size:.92rem; margin:0; }

.community-quote { background: var(--white); border: 2px solid var(--border); border-radius:var(--radius-lg); padding:48px; text-align:center; color:var(--dark); position:relative; box-shadow: var(--shadow-sm); }
.community-quote > i { font-size:4rem; color:var(--accent); opacity:.25; position:absolute; top:20px; left:36px; }
.community-quote p { font-size:1.1rem; font-style:italic; color: var(--text-main); max-width:700px; margin:0 auto 16px; line-height:1.8; }
.community-quote span { font-size:.85rem; font-weight:600; color:var(--accent); letter-spacing:.08em; text-transform:uppercase; }

.agri-card { background:linear-gradient(135deg,#1B4332,#2D6A4F); border-radius:var(--radius-lg); padding:40px 36px; color:#fff; }
.agri-icon { width:80px; height:80px; background:rgba(255,255,255,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto; }
.agri-icon i { font-size:2.2rem; color:#74c69d; }
.agri-card h4 { font-weight:700; margin-bottom:10px; }
.agri-card p  { color:rgba(255,255,255,.85); font-size:.93rem; }

.work-with-us-box { background:linear-gradient(135deg,rgba(232,160,0,.08),rgba(232,160,0,.03)); border:2px solid var(--accent); border-radius:var(--radius-lg); padding:48px 40px; max-width:760px; margin:0 auto; text-align:center; }
.work-with-us-box h4 { font-weight:700; margin-bottom:14px; }
.work-with-us-box p { color:var(--text-muted); font-size:.94rem; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-section { background: var(--white); padding:90px 0; }
.contact-info-card { background: var(--dark); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:36px 28px; }
.contact-item { display:flex; align-items:flex-start; gap:14px; margin-bottom:24px; color:rgba(255,255,255,.85); font-size:.92rem; }
.contact-icon { width:40px; height:40px; background:rgba(232,160,0,.15); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-icon i { color:var(--accent); font-size:1rem; }
.contact-item strong { display:block; color:#fff; margin-bottom:2px; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; }
.contact-link { color:rgba(255,255,255,.75); transition:var(--transition); }
.contact-link:hover { color:var(--accent); }
.contact-form-card { background:var(--white); border-radius:var(--radius-lg); padding:40px 36px; box-shadow:var(--shadow-lg); }
.contact-form-card h5 { font-weight:700; color:var(--dark); }
.form-label { font-size:.85rem; font-weight:600; color:var(--dark); margin-bottom:6px; }
.custom-input { border:1.5px solid var(--border); border-radius:8px; font-size:.93rem; padding:11px 14px; transition:var(--transition); }
.custom-input:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(232,160,0,.15); outline:none; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer-section { background:var(--dark); }
.footer-heading { font-size:.82rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.footer-desc { font-size:.88rem; color:rgba(255,255,255,.5); line-height:1.7; }
.footer-loc  { font-size:.85rem; color:rgba(255,255,255,.5); margin-top:12px; }
.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:10px; }
.footer-links a { font-size:.88rem; color:rgba(255,255,255,.5); transition:var(--transition); display:flex; align-items:center; gap:6px; }
.footer-links a:hover { color:var(--accent); padding-left:4px; }
.footer-divider { border-color:rgba(255,255,255,.08); margin:0; }
.footer-copy    { font-size:.82rem; color:rgba(255,255,255,.3); }

/* =========================================================
   BACK TO TOP
   ========================================================= */
#backToTop { position:fixed; bottom:28px; right:28px; width:44px; height:44px; background:var(--accent); color:#111; border:none; border-radius:50%; display:none; align-items:center; justify-content:center; font-size:1.1rem; cursor:pointer; z-index:9998; transition:var(--transition); box-shadow:0 4px 14px rgba(232,160,0,.4); }
#backToTop:hover { background:var(--accent-dark); color:#fff; transform:translateY(-3px); }
#backToTop.visible { display:flex; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:991.98px) {
  .navbar-collapse { background:var(--dark); border-radius:var(--radius); padding:12px; margin-top:10px; }
  .section-padding { padding:72px 0; }
  .page-banner { min-height:260px; padding-top: 90px; }
  .hero-img-collage { height:360px; }
  .hero-img-float.f2 { display:none; }
  .community-quote { padding:36px 24px; }
  .contact-form-card { padding:30px 22px; }
}
@media (max-width:767.98px) {
  .hero-title { font-size:2.1rem; }
  .section-padding { padding:56px 0; }
  .agri-card { padding:28px 20px; }
  .community-quote > i { display:none; }
  .work-with-us-box { padding:28px 18px; }
  .hero-stats { gap:20px; justify-content:center; }
  .page-banner h1 { font-size:1.8rem; }
  .hero-img-collage { height:280px; }
  .hero-img-float { display:none; }
}
@media (max-width:575.98px) {
  .hero-title { font-size:1.85rem; }
  .hero-desc { font-size:1rem; }
  .service-pill { font-size:.82rem; padding:12px 14px; }
  .team-avatar { height:220px; }
}