/* Ensure ticker overlays hero image and move image left */
.ticker-section {
  position: relative;
  z-index: 10;
}
.hero-parallax-img {
  left: -80px !important;
  margin-bottom: -70px;
}
/* Parallax Hero Image */
.hero-parallax-img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 520px;
  max-width: 95vw;
  z-index: 3;
  pointer-events: none;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,0.18));
  will-change: transform;
  transition: transform 0.2s cubic-bezier(0.4,0,0.2,1);
}
/* ==========================================
   Vesonis v2 — Global Styles
   Palette: Black · Warm Teal · Warm Beige
   ========================================== */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

:root {
  --black:       #0D0D0B;
  --black-2:     #181815;
  --black-3:     #242421;
  --white:       #FFFFFF;

  --teal:        #B8CEC9;
  --teal-10:     rgba(184,206,201,0.10);
  --teal-20:     rgba(184,206,201,0.20);
  --teal-35:     rgba(184,206,201,0.35);
  --teal-60:     rgba(184,206,201,0.60);
  --teal-dark:   #6FA8A0;

  --beige:       #faf9f4;
  --beige-10:    rgba(237,232,216,0.10);
  --beige-20:    rgba(237,232,216,0.20);
  --beige-40:    rgba(237,232,216,0.40);
  --beige-70:    rgba(237,232,216,0.70);
  --beige-deep:  #f8f6ef;

  --accent:      #6FA8A0;
  --accent-h:    #68a199;

  --bg:          #ffffff;
  --surface:     #FFFFFF;
  --surface-teal:rgba(184,206,201,0.13);
  --border:      rgba(184,206,201,0.50);
  --border-soft: rgba(184,206,201,0.28);
  --text:        #1A1916;
  --text-2:      #3A3834;
  --text-muted:  #7A7670;
  --dark-border: rgba(255,255,255,0.08);

  --nav-h: 70px;
  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;

  --font-display:'Syne', sans-serif;
  --font-body:   'DM Sans', sans-serif;
  --ease:  cubic-bezier(0.4,0,0.2,1);
  --t:     0.35s;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:16px;
  line-height:1.70;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{border:none;background:none;cursor:pointer;font-family:inherit}
svg{flex-shrink:0;display:block}

/* ── Layout ── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 32px}
.section{padding:100px 0}
.section-sm{padding:64px 0}

/* ── Typography ── */
.display-xl{
  font-family:var(--font-display);
  font-size:clamp(3.2rem,6vw,5.6rem);
  font-weight:800;
  line-height:1.13;
  letter-spacing:-0.025em;
  margin-top: 0.2em;
  margin-bottom: 0.2em;
  padding-top: 0;
  padding-bottom: 0;
}
.display-lg{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,4.5vw,4rem);
  font-weight:800;
  line-height:1.10;
  letter-spacing:-0.022em;
  margin-top: 0.18em;
  margin-bottom: 0.18em;
  padding-top: 0;
  padding-bottom: 0;
}
.display-md{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.2vw,2.8rem);
  font-weight:700;line-height:1.18;letter-spacing:-0.018em;
}
.display-sm{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2vw,1.7rem);
  font-weight:700;line-height:1.28;letter-spacing:-0.012em;
}
.body-lg{font-size:1.08rem;line-height:1.82}
.body-md{font-size:0.975rem;line-height:1.76}
.body-sm{font-size:0.875rem;line-height:1.72}
.text-muted{color:var(--text-muted)}

/* ── Badge ── */
.badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:0.77rem;font-weight:700;color:var(--accent);
  letter-spacing:0.08em;text-transform:uppercase;margin-bottom:18px;
}
.badge::before{content:'✦';font-size:0.65rem}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:12px 25px;border-radius:40px;
  font-family:var(--font-body);font-size:0.925rem;font-weight:600;
  cursor:pointer;transition:all var(--t) var(--ease);
  letter-spacing:0.01em;white-space:nowrap;
  margin-top: 8px;
}
.btn svg{transition:transform 0.22s var(--ease);width:17px;height:17px}
.btn:hover svg:last-child{transform:translateX(3px)}

.btn-primary{
  background:var(--accent);color:#fff;border:2px solid var(--accent);
  box-shadow:0 2px 12px rgba(200,71,42,0.20);
}
.btn-primary:hover{
  background:var(--accent-h);border-color:var(--accent-h);
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,71,42,0.30);
}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-ghost{
  background:rgba(255,255,255,0.08);color:#fff;
  border:1.5px solid rgba(255,255,255,0.22);backdrop-filter:blur(6px);
}
.btn-ghost:hover{background:rgba(255,255,255,0.16);border-color:rgba(255,255,255,0.45)}
.btn-teal{background:var(--teal-20);color:var(--text);border:1.5px solid var(--teal-60)}
.btn-teal:hover{background:var(--teal-35);border-color:var(--teal)}

