/* =========================================================
   DESIGN GALLERY CREATIVE SOLUTIONS — Design System
   Tokens: color, type, spacing, motion
   ========================================================= */

:root{
  /* Brand colors — extracted from logo */
  --ink-blue: #1B0FA0;      /* deep indigo blue (logo "D") */
  --ink-blue-dark: #120A6E;
  --coral: #FF6D4C;         /* logo "G" */
  --coral-dark: #E85434;

  --bg: #FFFFFF;
  --bg-soft: #F6F6FB;
  --bg-soft-2: #F0EFFA;
  --text: #14132B;
  --text-muted: #62617A;
  --text-faint: #9695AE;
  --line: #E7E6F2;

  --grad-blue: linear-gradient(135deg, #1B0FA0 0%, #3D2AD1 55%, #5B3FE0 100%);
  --grad-coral: linear-gradient(135deg, #FF6D4C 0%, #FF8A5B 100%);
  --grad-mesh: radial-gradient(circle at 15% 20%, rgba(27,15,160,0.10), transparent 45%),
               radial-gradient(circle at 85% 15%, rgba(255,109,76,0.12), transparent 40%),
               radial-gradient(circle at 50% 90%, rgba(27,15,160,0.06), transparent 45%);

  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --radius-pill: 999px;

  --shadow-sm: 0 2px 10px rgba(20,19,43,0.05);
  --shadow-md: 0 12px 32px rgba(20,19,43,0.08);
  --shadow-lg: 0 24px 60px rgba(20,19,43,0.12);
  --shadow-coral: 0 14px 32px rgba(255,109,76,0.32);
  --shadow-blue: 0 14px 32px rgba(27,15,160,0.28);

  --container: 1200px;
  --section-pad: clamp(64px, 9vw, 128px);

  --ease: cubic-bezier(.25,.8,.35,1);
}

*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

body{
  margin:0;
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  font-size: 16px;
  overflow-x: hidden;
}

h1,h2,h3,h4{
  font-family:'Poppins', sans-serif;
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 .5em;
  letter-spacing: -0.01em;
  color: var(--text);
}
h1{ font-weight: 800; }

p{ margin: 0 0 1em; color: var(--text-muted); }
a{ color: inherit; text-decoration: none; }
img{ max-width: 100%; display:block; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family: inherit; cursor: pointer; }

.container{
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}

section{ padding: var(--section-pad) 0; }

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Manrope', sans-serif;
  font-weight: 700;
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-blue);
  background: var(--bg-soft-2);
  padding: 7px 16px;
  border-radius: var(--radius-pill);
  margin-bottom: 20px;
}
.eyebrow::before{
  content:'';
  width:6px; height:6px; border-radius:50%;
  background: var(--coral);
  display:inline-block;
}

.section-head{
  max-width: 640px;
  margin: 0 0 56px;
}
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size: clamp(30px, 3.6vw, 44px); }
.section-head p{ font-size: 17px; margin-top: 14px; }

/* ---------- Buttons ---------- */
.btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content:center;
  gap: 10px;
  padding: 15px 30px;
  font-family:'Manrope', sans-serif;
  font-weight: 700;
  font-size: 15px;
  border-radius: var(--radius-pill);
  border: none;
  overflow: hidden;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  white-space: nowrap;
}
.btn:active{ transform: scale(0.97); }
.btn svg{ width:18px; height:18px; flex-shrink:0; }

.btn-coral{
  background: var(--grad-coral);
  color: #fff;
  box-shadow: var(--shadow-coral);
}
.btn-coral:hover{ transform: translateY(-3px); box-shadow: 0 20px 40px rgba(255,109,76,0.4); }

.btn-outline{
  background: transparent;
  color: var(--ink-blue);
  border: 1.5px solid var(--line);
}
.btn-outline:hover{ border-color: var(--ink-blue); background: var(--bg-soft-2); transform: translateY(-3px); }

.btn-white{
  background: #fff;
  color: var(--ink-blue);
  box-shadow: var(--shadow-md);
}
.btn-white:hover{ transform: translateY(-3px); box-shadow: var(--shadow-lg); }