/* ==========================================
   NAVBAR
   ========================================== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:#ffffff;
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border-soft);
  transition:box-shadow var(--t) var(--ease);
}
.navbar.scrolled{box-shadow:0 4px 30px rgba(13,13,11,0.08)}
.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:28px}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:1.28rem;font-weight:800;
  color:var(--black);letter-spacing:-0.025em;flex-shrink:0;
}
.nav-logo-icon{
  width:36px;height:36px;background:var(--black);border-radius:9px;
  display:grid;place-items:center;color:#fff;
}
.nav-logo-icon svg{width:18px;height:18px}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{
  font-size:0.895rem;font-weight:500;color:#000000;
  padding:8px 15px;border-radius:var(--r-sm);transition:all 0.22s var(--ease);
}
.nav-link:hover{color:var(--text);background:var(--teal-10)}
.nav-link.active{color:#6FA8A0}
.nav-dropdown{position:relative}
.nav-dropdown-toggle{
  display:flex;align-items:center;gap:5px;
  font-size:0.895rem;font-weight:500;color:#000000;
  padding:8px 15px;border-radius:var(--r-sm);cursor:pointer;
  transition:all 0.22s var(--ease);
}
.nav-dropdown-toggle:hover{color:var(--text);background:var(--teal-10)}
.nav-dropdown-toggle svg{transition:transform 0.22s var(--ease);width:14px;height:14px}
.nav-dropdown:hover .nav-dropdown-toggle svg{transform:rotate(180deg)}
.dropdown-menu{
  position:absolute;top:calc(100% + 10px);left:0;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:8px;min-width:190px;
  box-shadow:0 16px 50px rgba(13,13,11,0.10);
  opacity:0;visibility:hidden;transform:translateY(-10px) scale(0.97);
  transition:all 0.25s var(--ease);z-index:100;
}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.dropdown-item{
  display:block;padding:10px 15px;font-size:0.88rem;font-weight:500;
  color:var(--text-muted);border-radius:var(--r-sm);transition:all 0.2s;
}
.dropdown-item:hover{color:var(--accent);background:var(--surface-teal)}
.nav-cta{margin-left:6px}

.nav-hamburger{
  display:none;flex-direction:column;gap:5px;
  padding:8px;cursor:pointer;border-radius:var(--r-sm);transition:background 0.2s;
}
.nav-hamburger:hover{background:var(--teal-10)}
.hamburger-line{width:22px;height:2px;background:var(--text);border-radius:2px;transition:all var(--t) var(--ease)}
.nav-hamburger.open .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  position:fixed;top:var(--nav-h);left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--border);
  padding:22px 28px 32px;transform:translateY(-110%);
  transition:transform 0.38s var(--ease);z-index:999;
  box-shadow:0 24px 60px rgba(13,13,11,0.12);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-nav-link{
  display:block;padding:14px 0;font-size:1.05rem;font-weight:600;color:var(--text);
  border-bottom:1px solid var(--border-soft);transition:color 0.2s;
}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--accent)}
.mobile-sub-links{padding:6px 0 6px 18px}
.mobile-sub-link{display:block;padding:9px 0;font-size:0.92rem;font-weight:500;color:var(--text-muted);transition:color 0.2s}
.mobile-sub-link:hover{color:var(--accent)}
.mobile-cta{margin-top:22px;width:100%;justify-content:center}

/* ── PAGE WRAPPER ── */
.page-wrapper{padding-top:var(--nav-h)}

/* ==========================================
   HERO BLOB
   ========================================== */
.hero-blob{position:absolute;top:-20px;right:-50px;width:400px;height:380px;pointer-events:none;z-index:0}
.blob-shape{
  width:100%;height:100%;
  border-radius:62% 38% 70% 30%/52% 62% 38% 48%;
  background:linear-gradient(135deg,#6FA8A0 0%,#68a199 45%,#33605a 100%);
  opacity:0.85;animation:morphBlob 9s ease-in-out infinite;
  position:relative;overflow:hidden;
}
.blob-shape::after{
  content:'';position:absolute;inset:18%;
  background:radial-gradient(circle,#6FA8A0,transparent 70%);
  border-radius:50%;
}
.blob-shape-2{
  position:absolute;top:50px;right:50px;width:110px;height:130px;
  border-radius:42% 58% 52% 48%/58% 42% 58% 42%;
  background:linear-gradient(135deg,#ffffff,#c1e8e3);
  opacity:0.4;animation:morphBlob2 6s ease-in-out infinite reverse;
}
@keyframes morphBlob{
  0%,100%{border-radius:62% 38% 70% 30%/52% 62% 38% 48%;transform:rotate(0deg) scale(1)}
  33%{border-radius:38% 62% 30% 70%/62% 38% 62% 38%;transform:rotate(5deg) scale(1.02)}
  66%{border-radius:70% 30% 48% 52%/38% 62% 38% 62%;transform:rotate(-3deg) scale(0.97)}
}
@keyframes morphBlob2{
  0%,100%{border-radius:42% 58% 52% 48%/58% 42% 58% 42%}
  50%{border-radius:58% 42% 38% 62%/42% 58% 42% 58%}
}

/* ==========================================
   HERO
   ========================================== */
.hero{
  min-height:calc(100vh - var(--nav-h));
  position:relative;display:flex;align-items:center;
  /* overflow:hidden; */
  background:var(--bg);
}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(184,206,201,0.30) 1px,transparent 1px),
    linear-gradient(90deg,rgba(184,206,201,0.30) 1px,transparent 1px);
  background-size:64px 64px;z-index:0;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:center;width:100%;
}
.hero-content{max-width:600px}
.hero-heading{margin-bottom:26px}
.hero-heading .line{
  overflow:visible;
  line-height: 1.13;
}
.hero-heading .word{
  display:inline-block;transform:translateY(105%);opacity:0;
  animation:wordReveal 0.72s var(--ease) forwards;
}
@keyframes wordReveal{to{transform:translateY(0);opacity:1}}
.hero-desc{font-size:1.05rem;color:var(--text-muted);max-width:440px;margin-bottom:38px;line-height:1.82}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-stats{
  display:flex;gap:44px;margin-top:56px;margin-bottom: 40px;
  padding-top:36px;border-top:1px solid var(--border);flex-wrap:wrap;
}
.stat-item .stat-num{
  font-family:var(--font-display);font-size:2.4rem;font-weight:800;
  color:var(--text);line-height:1;letter-spacing:-0.035em;
}
.stat-item .stat-label{font-size:0.83rem;color:var(--text-muted);margin-top:5px;font-weight:500}

.hero-visual{position:relative;height:520px;display:flex;align-items:center;justify-content:center}
.hero-card{
  position:absolute;background:var(--white);
  border:1px solid var(--border);border-radius:var(--r-md);
  padding:18px 22px;box-shadow:0 8px 40px rgba(13,13,11,0.08);
  animation:floatCard 4.2s ease-in-out infinite;
}
.hero-card:nth-child(2){animation-delay:-1.8s;animation-duration:5.2s}
.hero-card:nth-child(3){animation-delay:-3.2s;animation-duration:4.8s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}
.hero-card-1{top:70px;left:0;max-width:230px}
.hero-card-2{bottom:110px;left:16px;max-width:200px}
.hero-card-3{top:130px;right:0;max-width:210px}
.hero-card-icon{
  width:38px;height:38px;border-radius:9px;background:var(--surface-teal);
  display:grid;place-items:center;color:var(--teal-dark);margin-bottom:11px;
}
.hero-card-icon svg{width:18px;height:18px}
.hero-card-label{font-size:0.72rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:5px}
.hero-card-value{font-family:var(--font-display);font-size:1.45rem;font-weight:800;color:var(--text)}
.hero-card-sub{font-size:0.78rem;color:var(--text-muted);margin-top:2px}
.country-flags{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.flag-chip{
  display:flex;align-items:center;gap:5px;padding:4px 10px;
  background:var(--teal-10);border:1px solid var(--border);border-radius:20px;
  font-size:0.75rem;font-weight:600;color:var(--text);
}

/* ==========================================
   TICKER
   ========================================== */
.ticker-section{background:var(--black);padding:16px 0;overflow:hidden}
.ticker-track{display:flex;animation:ticker 32s linear infinite;white-space:nowrap}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{
  display:inline-flex;align-items:center;gap:14px;padding:0 34px;
  font-family:var(--font-display);font-size:0.82rem;font-weight:600;
  color:rgba(255,255,255,0.55);letter-spacing:0.06em;text-transform:uppercase;flex-shrink:0;
}
.ticker-dot{width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================
   SERVICES LIST
   ========================================== */
.services-list-section{background:var(--white)}
.services-header{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.service-row{
  display:grid;grid-template-columns:64px 1fr 240px 140px;
  gap:28px;align-items:center;padding:30px 0;
  border-top:1px solid var(--border);
  transition:padding-left var(--t) var(--ease);
  position:relative;cursor:default;
}
.service-row::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--teal-dark),var(--teal));
  transform:scaleX(0);transform-origin:left;transition:transform 0.45s var(--ease);
}
.service-row:hover::after{transform:scaleX(1)}
.service-row:hover{padding-left:8px}
.service-row:hover .service-row-num{color:var(--accent)}
.service-row:hover .service-row-title{color:var(--teal-dark)}
.service-row:hover .service-row-img{opacity:1;transform:scale(1.04)}
.service-row-num{
  font-family:var(--font-display);font-size:0.78rem;font-weight:700;
  color:var(--text-muted);transition:color var(--t);letter-spacing:0.06em;
}
.service-row-title{
  font-family:var(--font-display);
  font-size:clamp(1.4rem,2.4vw,2.1rem);
  font-weight:700;line-height:1.15;letter-spacing:-0.02em;transition:color var(--t);
}
.service-row-tags{display:flex;flex-direction:column;gap:4px}
.service-row-tags span{font-size:0.82rem;color:var(--text-muted);font-weight:500}
.service-row-img{
  width:130px;height:86px;border-radius:var(--r-md);overflow:hidden;
  justify-self:end;opacity:0.85;transition:all 0.4s var(--ease);
  background:var(--teal-10);border:1px solid var(--border);
  display:grid;place-items:center;
}
.service-row-img svg{width:36px;height:36px;color:var(--teal-dark);opacity:0.7}

/* ==========================================
   PROCESS CARDS
   ========================================== */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px}