.btn-ghost-light{
  background: rgba(255,255,255,0.12);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.35);
  backdrop-filter: blur(6px);
}
.btn-ghost-light:hover{ background: rgba(255,255,255,0.2); transform: translateY(-3px); }

.btn-sm{ padding: 11px 20px; font-size: 13.5px; }

/* ripple */
.btn .ripple{
  position:absolute; border-radius:50%;
  background: rgba(255,255,255,0.55);
  transform: scale(0);
  animation: ripple .6s ease-out;
  pointer-events:none;
}
@keyframes ripple{ to{ transform: scale(3.2); opacity:0; } }

/* ---------- Header ---------- */
.site-header{
  position: fixed;
  top:0; left:0; right:0;
  z-index: 1000;
  padding: 18px 0;
  transition: padding .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
}
.site-header .header-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: var(--radius-pill);
  padding: 10px 12px 10px 22px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .3s var(--ease), background .3s var(--ease);
}
.site-header.scrolled .header-inner{
  box-shadow: var(--shadow-md);
  background: rgba(255,255,255,0.88);
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand img{ height: 40px; width:auto; }
.brand-name{ font-family:'Poppins',sans-serif; font-weight:700; font-size:15.5px; color: var(--text); letter-spacing: -0.01em; line-height:1.15; }
.brand-name span{ display:block; font-family:'Manrope',sans-serif; font-weight:600; font-size:10.5px; letter-spacing:0.12em; color: var(--text-faint); text-transform:uppercase; margin-top:1px;}

.main-nav ul{ display:flex; align-items:center; gap: 6px; }
.main-nav a{
  font-family:'Manrope', sans-serif;
  font-weight: 600;
  font-size: 14.5px;
  color: var(--text);
  padding: 10px 16px;
  border-radius: var(--radius-pill);
  transition: background .25s var(--ease), color .25s var(--ease);
}
.main-nav a:hover{ background: var(--bg-soft-2); color: var(--ink-blue); }
.main-nav a.active{ background: var(--ink-blue); color:#fff; }

.header-cta{ display:flex; align-items:center; gap: 10px; }
.nav-toggle{
  display:none;
  width: 44px; height:44px;
  border-radius:50%;
  border:none;
  background: var(--bg-soft-2);
  align-items:center; justify-content:center;
  flex-direction:column;
  gap:5px;
}
.nav-toggle span{ width:18px; height:2px; background: var(--ink-blue); border-radius:2px; transition: all .3s var(--ease); }
.nav-toggle.open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

.mobile-nav{
  position: fixed; inset:0; z-index: 999;
  background: #fff;
  display:flex; flex-direction:column;
  padding: 110px 32px 40px;
  transform: translateY(-100%);
  transition: transform .45s var(--ease);
}
.mobile-nav.open{ transform: translateY(0); }
.mobile-nav ul{ display:flex; flex-direction:column; gap:6px; }
.mobile-nav a{
  font-family:'Poppins',sans-serif;
  font-size: 26px; font-weight:600;
  padding: 14px 4px;
  border-bottom: 1px solid var(--line);
  display:block;
}
.mobile-nav .mobile-cta{ margin-top: 32px; }
body.nav-locked{ overflow:hidden; }

/* ---------- Hero (shared) ---------- */
.page-hero{
  position:relative;
  padding: clamp(150px,20vw,200px) 0 clamp(70px,10vw,100px);
  background: var(--bg-soft);
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute; inset:0;
  background: var(--grad-mesh);
  pointer-events:none;
}
.page-hero .container{ position:relative; z-index:1; }
.page-hero-inner{ max-width: 720px; }
.page-hero h1{ font-size: clamp(36px, 5vw, 58px); }
.breadcrumb{
  font-family:'Manrope',sans-serif; font-weight:600; font-size:13.5px;
  color: var(--text-faint); text-transform:uppercase; letter-spacing:.08em;
  margin-bottom: 18px; display:flex; gap:8px; align-items:center;
}
.breadcrumb .sep{ color: var(--coral); }

/* ---------- Fade animations ---------- */
[data-reveal]{ opacity:0; transition: opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal="up"]{ transform: translateY(36px); }
[data-reveal="left"]{ transform: translateX(-36px); }
[data-reveal="right"]{ transform: translateX(36px); }
[data-reveal="scale"]{ transform: scale(0.92); }
[data-reveal].in-view{ opacity:1; transform: none; }

/* ---------- Home Hero ---------- */
.hero{
  position: relative;
  padding: clamp(150px,20vw,210px) 0 clamp(90px,12vw,140px);
  background: var(--bg-soft);
  overflow: hidden;
}
.hero::before{ content:''; position:absolute; inset:0; background: var(--grad-mesh); pointer-events:none; }
.hero .container{ position:relative; z-index:1; display:grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items:center; }
.hero-copy h1{ font-size: clamp(38px, 4.6vw, 60px); }
.hero-copy p.lead{ font-size: 18px; max-width: 520px; margin-top: 18px; }
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-trust{ display:flex; align-items:center; gap:22px; margin-top:44px; flex-wrap:wrap; }
.hero-trust-item{ display:flex; align-items:center; gap:10px; }
.hero-trust-item strong{ font-family:'Poppins',sans-serif; font-size:20px; color: var(--ink-blue); display:block; line-height:1; }
.hero-trust-item span{ font-size:12.5px; color: var(--text-faint); font-family:'Manrope',sans-serif; font-weight:600; }

/* Hero visual: layered mock-cards representing design + marketing output */
.hero-visual{ position:relative; height: 460px; }
.hv-card{
  position:absolute;
  background:#fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 18px;
  border: 1px solid var(--line);
}
.hv-card.main{
  width: 78%; top: 8%; left: 6%;
  z-index:3;
  padding:0; overflow:hidden;
}
.hv-card.main img{ width:100%; height:230px; object-fit:cover; }
.hv-card.main .hv-card-body{ padding:18px 20px 22px; }
.hv-card.main .hv-tag{ font-family:'Manrope',sans-serif; font-weight:700; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--coral); }
.hv-card.main h4{ font-size:17px; margin:8px 0 0; }

.hv-card.stat{
  width: 220px; bottom: 4%; right: 0%;
  z-index:4;
}
.hv-card.stat .stat-row{ display:flex; align-items:center; gap:12px; }
.hv-card.stat .icon-box{ width:44px; height:44px; border-radius:12px; background: var(--grad-coral); display:flex; align-items:center; justify-content:center; }
.hv-card.stat .icon-box svg{ width:22px; height:22px; color:#fff; }
.hv-card.stat strong{ font-family:'Poppins',sans-serif; font-size:22px; display:block; }
.hv-card.stat span{ font-size:12px; color:var(--text-faint); }

.hv-card.chip{
  top: 4%; right: 6%;
  padding: 12px 16px;
  z-index:5;
  display:flex; align-items:center; gap:8px;
}
.hv-card.chip span{ font-family:'Manrope',sans-serif; font-weight:700; font-size:13px; }
.hv-card.chip .dot{ width:9px; height:9px; border-radius:50%; background:#2ECC71; box-shadow:0 0 0 4px rgba(46,204,113,0.18); }

.hv-blob{
  position:absolute; width:340px; height:340px; border-radius:50%;
  background: var(--grad-blue);
  filter: blur(60px); opacity:.22;
  top: -40px; left: -60px; z-index:0;
}

/* float animation for cards */
.float{ animation: floaty 6s ease-in-out infinite; }
.float-delay{ animation-delay: -3s; }
@keyframes floaty{ 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-14px);} }

/* ---------- Stats / counters ---------- */
.stats-strip{
  background: var(--ink-blue);
  background: var(--grad-blue);
  padding: 56px 0;
  position:relative;
  overflow:hidden;
}
.stats-strip::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 80% 0%, rgba(255,255,255,0.12), transparent 55%);
}
.stats-grid{ position:relative; display:grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.stat-item{ text-align:center; color:#fff; }
.stat-item .num{ font-family:'Poppins',sans-serif; font-weight:800; font-size: clamp(30px,3.6vw,44px); display:flex; align-items:center; justify-content:center; gap:4px; }
.stat-item .label{ font-family:'Manrope',sans-serif; font-weight:600; font-size:13.5px; color: rgba(255,255,255,0.78); margin-top:6px; letter-spacing:.03em; }

/* ---------- Service cards ---------- */
.services-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap: 26px; }
.service-card{
  background:#fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 34px 28px;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  position: relative;
  overflow:hidden;
}
.service-card:hover{ transform: translateY(-8px); box-shadow: var(--shadow-lg); border-color: transparent; }
.service-card .icon-wrap{
  width: 58px; height:58px; border-radius: 16px;
  background: var(--bg-soft-2);
  display:flex; align-items:center; justify-content:center;
  margin-bottom: 22px;
  transition: background .4s var(--ease), transform .4s var(--ease);
}
.service-card:hover .icon-wrap{ background: var(--grad-coral); transform: rotate(-6deg) scale(1.05); }
.service-card .icon-wrap svg{ width:26px; height:26px; color: var(--ink-blue); transition: color .3s; }
.service-card:hover .icon-wrap svg{ color:#fff; }
.service-card h3{ font-size: 19.5px; margin-bottom:10px; }
.service-card p{ font-size: 14.5px; margin-bottom: 20px; }
.service-card .learn-more{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:13.5px;
  color: var(--ink-blue);
  display:inline-flex; align-items:center; gap:6px;
}
.service-card .learn-more svg{ width:15px; height:15px; transition: transform .3s var(--ease); }
.service-card:hover .learn-more svg{ transform: translateX(4px); }

/* ---------- Why choose us ---------- */
.why-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.why-card{
  background: var(--bg-soft);
  border-radius: var(--radius-md);
  padding: 28px 24px;
  transition: transform .35s var(--ease), background .35s var(--ease);
}
.why-card:hover{ transform: translateY(-6px); background: var(--bg-soft-2); }
.why-card .icon-wrap{ width:46px; height:46px; border-radius:12px; background:#fff; box-shadow: var(--shadow-sm); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.why-card .icon-wrap svg{ width:22px; height:22px; color: var(--coral); }
.why-card h4{ font-size:16px; margin-bottom:6px; }
.why-card p{ font-size:13.5px; margin:0; }

/* ---------- Process ---------- */
.process-track{ position:relative; }
.process-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap: 28px 24px; position:relative; }
.process-item{ position:relative; padding-left: 4px; }
.process-item .step-num{
  font-family:'Poppins',sans-serif; font-weight:800; font-size:14px;
  color:#fff; background: var(--grad-blue);
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.process-item h4{ font-size:17px; margin-bottom:6px; }
.process-item p{ font-size:14px; margin:0; }

/* ---------- Testimonials ---------- */
.testi-track{ display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.testi-card{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-md);
  padding: 30px 26px; display:flex; flex-direction:column; gap: 16px;
  box-shadow: var(--shadow-sm);
}
.stars{ display:flex; gap:3px; }
.stars svg{ width:16px;height:16px; color:#FFB33D; }
.testi-card p.quote{ font-size:14.5px; color: var(--text); margin:0; flex:1; }
.testi-person{ display:flex; align-items:center; gap:12px; }
.testi-avatar{ width:42px;height:42px;border-radius:50%; background: var(--grad-coral); color:#fff; display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-weight:700; font-size:15px; }
.testi-person strong{ display:block; font-size:14px; }
.testi-person span{ display:block; font-size:12px; color: var(--text-faint); }

/* ---------- Final CTA ---------- */
.final-cta{
  position:relative;
  background: var(--grad-blue);
  border-radius: var(--radius-lg);
  padding: clamp(48px,7vw,80px);
  text-align:center;
  overflow:hidden;
  margin: 0 24px;
  max-width: calc(var(--container) - 0px);
  margin-left:auto; margin-right:auto;
}
.final-cta::before{ content:''; position:absolute; inset:0; background: radial-gradient(circle at 20% 20%, rgba(255,109,76,0.25), transparent 45%); }
.final-cta .content{ position:relative; z-index:1; }
.final-cta h2{ color:#fff; font-size: clamp(28px,4vw,42px); max-width:640px; margin:0 auto 14px; }
.final-cta p{ color: rgba(255,255,255,0.8); max-width:520px; margin:0 auto 30px; }
.final-cta .cta-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.site-footer{ background: #0E0A3E; color: rgba(255,255,255,0.7); padding: 72px 0 0; margin-top: var(--section-pad); }
.footer-grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 50px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-brand{ display:flex; align-items:center; gap:10px; margin-bottom: 18px; }
.footer-brand img{ height:38px; background:#fff; border-radius:8px; padding:4px; }
.footer-brand strong{ font-family:'Poppins',sans-serif; color:#fff; font-size:15px; }
.footer-col h5{ font-family:'Poppins',sans-serif; color:#fff; font-size:14.5px; margin-bottom:18px; }
.footer-col ul li{ margin-bottom: 11px; }
.footer-col a{ font-size:14px; transition: color .25s; }
.footer-col a:hover{ color:#fff; }
.footer-desc{ font-size:14px; max-width: 300px; line-height:1.7; }
.footer-social{ display:flex; gap:10px; margin-top:20px; }
.footer-social a{ width:38px;height:38px;border-radius:50%; background: rgba(255,255,255,0.08); display:flex;align-items:center;justify-content:center; transition: background .3s; }
.footer-social a:hover{ background: var(--coral); }
.footer-social svg{ width:16px;height:16px; color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding: 26px 0; font-size:13px; flex-wrap:wrap; gap:10px; }
.footer-bottom a{ color: rgba(255,255,255,0.6); }

/* ---------- Floating WhatsApp button ---------- */
.wa-float{
  position: fixed; bottom: 26px; right: 26px; z-index: 900;
  width: 60px; height:60px; border-radius:50%;
  background: #25D366;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 14px 30px rgba(37,211,102,0.45);
  animation: pulse-wa 2.6s ease-in-out infinite;
}
.wa-float svg{ width:28px;height:28px; color:#fff; }
@keyframes pulse-wa{ 0%,100%{ box-shadow:0 14px 30px rgba(37,211,102,0.45);} 50%{ box-shadow:0 14px 30px rgba(37,211,102,0.7), 0 0 0 10px rgba(37,211,102,0.12);} }

/* ---------- About page specific ---------- */
.story-grid{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items:center; }
.story-visual{ position:relative; }
.story-visual img{ border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.story-badge{
  position:absolute; bottom:-24px; left:-24px;
  background:#fff; border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  padding: 20px 24px; display:flex; align-items:center; gap:14px;
}
.story-badge .icon-box{ width:48px;height:48px;border-radius:12px; background: var(--grad-blue); display:flex;align-items:center;justify-content:center; }
.story-badge .icon-box svg{ width:22px;height:22px;color:#fff; }
.story-badge strong{ font-family:'Poppins',sans-serif; font-size:20px; display:block; }
.story-badge span{ font-size:12px; color: var(--text-faint); }

.mvv-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.mvv-card{ background:#fff; border:1px solid var(--line); border-radius: var(--radius-md); padding:32px 28px; }
.mvv-card .icon-wrap{ width:52px;height:52px;border-radius:14px; background: var(--bg-soft-2); display:flex;align-items:center;justify-content:center; margin-bottom:20px; }
.mvv-card .icon-wrap svg{ width:24px;height:24px; color: var(--ink-blue); }
.mvv-card h3{ font-size:19px; margin-bottom:10px; }
.mvv-card p{ font-size:14.5px; margin:0; }

.values-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.value-chip{ background: var(--bg-soft); border-radius: var(--radius-md); padding: 26px 22px; text-align:center; }
.value-chip .icon-wrap{ width:44px;height:44px;border-radius:50%; background:#fff; box-shadow:var(--shadow-sm); display:flex; align-items:center;justify-content:center; margin: 0 auto 14px; }
.value-chip .icon-wrap svg{ width:20px;height:20px; color: var(--coral); }
.value-chip h4{ font-size:14.5px; margin:0; }

.timeline{ position:relative; max-width: 760px; margin: 0 auto; }
.timeline::before{ content:''; position:absolute; left: 20px; top:6px; bottom:6px; width:2px; background: var(--line); }
.timeline-item{ position:relative; padding-left: 60px; margin-bottom: 40px; }
.timeline-item:last-child{ margin-bottom:0; }
.timeline-dot{ position:absolute; left:9px; top:2px; width:24px;height:24px;border-radius:50%; background: var(--grad-coral); border:4px solid #fff; box-shadow: 0 0 0 2px var(--coral); }
.timeline-item h4{ font-size:16.5px; margin-bottom:6px; }
.timeline-item p{ margin:0; font-size:14px; }
.timeline-year{ font-family:'Manrope',sans-serif; font-weight:700; font-size:12px; color: var(--coral); text-transform:uppercase; letter-spacing:.08em; margin-bottom:4px; display:block; }

.achieve-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.achieve-card{ text-align:center; padding: 30px 20px; border-radius: var(--radius-md); background:#fff; border:1px solid var(--line); }
.achieve-card .num{ font-family:'Poppins',sans-serif; font-weight:800; font-size: 34px; color: var(--ink-blue); }
.achieve-card .label{ font-size:13px; color: var(--text-faint); margin-top:4px; }

/* ---------- Services page specific ---------- */
.service-block{ padding: 60px 0; border-bottom: 1px solid var(--line); }
.service-block:last-child{ border-bottom:none; }
.service-block-head{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap: 40px; align-items:start; margin-bottom: 40px; }
.service-block-head .icon-wrap{ width:60px;height:60px;border-radius:16px; background: var(--grad-blue); display:flex;align-items:center;justify-content:center; margin-bottom:22px; }
.service-block-head .icon-wrap svg{ width:28px;height:28px;color:#fff; }
.service-block-head.reverse{ direction: rtl; }
.service-block-head.reverse > *{ direction: ltr; }
.chip-list{ display:flex; flex-wrap:wrap; gap:10px; }
.chip-list li{
  font-family:'Manrope',sans-serif; font-weight:600; font-size:13.5px;
  background: var(--bg-soft); border:1px solid var(--line);
  padding: 10px 16px; border-radius: var(--radius-pill);
  display:flex; align-items:center; gap:8px;
  transition: background .3s, border-color .3s, transform .3s;
}
.chip-list li:hover{ background: var(--bg-soft-2); border-color: var(--ink-blue); transform: translateY(-2px); }
.chip-list li svg{ width:14px;height:14px; color: var(--coral); }
.service-block-alt{ background: var(--bg-soft); }

.cta-inline{
  display:flex; align-items:center; justify-content:space-between;
  background: #fff; border:1px solid var(--line); border-radius: var(--radius-md);
  padding: 22px 28px; margin-top: 26px; gap: 20px; flex-wrap:wrap;
}
.cta-inline p{ margin:0; font-size:14.5px; font-weight:600; color: var(--text); }

/* ---------- Contact page ---------- */
.contact-grid{ display:grid; grid-template-columns: 0.85fr 1.15fr; gap: 48px; align-items:start; }
.contact-info-card{ background: var(--grad-blue); color:#fff; border-radius: var(--radius-lg); padding: 40px 34px; }
.contact-info-card h3{ color:#fff; font-size: 22px; }
.contact-info-card p{ color: rgba(255,255,255,0.78); font-size:14.5px; }
.contact-row{ display:flex; align-items:flex-start; gap:14px; padding: 16px 0; border-top: 1px solid rgba(255,255,255,0.15); }
.contact-row:first-of-type{ border-top:none; }
.contact-row .icon-box{ width:42px;height:42px;border-radius:12px; background: rgba(255,255,255,0.14); display:flex;align-items:center;justify-content:center; flex-shrink:0; }
.contact-row .icon-box svg{ width:19px;height:19px; color:#fff; }
.contact-row strong{ display:block; font-size:14.5px; }
.contact-row span{ font-size:13.5px; color: rgba(255,255,255,0.75); }

.contact-form-card{ background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: 40px; box-shadow: var(--shadow-md); }
.form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-group{ display:flex; flex-direction:column; gap:8px; margin-bottom: 18px; }
.form-group.full{ grid-column: 1 / -1; }
.form-group label{ font-family:'Manrope',sans-serif; font-weight:700; font-size:13px; color: var(--text); }
.form-group input, .form-group select, .form-group textarea{
  font-family:'Inter',sans-serif; font-size:14.5px;
  padding: 13px 16px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--line); background: var(--bg-soft);
  transition: border-color .25s, background .25s;
  color: var(--text);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{
  outline:none; border-color: var(--ink-blue); background:#fff;
}
.form-group textarea{ resize: vertical; min-height: 110px; font-family:'Inter',sans-serif; }
.quick-btns{ display:flex; flex-wrap:wrap; gap:10px; margin-top: 6px; margin-bottom: 24px;}
.quick-btn{
  font-family:'Manrope',sans-serif; font-weight:600; font-size:13px;
  padding: 9px 15px; border-radius: var(--radius-pill);
  border: 1.5px solid var(--line); background: var(--bg-soft);
  transition: all .25s;
}
.quick-btn.active, .quick-btn:hover{ background: var(--ink-blue); border-color: var(--ink-blue); color:#fff; }

.map-wrap{ border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-md); border:1px solid var(--line); }
.map-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.map-card iframe{ width:100%; height: 280px; border:0; display:block; }
.map-card-label{ background:#fff; padding: 16px 20px; display:flex; align-items:center; gap:10px; border-top:1px solid var(--line); }
.map-card-label svg{ width:18px;height:18px; color: var(--coral); }
.map-card-label strong{ font-size:14px; }

/* ---------- Utility ---------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }

/* ---------- Responsive ---------- */
@media (max-width: 1080px){
  .services-grid{ grid-template-columns: repeat(2,1fr); }
  .why-grid{ grid-template-columns: repeat(2,1fr); }
  .process-grid{ grid-template-columns: repeat(2,1fr); }
  .testi-track{ grid-template-columns: 1fr; }
  .stats-grid{ grid-template-columns: repeat(2,1fr); gap: 32px; }
  .footer-grid{ grid-template-columns: 1fr 1fr; }
  .mvv-grid{ grid-template-columns: 1fr; }
  .values-grid{ grid-template-columns: repeat(2,1fr); }
  .achieve-grid{ grid-template-columns: repeat(2,1fr); }
  .map-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 920px){
  .main-nav, .header-cta .btn-outline{ display:none; }
  .nav-toggle{ display:flex; }
  .hero .container{ grid-template-columns: 1fr; }
  .hero-visual{ height: 360px; margin-top: 20px; }
  .story-grid{ grid-template-columns:1fr; }
  .service-block-head{ grid-template-columns:1fr; }
  .service-block-head.reverse{ direction: ltr; }
  .contact-grid{ grid-template-columns:1fr; }
}

@media (max-width: 680px){
  section{ padding: 56px 0; }
  .services-grid, .why-grid, .process-grid, .values-grid, .achieve-grid{ grid-template-columns: 1fr; }
  .stats-grid{ grid-template-columns: repeat(2,1fr); }
  .footer-grid{ grid-template-columns: 1fr; gap: 30px; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .form-grid{ grid-template-columns:1fr; }
  .story-badge{ position: static; margin-top: -40px; margin-left:16px; margin-right:16px; }
  .final-cta{ margin: 0 16px; }
  .cta-inline{ flex-direction:column; align-items:flex-start; }
}