.process-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px 26px;
  transition:all var(--t) var(--ease);position:relative;overflow:hidden;
}
.process-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal-dark),var(--teal));
  transform:scaleX(0);transition:transform 0.45s var(--ease);
}
.process-card:hover::before{transform:scaleX(1)}
.process-card:hover{box-shadow:0 16px 48px rgba(13,13,11,0.07);transform:translateY(-5px)}
.process-card.featured{background:var(--black);border-color:var(--black);color:#fff}
.process-card.featured .process-card-title{color:#fff}
.process-card.featured .process-card-desc{color:rgba(255,255,255,0.55)}
.process-icon{
  width:50px;height:50px;border-radius:var(--r-sm);background:var(--surface-teal);
  display:grid;place-items:center;color:var(--teal-dark);margin-bottom:22px;
}
.process-icon svg{width:22px;height:22px}
.featured .process-icon{background:rgba(184,206,201,0.15);color:var(--teal)}
.process-card-title{font-family:var(--font-display);font-size:1.12rem;font-weight:700;margin-bottom:11px;letter-spacing:-0.01em}
.process-card-desc{font-size:0.895rem;color:var(--text-muted);line-height:1.72}

/* ==========================================
   PORTFOLIO (dark)
   ========================================== */
.portfolio-section{background:var(--black);color:#fff}
.portfolio-section .badge{color:rgba(255,255,255,0.45)}
.portfolio-section .badge::before{color:rgba(255,255,255,0.45)}
.portfolio-header{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end}
.portfolio-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:52px}
.portfolio-card{
  border-radius:var(--r-lg);overflow:hidden;
  background:var(--black-2);border:1px solid var(--dark-border);
  transition:all var(--t) var(--ease);cursor:pointer;
}
.portfolio-card:hover{transform:translateY(-7px);box-shadow:0 24px 70px rgba(0,0,0,0.45)}
.portfolio-card:hover .p-img-inner svg{transform:scale(1.1)}
.portfolio-card-img{height:270px;overflow:hidden}
.p-img-inner{
  width:100%;height:100%;display:grid;place-items:center;
}
.p-img-inner svg{width:56px;height:56px;opacity:0.40;transition:transform 0.6s var(--ease);color:var(--teal)}
.portfolio-card-body{padding:26px}
.portfolio-card-tag{font-size:0.75rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:10px}
.portfolio-card-title{font-family:var(--font-display);font-size:1.22rem;font-weight:700;color:#fff;margin-bottom:10px;line-height:1.3}
.portfolio-card-desc{font-size:0.87rem;color:rgba(255,255,255,0.50);line-height:1.68}

/* ==========================================
   ACHIEVEMENTS
   ========================================== */
.achievements-section{background:var(--teal-10)}
.achievements-header{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:60px}
.achievement-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.achievement-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:34px 28px;transition:all var(--t) var(--ease);
}
.achievement-card:hover{transform:translateY(-5px);box-shadow:0 14px 45px rgba(13,13,11,0.07)}
.achievement-card.accent-card{background:var(--accent);border-color:var(--accent);color:#fff}
.achievement-card.accent-card .achievement-num,
.achievement-card.accent-card .achievement-label{color:#fff}
.achievement-card.accent-card .achievement-desc{color:rgba(255,255,255,0.72)}
.achievement-num{font-family:var(--font-display);font-size:3.2rem;font-weight:800;color:var(--text);line-height:1;letter-spacing:-0.045em}
.achievement-label{font-family:var(--font-display);font-size:1.02rem;font-weight:700;color:var(--text);margin-top:9px;margin-bottom:11px}
.achievement-desc{font-size:0.855rem;color:var(--text-muted);line-height:1.68}

/* ==========================================
   AWARDS
   ========================================== */
.awards-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:52px}
.award-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px;
  display:grid;grid-template-columns:96px 1fr;gap:24px;
  align-items:center;transition:all var(--t) var(--ease);
}
.award-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(13,13,11,0.07)}
.award-trophy{
  width:96px;height:96px;border-radius:var(--r-md);
  background:var(--teal-10);border:1px solid var(--border);
  display:grid;place-items:center;
}
.award-trophy svg{width:40px;height:40px;color:var(--teal-dark)}
.award-year{font-size:0.75rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:6px}
.award-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:8px;letter-spacing:-0.01em}
.award-desc{font-size:0.855rem;color:var(--text-muted);line-height:1.68}

/* ==========================================
   TEAM
   ========================================== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px}
.team-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:all var(--t) var(--ease);
}
.team-card:hover{transform:translateY(-6px);box-shadow:0 14px 45px rgba(13,13,11,0.09)}
.team-card-img{height:220px;overflow:hidden;background:var(--teal-10);display:grid;place-items:center}
.team-card-img svg{width:72px;height:72px;color:var(--teal-dark);opacity:0.55;transition:transform 0.5s var(--ease)}
.team-card:hover .team-card-img svg{transform:scale(1.06)}
.team-card-body{padding:20px 22px}
.team-name{font-family:var(--font-display);font-size:1.06rem;font-weight:700;margin-bottom:4px}
.team-role{font-size:0.83rem;color:var(--text-muted);font-weight:500}

/* ==========================================
   TESTIMONIALS
   ========================================== */
.testimonials-section{background:var(--white)}
.testimonials-header{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:52px}
.testimonials-track-wrap{overflow:hidden}
.testimonials-track{display:flex;gap:24px;transition:transform 0.52s var(--ease)}
.testimonial-card{
  background:var(--teal-10);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:38px;
  min-width:calc(50% - 12px);flex-shrink:0;
}
.testimonial-stars{display:flex;gap:4px;margin-bottom:20px}
.testimonial-stars svg{width:16px;height:16px;fill:var(--accent);stroke:var(--accent)}
.testimonial-quote{font-size:0.975rem;line-height:1.84;color:var(--text);margin-bottom:28px;font-style:italic}
.testimonial-logo-row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.testimonial-avatar{
  width:46px;height:46px;border-radius:50%;
  background:var(--teal-35);border:2px solid var(--border);
  display:grid;place-items:center;
}
.testimonial-avatar svg{width:22px;height:22px;color:var(--teal-dark)}
.testimonial-name{font-family:var(--font-display);font-size:0.97rem;font-weight:700}
.testimonial-org{font-size:0.79rem;color:var(--text-muted);margin-top:2px}
.testimonial-badge{
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:5px 11px;font-size:0.73rem;font-weight:700;color:var(--text-muted);
  letter-spacing:0.04em;white-space:nowrap;
}
.slider-controls{display:flex;gap:12px;margin-top:30px;justify-content:flex-end}
.slider-btn{
  width:46px;height:46px;border-radius:50%;border:1.5px solid var(--border);
  display:grid;place-items:center;cursor:pointer;
  transition:all var(--t) var(--ease);background:var(--white);
}
.slider-btn svg{width:18px;height:18px}
.slider-btn:hover{border-color:var(--teal-dark);color:var(--teal-dark);background:var(--surface-teal)}

/* ==========================================
   BLOG
   ========================================== */
.blog-section{background:var(--bg)}
.blog-header{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.blog-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:all var(--t) var(--ease);
}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(13,13,11,0.07)}
.blog-card:hover .b-img-inner svg{transform:scale(1.1)}
.blog-card-img{height:200px;overflow:hidden;background:var(--teal-10);display:grid;place-items:center}
.b-img-inner{width:100%;height:100%;display:grid;place-items:center}
.b-img-inner svg{width:48px;height:48px;opacity:0.50;transition:transform 0.55s var(--ease);color:var(--teal-dark)}
.blog-card-body{padding:24px}
.blog-meta{display:flex;align-items:center;gap:8px;font-size:0.76rem;color:var(--text-muted);font-weight:500;margin-bottom:11px}
.blog-meta-dot{width:3px;height:3px;background:var(--text-muted);border-radius:50%}
.blog-card-title{font-family:var(--font-display);font-size:1.02rem;font-weight:700;line-height:1.38;margin-bottom:11px;letter-spacing:-0.01em}
.blog-card-excerpt{font-size:0.855rem;color:var(--text-muted);line-height:1.72}

.blog-full-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:52px}
.blog-full-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:all var(--t) var(--ease);
}
.blog-full-card:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(13,13,11,0.07)}
.blog-full-card:hover .b-img-inner svg{transform:scale(1.1)}
.blog-full-card-img{height:230px;background:var(--teal-10);display:grid;place-items:center;overflow:hidden}
.blog-full-card-body{padding:28px}

/* ==========================================
   CTA BANNER
   ========================================== */
.cta-banner{background:var(--black);padding:108px 0;position:relative;overflow:hidden}
.cta-banner::before{
  content:'';position:absolute;top:-120px;right:-120px;width:550px;height:550px;
  background:radial-gradient(circle,rgba(200,71,42,0.18) 0%,transparent 65%);pointer-events:none;
}
.cta-banner::after{
  content:'';position:absolute;bottom:-80px;left:-80px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(184,206,201,0.10) 0%,transparent 65%);pointer-events:none;
}
.cta-banner-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:64px;align-items:center}
.cta-banner-heading{
  font-family:var(--font-display);
  font-size:clamp(2.6rem,5.2vw,4.8rem);
  font-weight:800;color:#fff;line-height:1.08;letter-spacing:-0.03em;
}

/* ==========================================
   FOOTER
   ========================================== */
.footer{background:var(--black);border-top:1px solid var(--dark-border);padding:64px 0 32px}
.footer-main{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:44px;padding-bottom:52px;border-bottom:1px solid var(--dark-border);
}
.footer-brand{max-width:270px}
.footer-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:1.22rem;font-weight:800;color:#fff;margin-bottom:13px;
}
.footer-logo .nav-logo-icon{background:rgba(255,255,255,0.10)}
.footer-tagline{font-size:0.84rem;font-weight:700;color:rgba(255,255,255,0.85);margin-bottom:7px}
.footer-desc{font-size:0.84rem;color:rgba(255,255,255,0.40);line-height:1.78;margin-bottom:26px}
.footer-col-title{
  font-family:var(--font-display);font-size:0.80rem;font-weight:700;
  color:rgba(255,255,255,0.85);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:20px;
}
.footer-link{display:block;font-size:0.87rem;color:rgba(255,255,255,0.42);padding:5px 0;transition:color 0.2s;font-weight:500}
.footer-link:hover{color:rgba(255,255,255,0.88)}
.social-links{display:flex;gap:10px}
.social-link{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(255,255,255,0.06);display:grid;place-items:center;
  color:rgba(255,255,255,0.45);transition:all var(--t) var(--ease);
  border:1px solid rgba(255,255,255,0.08);
}
.social-link svg{width:16px;height:16px}
.social-link:hover{background:var(--teal-20);color:var(--teal);border-color:var(--teal-60)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:26px;font-size:0.80rem;color:rgba(255,255,255,0.28);
}
.footer-bottom a{color:rgba(255,255,255,0.46)}
.footer-bottom a:hover{color:#fff}

/* ==========================================
   PAGE HERO (inner pages)
   ========================================== */
.page-hero{padding:88px 0 72px;position:relative;overflow:hidden;background:var(--bg)}
.page-hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(184,206,201,0.28) 1px,transparent 1px),
    linear-gradient(90deg,rgba(184,206,201,0.28) 1px,transparent 1px);
  background-size:64px 64px;z-index:0;
}
.page-hero-blob{position:absolute;top:-60px;right:-90px;width:310px;height:290px;pointer-events:none;z-index:0}
.page-hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}

/* ==========================================
   ABOUT PAGE
   ========================================== */
.about-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-hero-visual{
  position:relative;height:440px;border-radius:var(--r-xl);
  overflow:hidden;background:var(--black-2);display:grid;place-items:center;
}
.about-big-icon{width:100px;height:100px;color:var(--teal-60)}
.about-hero-visual-overlay{
  position:absolute;bottom:24px;left:24px;right:24px;
  background:rgba(255,255,255,0.96);border-radius:var(--r-md);padding:18px 22px;
  backdrop-filter:blur(12px);display:flex;align-items:center;gap:20px;
}
.about-overlay-stat .num{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--accent)}
.about-overlay-stat .lbl{font-size:0.76rem;color:var(--text-muted);font-weight:500}
.about-overlay-div{width:1px;height:36px;background:var(--border);flex-shrink:0}
.about-stats-row{
  display:flex;gap:44px;padding:36px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  margin:40px 0;flex-wrap:wrap;
}
.about-stat-item .num{font-family:var(--font-display);font-size:2.5rem;font-weight:800;letter-spacing:-0.045em;color:var(--text)}
.about-stat-item .lbl{font-size:0.84rem;color:var(--text-muted);font-weight:500;margin-top:4px}

.values-dark{background:var(--black);border-radius:var(--r-xl);padding:54px 50px;margin-top:52px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.value-card{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-md);padding:28px;transition:all var(--t) var(--ease);
}
.value-card:hover{background:rgba(255,255,255,0.07);border-color:var(--teal-60)}
.value-icon{
  width:46px;height:46px;border-radius:var(--r-sm);background:rgba(184,206,201,0.12);
  display:grid;place-items:center;color:var(--teal);margin-bottom:16px;
}
.value-icon svg{width:22px;height:22px}
.value-title{font-family:var(--font-display);font-size:1.10rem;font-weight:700;color:#fff;margin-bottom:9px}
.value-desc{font-size:0.855rem;color:rgba(255,255,255,0.48);line-height:1.72}

/* ==========================================
   SERVICE DETAIL
   ========================================== */
.service-detail-section{background:var(--white)}
.service-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:center;padding:56px 0;border-top:1px solid var(--border);
}
.service-detail-grid:last-child{border-bottom:1px solid var(--border)}
.service-detail-grid.reverse{direction:rtl}
.service-detail-grid.reverse>*{direction:ltr}
.service-detail-num{font-size:0.76rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:13px}
.service-detail-title{font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:800;letter-spacing:-0.022em;margin-bottom:18px;line-height:1.15}
.service-detail-desc{font-size:0.955rem;color:var(--text-muted);line-height:1.82;margin-bottom:26px}
.service-detail-tags{display:flex;flex-wrap:wrap;gap:8px}
.service-tag{
  padding:7px 15px;background:var(--teal-10);border:1px solid var(--border);
  border-radius:24px;font-size:0.80rem;font-weight:600;color:var(--text);transition:all 0.2s;
}
.service-tag:hover{background:var(--teal-35);border-color:var(--teal)}
.service-detail-image{
  height:340px;border-radius:var(--r-xl);overflow:hidden;
  background:var(--teal-10);border:1px solid var(--border);display:grid;place-items:center;
}
.service-detail-image svg{width:80px;height:80px;color:var(--teal-dark);opacity:0.65}

.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.why-features{display:flex;flex-direction:column;gap:18px;margin-top:32px}
.why-feature{
  display:flex;gap:18px;padding:20px 22px;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);transition:all var(--t) var(--ease);
}
.why-feature:hover{border-color:var(--teal);transform:translateX(5px);box-shadow:0 4px 24px rgba(184,206,201,0.20)}
.why-feature-icon{
  width:44px;height:44px;border-radius:var(--r-sm);background:var(--surface-teal);
  display:grid;place-items:center;color:var(--teal-dark);flex-shrink:0;
}
.why-feature-icon svg{width:20px;height:20px}
.why-feature-title{font-family:var(--font-display);font-size:0.97rem;font-weight:700;margin-bottom:5px}
.why-feature-desc{font-size:0.845rem;color:var(--text-muted);line-height:1.68}
.why-image{
  height:500px;border-radius:var(--r-xl);overflow:hidden;
  background:var(--black-2);display:grid;place-items:center;position:relative;
}
.why-image-icon{width:90px;height:90px;color:var(--teal-60)}
.why-image-overlay{
  position:absolute;bottom:24px;left:24px;right:24px;
  background:rgba(255,255,255,0.96);border-radius:var(--r-md);padding:18px 22px;
  backdrop-filter:blur(12px);display:flex;align-items:center;gap:16px;
}
.why-overlay-stat .num{font-family:var(--font-display);font-size:1.52rem;font-weight:800;color:var(--accent)}
.why-overlay-stat .lbl{font-size:0.76rem;color:var(--text-muted);font-weight:500}
.why-overlay-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}

/* ==========================================
   CONTACT
   ========================================== */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.contact-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px;transition:all var(--t) var(--ease);
}
.contact-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(13,13,11,0.07);border-color:var(--teal)}
.contact-icon{
  width:54px;height:54px;border-radius:var(--r-md);
  background:var(--teal-10);border:1px solid var(--border);
  display:grid;place-items:center;color:var(--teal-dark);margin-bottom:22px;
}
.contact-icon svg{width:24px;height:24px}
.contact-card-label{font-size:0.80rem;color:var(--text-muted);font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.05em}
.contact-card-value{font-family:var(--font-display);font-size:1.12rem;font-weight:700}
.contact-card-action{display:inline-flex;align-items:center;gap:6px;font-size:0.87rem;color:var(--accent);font-weight:600;margin-top:11px;transition:gap 0.2s}
.contact-card:hover .contact-card-action{gap:10px}
.contact-section-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:64px;align-items:start}
.contact-social-links{display:flex;gap:11px;margin-top:26px}
.contact-social-btn{
  width:42px;height:42px;border-radius:var(--r-sm);
  background:var(--teal-10);border:1px solid var(--border);
  display:grid;place-items:center;color:var(--text-muted);transition:all var(--t) var(--ease);
}
.contact-social-btn svg{width:17px;height:17px}
.contact-social-btn:hover{background:var(--teal-35);color:var(--text);border-color:var(--teal)}
.office-img{
  width:100%;height:200px;border-radius:var(--r-lg);overflow:hidden;
  margin-top:26px;background:var(--teal-10);border:1px solid var(--border);
  display:grid;place-items:center;
}
.office-img svg{width:64px;height:64px;color:var(--teal-dark);opacity:0.6}
.office-address-label{font-family:var(--font-display);font-size:1.12rem;font-weight:700;margin-top:18px;margin-bottom:5px}
.office-address{font-size:0.88rem;color:var(--text-muted);line-height:1.72}
.contact-form-side{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:44px}
.form-title{font-family:var(--font-display);font-size:1.55rem;font-weight:800;margin-bottom:8px;letter-spacing:-0.02em}
.form-subtitle{font-size:0.89rem;color:var(--text-muted);margin-bottom:30px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group.full-width{grid-column:1/-1}
.form-label{font-size:0.81rem;font-weight:700;color:var(--text);letter-spacing:0.02em}
.form-control{
  padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font-body);font-size:0.925rem;color:var(--text);background:var(--bg);
  transition:border-color 0.25s,box-shadow 0.25s;outline:none;width:100%;
}
.form-control:focus{border-color:var(--teal-dark);box-shadow:0 0 0 3px var(--teal-10);background:var(--white)}
.form-control::placeholder{color:var(--text-muted);font-size:0.87rem}
.form-select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237A7670' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;
}
.form-textarea{resize:vertical;min-height:126px}
.form-submit{margin-top:22px;width:100%;justify-content:center;padding:15px;font-size:0.97rem}

/* ==========================================
   SCROLL ANIMATIONS
   ========================================== */
.reveal,.reveal-left,.reveal-right{transition:opacity 0.72s var(--ease),transform 0.72s var(--ease)}
.reveal{opacity:0;transform:translateY(30px)}
.reveal-left{opacity:0;transform:translateX(-32px)}
.reveal-right{opacity:0;transform:translateX(32px)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:translate(0,0)}
.reveal-delay-1{transition-delay:0.10s}
.reveal-delay-2{transition-delay:0.20s}
.reveal-delay-3{transition-delay:0.30s}
.reveal-delay-4{transition-delay:0.40s}
.reveal-delay-5{transition-delay:0.50s}

/* ==========================================
   UTILITIES
   ========================================== */
.text-center{text-align:center}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}

/* ==========================================
   RESPONSIVE
   ========================================== */
@media(max-width:1100px){
  .process-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .footer-main{grid-template-columns:1fr 1fr;gap:30px}
  .service-row{grid-template-columns:52px 1fr 1fr}
  .service-row-img{display:none}
  .container{padding:0 24px}
}
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 64px;
  }
  .nav-logo {
    display: flex;
    align-items: center;
    height: 100%;
  }
  .nav-hamburger {
    align-items: center;
    height: 100%;
  }
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero{min-height:auto;padding:64px 0}
  .services-header{grid-template-columns:1fr}
  .achievements-header{grid-template-columns:1fr}
  .achievement-cards{grid-template-columns:1fr 1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .portfolio-header{grid-template-columns:1fr}
  .testimonials-header{grid-template-columns:1fr}
  .blog-header{grid-template-columns:1fr}
  .cta-banner-inner{grid-template-columns:1fr;gap:24px}
  .page-hero-inner{grid-template-columns:1fr}
  .contact-section-inner{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .service-detail-grid{grid-template-columns:1fr}
  .service-detail-grid.reverse{direction:ltr}
  .awards-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .blog-full-grid{grid-template-columns:1fr}
  .about-hero-inner{grid-template-columns:1fr}
  .values-dark{padding:36px 28px}
}
@media(max-width:640px){
  .section{padding:68px 0}
  .section-sm{padding:48px 0}
  .process-grid{grid-template-columns:1fr}
  .achievement-cards{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero-stats{gap:28px}
  .footer-main{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .service-row{grid-template-columns:42px 1fr}
  .service-row-tags{display:none}
  .award-card{grid-template-columns:1fr}
  .contact-form-side{padding:28px 22px}
  .testimonial-card{min-width:88vw}
  .blog-header{grid-template-columns:1fr}
  .about-stats-row{gap:28px}
  .display-xl{font-size:clamp(2.8rem,9vw,5.6rem)}
  .display-lg{font-size:clamp(2.2rem,7vw,4rem)}
}











.fixed-img-box {
  width: 100%;
  height: 340px;
  border-radius: 16px;
  overflow: hidden;
}

.fixed-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fixed-img-blog {
  width: 100%;
  height: 200px;
  border-radius: 0px;
  overflow: hidden;
}

.fixed-img-blog img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}