@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

html, body {
  width: 100%;
  overflow-x: hidden;
}

:root{
  --brand-blue:#192F89;
  --accent:#1174BA;
  --card-shadow:0 8px 24px rgba(25,47,137,.08);
  --card-shadow-hover:0 16px 40px rgba(25,47,137,.18);
  --hero-h:60vh;
  --hero-min:420px;
}

/* =========================
   HERO SECTION
========================== */
.hero-section{
  position:relative;
  width:100%;
  height:var(--hero-h);
  min-height:var(--hero-min);
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden; color:#fff;
  background:url("/img/projects/projects.jpg") center/cover no-repeat;
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(25,47,137,.85),rgba(17,116,186,.75));}
.hero-content{position:relative;z-index:1;padding:2rem 1.5rem;max-width:900px;opacity:0;transform:translateY(24px);transition:opacity 1s,transform 1s;}
.hero-content.visible{opacity:1;transform:translateY(0);}
.hero-title{font-family:Inter,sans-serif;font-weight:800;font-size:clamp(2.5rem,5vw,4rem);margin:0 0 1rem;text-shadow:0 8px 32px rgba(0,0,0,.4);letter-spacing:.03em;line-height:1.1;}
.hero-subtitle{font-family:Inter,sans-serif;font-size:clamp(1rem,2vw,1.3rem);font-weight:400;opacity:.95;max-width:600px;margin:0 auto;text-shadow:0 4px 16px rgba(0,0,0,.3);line-height:1.6;}

/* =========================
   SECTION STYLING
========================== */
.content-section{
  background: #f5f9fc;
  padding: 80px 0 56px;
}

/* =========================
   SECTION HEADER
========================== */
.section-header{
  text-align:center;
  margin-bottom:48px;
  opacity:0;
  transform:translateY(20px);
}
.section-header.visible{
  opacity:1;
  transform:translateY(0);
  transition:opacity .8s ease, transform .8s ease;
}

.section-eyebrow{
  font-family:Inter,sans-serif;
  color:var(--accent);
  font-size:.9rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin:0 0 12px;
}

.section-title{
  font-family:Inter,sans-serif;
  font-size:clamp(2rem,4vw,2.75rem);
  font-weight:800;
  color:var(--brand-blue);
  margin:0 0 24px;
  line-height:1.2;
  position:relative;
  display:inline-block;
  padding-bottom:12px;
}

.section-title::after{
  content:"";
  position:absolute;
  bottom:-8px;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:4px;
  background:linear-gradient(90deg, var(--accent), var(--brand-blue));
  border-radius:2px;
}

.section-description{
  font-family:Inter,sans-serif;
  font-size:1.05rem;
  color:#5a6c8f;
  max-width:700px;
  margin:0 auto;
  line-height:1.7;
}

/* Video Autogate: di area card di bawah photo, lebar sama dengan grid kolom foto, rapat ke foto */
.airport-gallery-below-photo.autogate-video-compact {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  width: 100%;
  box-sizing: border-box;
}
/* Override: video card full lebar kolom preview (sama dengan .airport-gallery-grid), tanpa border-radius & hover */
.airport-gallery-preview .airport-gallery-below-photo .autogate-single-video-card {
  max-width: none;
  width: 100%;
  margin: 0;
  box-sizing: border-box;
  border-radius: 0;
}
.airport-gallery-preview .airport-gallery-below-photo .autogate-single-video-card:hover {
  transform: none;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
  border-color: #e8eef5;
}
.airport-gallery-preview .airport-gallery-below-photo .autogate-single-video-card:hover .autogate-video-play {
  background: rgba(0, 0, 0, 0.25);
}

.autogate-video-compact {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.autogate-video-compact .autogate-single-video-card {
  display: flex;
  align-items: stretch;
  max-width: 560px;
  margin: 0 auto;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #e8eef5;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.2s ease;
}

.autogate-video-compact .autogate-single-video-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border-color: var(--accent, #0a83c7);
}

.autogate-video-compact .autogate-video-thumb {
  position: relative;
  flex: 0 0 200px;
  width: 200px;
  min-height: 112px;
  background: linear-gradient(135deg, #e8eef5, #f0f4f9);
  overflow: hidden;
}

.autogate-video-compact .autogate-video-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.autogate-video-compact .autogate-video-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.25);
  color: #fff;
  transition: background 0.2s ease;
}

.autogate-video-compact .autogate-single-video-card:hover .autogate-video-play {
  background: rgba(0, 0, 0, 0.4);
}

.autogate-video-compact .autogate-video-play svg {
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

.autogate-video-compact .autogate-video-meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 16px 20px;
  min-width: 0;
}

.autogate-video-compact .autogate-video-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--accent, #0a83c7);
  text-transform: uppercase;
}

.autogate-video-compact .autogate-video-title {
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.3;
}

.autogate-video-compact .autogate-video-hint {
  font-size: 0.8rem;
  color: #64748b;
  line-height: 1.4;
  margin-top: 2px;
}

@media (max-width: 600px) {
  .autogate-video-compact .autogate-single-video-card {
    flex-direction: column;
    max-width: 100%;
  }
  .autogate-video-compact .autogate-video-thumb {
    flex: 0 0 auto;
    width: 100%;
    min-height: 180px;
  }
  .autogate-video-compact .autogate-video-meta {
    padding: 14px 16px;
  }
  .autogate-video-compact .autogate-video-title {
    font-size: 0.95rem;
  }
}

/* Video Card */
.video-card{
 
  min-width:calc(25% - 21px);
  background:#fff;
  border-radius:20px;
  overflow:hidden;
 box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  cursor:pointer;
  position:relative;
  border:1px solid #e8eef5;
}

.video-card:hover{
  transform:translateY(-12px);
box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;
  border-color:var(--accent);
}

.video-thumbnail-wrapper{
  position:relative;
  width:100%;
  padding-bottom:65%;
  overflow:hidden;
  background:linear-gradient(135deg,#e8eef5,#f5f8fc);
}

.video-thumbnail{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}

.video-card:hover .video-thumbnail{
  transform:scale(1.08);
}

.video-play-icon{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:70px;
  height:70px;
  background:rgba(255,255,255,0.98);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  box-shadow:0 8px 32px rgba(25,47,137,.25);
  z-index:2;
  border:3px solid rgba(25,47,137,0.1);
}

.video-play-icon::after{
  content:'';
  width:0;
  height:0;
  border-left:24px solid var(--brand-blue);
  border-top:14px solid transparent;
  border-bottom:14px solid transparent;
  margin-left:6px;
}

.video-card:hover .video-play-icon{
  transform:translate(-50%,-50%) scale(1.2);
  background:#fff;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;
  border-color:var(--accent);
}

.video-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(25,47,137,0.95) 100%);
  opacity:0;
  transition:opacity .35s ease;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:20px;
}

.video-card:hover .video-overlay{
  opacity:1;
}

.video-card-title{
  font-family:Inter,sans-serif;
  font-size:.9rem;
  font-weight:600;
  color:#fff;
  line-height:1.5;
  text-shadow:0 2px 12px rgba(0,0,0,.4);
  margin:0;
  letter-spacing:.01em;
}

.video-card-year{
  font-family:Inter,sans-serif;
  font-size:.78rem;
  color:rgba(255,255,255,0.95);
  margin-top:6px;
  font-weight:400;
  letter-spacing:.02em;
}

.video-info{
  padding:18px 20px;
  background:#fff;
  border-top:1px solid #f5f5f5;
}

.video-info-title{
  font-family:Inter,sans-serif;
  font-size:1rem;
  font-weight:600;
  color:var(--brand-blue);
  margin:0 0 6px;
  line-height:1.5;
  display:-webkit-box;
  line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-overflow:ellipsis;
  min-height:3em;
}

.video-info-type{
  font-family:Inter,sans-serif;
  font-size:.82rem;
  color:#8b92a8;
  margin:0;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:600;
}

/* =========================
   PROJECT CATEGORIES SECTION - EXACT MATCH TO IMAGE
========================== */
.project-categories-section {
  background: #fff;
  padding: 80px 0 100px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .8s ease, transform .8s ease;
}

.project-categories-section.visible {
  opacity: 1;
  transform: translateY(0);
}

.project-categories-grid {
  display: flex;
  gap: 20px;
  padding: 0 20px;
  max-width: 1400px;
  margin: 0 auto;
  justify-content: center;
  flex-wrap: wrap;
}

.project-category-card {
  flex: 0 1 calc(25% - 15px);
  min-width: 260px;
  max-width: 340px;
  background: #77d2e1;
  border-radius: 24px;
  padding: 2.5rem 2rem 2rem;
  text-align: left;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 340px;
  transition: all 0.3s ease;
  box-shadow: none;
}

.project-category-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.category-card-title {
  font-family: Inter, sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.3;
  margin: 0 0 1rem;
  color: #0A83C7;
  transition: color 0.3s ease;
}

.category-card-description {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  color: #4A5568;
  margin: 0 0 auto;
  line-height: 1.6;
  transition: color 0.3s ease;
  flex-grow: 1;
  opacity: 0;
  height: 0;
  overflow: hidden;
}

/* Icon Container at Bottom Left */
.category-icon {
  width: 56px;
  height: 56px;
  background: #0A83C7;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  box-shadow: 0 4px 12px rgba(10, 131, 199, 0.25);
  transition: all 0.3s ease;
  align-self: flex-start;
}

.project-category-card:hover .category-icon {
  transform: scale(1.08);
  box-shadow: 0 6px 16px rgba(10, 131, 199, 0.35);
}

.category-icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* =========================
   VIDEO MODAL
========================== */
.modal-backdrop.show{
  opacity:.4;
  background:rgba(0,0,0,0.4);
}

.modal-content{
  background:transparent;
  border:none;
  box-shadow:none;
}

.modal-body{
  padding:0px;
  position:relative;
}

.video-modal-wrapper{
  position:relative;
  max-width:900px;
  margin:0 auto;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
}

.modal-dialog {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  height: 100%;
}

.modal-header-section{
  background:linear-gradient(135deg, var(--brand-blue), var(--accent));
  padding:24px 32px;
  color:#fff;
}

.modal-video-title{
  font-family:Inter,sans-serif;
  font-size:1.3rem;
  font-weight:700;
  margin:0 0 4px;
  line-height:1.3;
}

.modal-video-subtitle{
  font-family:Inter,sans-serif;
  font-size:.95rem;
  opacity:.9;
  margin:0;
}

.modal-video-container{
  position:relative;
  width:100%;
  padding-bottom:56.25%;
  background:#000;
}

.modal-video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
}

.modal-footer-section {
  background: white;
  padding: 1.25rem 2rem;
  border-top: 1px solid #e5e7eb;
  display: flex;
  justify-content: flex-end;
}

.modal-close-btn {
  padding: 0.75rem 2rem;
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--accent) 100%);
  color: white;
  border: none;
  border-radius: 8px;
  font-weight: 500;
  font-size: 0.9375rem;
  font-family: Inter, sans-serif;
  box-shadow: 0 2px 8px rgba(25, 47, 137, 0.3);
  cursor: pointer;
  transition: all 0.2s ease;
}

.modal-close-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(25, 47, 137, 0.4);
}

.modal-close-btn:active {
  transform: translateY(0);
}

/* =========================
   RESPONSIVE
========================== */
@media (max-width:1200px){
  .fp-carousel-wrapper{padding:0 60px;}
  .fp-nav{width:52px;height:52px;}
  .fp-nav svg{width:26px;height:26px;}
  .fp-nav.fp-prev{left:-10px;}
  .fp-nav.fp-next{right:-10px;}
  
  .project-category-card {
    flex: 0 1 calc(25% - 15px);
    max-width: none;
  }
}

@media (max-width:992px){
  .content-section{padding:64px 0 52px;}
  .section-header{margin-bottom:40px;}
  .fp-nav{width:50px;height:50px;}
  .fp-nav svg{width:24px;height:24px;}
  .fp-nav.fp-prev{left:-8px;}
  .fp-nav.fp-next{right:-8px;}
  .video-info{padding:16px 18px;}
  .video-info-title{font-size:.95rem;min-height:2.85em;}
  
  .project-categories-section {
    padding: 64px 0 80px;
  }
  
  .project-category-card {
    flex: 0 1 calc(50% - 15px);
    min-height: 320px;
  }
}

@media (max-width:768px){
  :root{--hero-h:52vh;--hero-min:360px;}
  .content-section{padding:56px 0 48px;}
  .section-header{margin-bottom:32px;}
  .fp-nav{width:46px;height:46px;}
  .fp-nav svg{width:22px;height:22px;stroke-width:2.8;}
  .fp-nav.fp-prev{left:-6px;}
  .fp-nav.fp-next{right:-6px;}
  .video-play-icon{width:60px;height:60px;}
  .video-play-icon::after{border-left:20px solid var(--brand-blue);border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:5px;}
  .video-info{padding:14px 16px;}
  .video-info-title{font-size:.9rem;}
  .video-card-title{font-size:.85rem;}
  .modal-body{padding:20px;}
  .modal-header-section{padding:20px 24px;}
  .modal-video-title{font-size:1.1rem;}
  .modal-video-subtitle{font-size:.85rem;}
  .modal-footer-section {
    padding: 1rem 1.25rem;
  }
  .modal-close-btn {
    padding: 0.65rem 1.75rem;
    font-size: 0.875rem;
  }
  
  .project-categories-section {
    padding: 56px 0 72px;
  }
  
  .project-category-card {
    flex: 0 1 calc(50% - 12px);
    min-height: 300px;
    padding: 2rem 1.75rem 1.75rem;
  }
  
  .category-card-title {
    font-size: 1.25rem;
  }
  
  .category-icon {
    width: 52px;
    height: 52px;
  }
  
  .category-icon img {
    width: 26px;
    height: 26px;
  }
}

@media (max-width:780px){
  .fp-nav{width:40px;height:40px;}
  .fp-nav.fp-prev{left:-4px;}
  .fp-nav.fp-next{right:-4px;}
}

@media (max-width:576px){
  :root{--hero-h:48vh;--hero-min:320px;}
  .content-section{padding:48px 0 44px;}
  .section-header{margin-bottom:32px;}
  .section-title{font-size:1.75rem;}
  .section-description{font-size:1rem;}
  .fp-nav{width:36px;height:36px;}
  .fp-nav svg{width:20px;height:20px;}
  .fp-nav.fp-prev{left:-2px;}
  .fp-nav.fp-next{right:-2px;}
  .video-thumbnail-wrapper{padding-bottom:60%;}
  .video-info{padding:16px;}
  .video-info-title{font-size:.95rem;min-height:auto;}
  .video-play-icon{width:70px;height:70px;}
  .video-play-icon::after{border-left:24px solid var(--brand-blue);border-top:14px solid transparent;border-bottom:14px solid transparent;margin-left:6px;}
  .modal-body{padding:16px;}
  .modal-header-section{padding:18px 20px;}
  .modal-video-title{font-size:1rem;}
  .modal-video-subtitle{font-size:.8rem;}
  .modal-footer-section {
    padding: 0.875rem 1rem;
  }
  
  .project-categories-section {
    padding: 48px 0 64px;
  }
  
  .project-category-card {
    flex: 0 1 100%;
    max-width: 100%;
    min-width: auto;
    min-height: 280px;
  }
  
  .category-card-title {
    font-size: 1.2rem;
  }
}

@media (max-width:480px){
  :root{--hero-h:42vh;--hero-min:280px;}
  .content-section{padding:40px 0 36px;}
  
  .project-categories-section {
    padding: 40px 0 56px;
  }
  
  .project-category-card {
    padding: 2rem 1.5rem 1.5rem;
    min-height: 260px;
  }
  
  .category-card-title {
    font-size: 1.15rem;
  }
  
  .category-icon {
    width: 48px;
    height: 48px;
  }
  
  .category-icon img {
    width: 24px;
    height: 24px;
  }

  .featured-image-title{
    font-size: 1rem !important;
  }

  .airport-map-title{
    font-size: 1rem !important;
  }
}

@media (max-width:350px){
  :root{--hero-h:38vh;--hero-min:250px;}
}
/* =========================
   FINANCIAL PROJECT PORTFOLIO SECTION
========================== */
.financial-portfolio-section {
  background: #f5f9fc;
  padding: 60px 0 48px;
  position: relative;
  overflow: visible;
}

.financial-portfolio-section::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(1100px, 100%);
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(15, 23, 42, 0) 0%, rgba(15, 23, 42, 0.15) 30%, rgba(10, 131, 199, 0.5) 50%, rgba(15, 23, 42, 0.15) 70%, rgba(15, 23, 42, 0) 100%);
}

.financial-portfolio-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 30% 50%, rgba(10, 131, 199, 0.03) 0%, transparent 70%);
  pointer-events: none;
}

.fp-header {
  text-align: center;
  margin-bottom: 48px;
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.fp-badge {
  display: inline-block;
  padding: 8px 20px;
  background: linear-gradient(135deg, rgba(10, 131, 199, 0.1), rgba(119, 210, 225, 0.15));
  border: 1.5px solid rgba(10, 131, 199, 0.3);
  border-radius: 24px;
  font-family: Inter, sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: #0a83c7;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 16px;
}

.fp-title {
  font-family: Inter, sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  color: #0a83c7;
  margin: 0 0 12px;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.fp-subtitle {
  font-family: Inter, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  color: #5a6c8f;
  margin: 0;
  line-height: 1.6;
}

/* Carousel Wrapper - struktur sama dengan carousel-container agar lebar kartu konsisten */
.fp-carousel-wrapper {
  position: relative;
  margin-top: 40px;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 32px;
  padding: 0 60px;
  overflow: visible;
}

/* Navigation Buttons - sama persis dengan carousel-nav agar konsisten */
.fp-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(255,255,255,0.95));
  backdrop-filter: blur(8px);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .35s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 4px 20px rgba(25,47,137,.15), 0 0 0 1px rgba(25,47,137,.08);
  z-index: 3;
  padding: 0;
}

.fp-nav svg {
  width: 28px;
  height: 28px;
  stroke: var(--brand-blue);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: all .35s cubic-bezier(.4,0,.2,1);
}

.fp-nav:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--brand-blue), var(--accent));
  transform: translateY(-50%) scale(1.12);
  box-shadow: 0 8px 32px rgba(25,47,137,.3), 0 0 0 2px rgba(25,47,137,.15);
}

.fp-nav:hover:not(:disabled) svg {
  stroke: #fff;
  transform: scale(1.1);
}

.fp-nav:active {
  transform: translateY(-50%) scale(1.02);
}

.fp-nav:disabled {
  opacity: 0.3;
  cursor: not-allowed;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.6);
}

.fp-nav:disabled:hover {
  background: rgba(255,255,255,0.6);
  transform: translateY(-50%);
  box-shadow: 0 4px 20px rgba(25,47,137,.15), 0 0 0 1px rgba(25,47,137,.08);
}

.fp-nav:disabled svg {
  stroke: #9ca3af;
}

.fp-nav.fp-prev { left: -12px; }
.fp-nav.fp-next { right: -12px; }

/* Carousel Container */
.fp-carousel {
  overflow: hidden;
  position: relative;
  padding: 12px 0;
}

.fp-track {
  display: flex;
  gap: 28px;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Financial Portfolio Card - lebar mengikuti video-card */
.fp-card {
  flex: 0 0 calc(25% - 21px);
  min-width: calc(25% - 21px);
  background: linear-gradient(145deg, #ffffff, #f8fbfd);
  border: 1.5px solid rgba(10, 131, 199, 0.15);
  border-radius: 20px;
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-height: 340px;
  position: relative;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}

.fp-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(10, 131, 199, 0.02) 0%, rgba(119, 210, 225, 0.04) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.fp-card:hover {
  transform: translateY(-8px);
  border-color: #0a83c7;
  box-shadow: 0 12px 40px rgba(10, 131, 199, 0.18);
}

.fp-card:hover::before {
  opacity: 1;
}

/* Card Number Badge */
.fp-card-number {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #77d2e1, #0a83c7);
  color: #ffffff;
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(10, 131, 199, 0.25);
  z-index: 1;
}

/* Logo Container */
.fp-card-logo {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: #ffffff;
  border: 3px solid rgba(10, 131, 199, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  padding: 20px;
  box-shadow: 0 4px 16px rgba(10, 131, 199, 0.08);
  transition: all 0.3s ease;
}

.fp-card:hover .fp-card-logo {
  border-color: #0a83c7;
  box-shadow: 0 6px 24px rgba(10, 131, 199, 0.2);
  transform: scale(1.05);
}

.fp-card-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: grayscale(0.2);
  transition: filter 0.3s ease;
}

.fp-card:hover .fp-card-logo img {
  filter: grayscale(0);
}

/* Card Title */
.fp-card-title {
  font-family: Inter, sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: #0a83c7;
  margin: 0 0 12px;
  line-height: 1.4;
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Card Description */
.fp-card-desc {
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: #5a6c8f;
  line-height: 1.6;
  margin: 0;
  flex-grow: 1;
}

/* Dots Navigation */
.fp-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  max-width: 1200px;
  margin: 0 auto;
}

.fp-dot {
  width: 28px;
  height: 6px;
  border-radius: 3px;
  background: rgba(10, 131, 199, 0.2);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fp-dot.active {
  width: 40px;
  background: linear-gradient(90deg, #0a83c7, #77d2e1);
  box-shadow: 0 2px 8px rgba(10, 131, 199, 0.3);
}

.fp-dot:hover:not(.active) {
  background: rgba(10, 131, 199, 0.5);
  transform: scale(1.15);
}

/* =========================
   RESPONSIVE
========================== */
@media (max-width: 1200px) {
  .fp-card {
    flex: 0 0 calc(33.333% - 18.67px);
    min-width: calc(33.333% - 18.67px);
  }
}

@media (max-width: 992px) {
  .financial-portfolio-section {
    padding: 50px 0 52px;
  }

  .fp-title {
    font-size: 2rem;
  }

  .fp-subtitle {
    font-size: 1rem;
  }

  .fp-carousel-wrapper {
    padding: 0 50px;
  }

  .fp-card {
    flex: 0 0 calc(50% - 14px);
    min-width: calc(50% - 14px);
    min-height: 320px;
    padding: 28px 24px;
  }

  .fp-card-logo {
    width: 90px;
    height: 90px;
    margin-bottom: 20px;
  }

  .fp-nav {
    width: 44px;
    height: 44px;
  }
  .fp-nav svg {
    width: 22px;
    height: 22px;
  }
}

@media (max-width: 576px) {
  .financial-portfolio-section {
    padding: 40px 0 44px;
  }

  .fp-header {
    margin-bottom: 36px;
  }

  .fp-badge {
    font-size: 0.75rem;
    padding: 6px 16px;
  }

  .fp-title {
    font-size: 1.75rem;
  }

  .fp-subtitle {
    font-size: 0.95rem;
  }

  .fp-carousel-wrapper {
    padding: 0 40px;
    margin-bottom: 24px;
  }

  .fp-card {
    flex: 0 0 100%;
    min-width: 100%;
    min-height: 300px;
    padding: 24px 20px;
  }

  .fp-card-number {
    width: 32px;
    height: 32px;
    font-size: 0.8rem;
    top: 16px;
    right: 16px;
  }

  .fp-card-logo {
    width: 80px;
    height: 80px;
    padding: 16px;
    margin-bottom: 18px;
  }

  .fp-card-title {
    font-size: 1.05rem;
    min-height: 45px;
  }

  .fp-card-desc {
    font-size: 0.85rem;
  }

  .fp-nav {
    width: 40px;
    height: 40px;
  }
  .fp-nav svg {
    width: 20px;
    height: 20px;
  }
}

@media (max-width: 480px) {
  .financial-portfolio-section {
    padding: 36px 0 40px;
  }

  .fp-carousel-wrapper {
    padding: 0 36px;
  }

  .fp-card {
    min-height: 280px;
  }

  .fp-title {
    font-size: 1.5rem;
  }

  .fp-nav {
    width: 36px;
    height: 36px;
  }
  .fp-nav svg {
    width: 18px;
    height: 18px;
  }
  .fp-nav.fp-prev { left: 0; }
  .fp-nav.fp-next { right: 0; }
}

/* =========================
   FEATURED IMAGE SECTION - FULL WIDTH WITH OVERLAY
========================== */
.featured-image-section {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  margin-top: 50px;
  margin-bottom: 80px;
  overflow: hidden;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 0.8s ease forwards;
  animation-delay: 0.2s;
}

.featured-airport-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  max-height: 600px;
  min-height: 450px;
  border-radius: 18px 18px 0px 0px;
  filter: brightness(0.85);
  transition: all 0.4s ease;
}

.featured-image-section:hover .featured-airport-image {
  transform: scale(1.02);
  filter: brightness(0.75);
}

/* Overlay Content */
.featured-overlay {
  position: absolute;
  top: 50%;
  left: 8%;
  transform: translateY(-50%);
  color: #ffffff;
  z-index: 2;
  max-width: 500px;
}

.overlay-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 24px;
}

.overlay-badge {
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.overlay-project {
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.9);
}

.overlay-title {
  font-family: Inter, sans-serif;
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 800;
  color: #ffffff;
  margin: 0 0 12px;
  line-height: 1;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
  letter-spacing: -0.02em;
}

.overlay-subtitle {
  font-family: Inter, sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 300;
  color: rgba(255, 255, 255, 0.95);
  margin: 0;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  letter-spacing: 0.02em;
}

/* Client Badge */
.client-badge {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(91deg, rgb(119 210 225 / 33%) 0%, rgb(119 210 225 / 22%) 100%);
  backdrop-filter: blur(8px);
  padding: 20px 8%;
  display: flex;
  align-items: center;
  gap: 20px;
  z-index: 3;
  border-top: 3px solid rgba(255, 255, 255, 0.3);
}

.client-logo {
  width: 80px;
  height: 80px;
  object-fit: contain;
  background: #ffffff;
  border-radius: 50%;
  padding: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.client-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.client-name {
  font-family: Inter, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0;
  line-height: 1.3;
}

.client-country {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #2d2d2d;
  margin: 0;
  line-height: 1.3;
}

/* =========================
   AIRPORT GALLERY ROW 
========================== */
.airport-gallery-row {
  width: min(1100px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(220px, 0.9fr) minmax(320px, 1.6fr);
  gap: 0;
  align-items: stretch;
  background: #ffffff;
  border-radius: 0 0 20px 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.12);
  overflow: hidden;
}

.airport-gallery-actions {
  background: transparent;
  border-radius: 0;
  padding: 24px;
  border: none;
  box-shadow: none;
}

.airport-gallery-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #6b7d91;
  margin: 0 0 8px;
}

.airport-gallery-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #0b3a66;
  margin: 0 0 20px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.airport-gallery-description {
  font-size: 0.9rem;
  line-height: 1.65;
  color: #64748b;
  margin: 20px 0 0 0;
  padding: 0;
}

.airport-gallery-stat-badge {
  margin-top: 14px;
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  gap: 10px;
  padding: 10px 20px;
  border-radius: 12px;
  border: 1px solid rgba(10, 131, 199, 0.3);
  background: linear-gradient(135deg, rgba(219, 234, 254, 0.95) 0%, rgba(186, 230, 253, 0.9) 100%);
  color: #0b3a66;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 2px 8px rgba(10, 131, 199, 0.15);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  cursor: default;
}

.airport-gallery-stat-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(10, 131, 199, 0.2);
  border-color: rgba(10, 131, 199, 0.45);
}

.airport-gallery-stat-badge::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0ea5e9, #0a83c7);
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.35);
  flex-shrink: 0;
}

.airport-gallery-buttons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.airport-gallery-button {
  width: 100%;
  text-align: center;
  border-radius: 16px;
  padding: 16px 12px;
  border: 1.5px solid rgba(10, 131, 199, 0.18);
  background: #ffffff;
  color: #0b3a66;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
  min-height: 100px;
  position: relative;
  overflow: hidden;
}

.airport-gallery-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, rgba(10, 131, 199, 0.25), transparent);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.airport-gallery-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(10, 131, 199, 0.15);
  border-color: rgba(10, 131, 199, 0.35);
  background: linear-gradient(160deg, #f0f9ff 0%, #e0f2fe 100%);
}

.airport-gallery-button:hover::before {
  opacity: 1;
}

/* Aktif: hanya background icon yang berubah, tombol tetap seperti biasa */
.airport-gallery-button.active {
  background: #ffffff;
  color: #0b3a66;
  border-color: rgba(10, 131, 199, 0.18);
  box-shadow: none;
}

.airport-gallery-button.active::before {
  opacity: 0;
}

.airport-gallery-button-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: linear-gradient(135deg, #e0f2fe 0%, #bae6fd 100%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #0b3a66;
  box-shadow: 0 2px 8px rgba(10, 131, 199, 0.15);
  transition: all 0.25s ease;
}

.airport-gallery-button:hover .airport-gallery-button-icon {
  background: linear-gradient(135deg, #bae6fd 0%, #7dd3fc 100%);
  transform: scale(1.05);
}

.airport-gallery-button.active .airport-gallery-button-icon {
  background: linear-gradient(135deg, #0a83c7 0%, #0284c7 100%);
  box-shadow: 0 4px 12px rgba(10, 131, 199, 0.35);
}

.airport-gallery-button.active .airport-gallery-button-icon img {
  filter: brightness(0) invert(1);
}

.airport-gallery-button-icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  display: block;
  transition: filter 0.25s ease;
}

.airport-gallery-button-label {
  font-size: 0.8rem;
  line-height: 1.2;
}

.airport-gallery-preview {
  background: transparent;
  border-radius: 0 0 16px 16px;
  padding: 0;
  border: none;
  box-shadow: none;
  overflow: hidden;
}

.airport-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  background: #edf2f7;
  min-height: 460px;
  align-content: start;
  padding: 4px;
  border-radius: 0 0 16px 16px;
}

/* Item foto: sel grid dengan aspect-ratio; gambar pakai object-fit: contain agar portrait tidak terpotong */
.ag-grid-item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  min-width: 0;
  min-height: 0;
  cursor: pointer;
  opacity: 0;
  transform: scale(0.96);
  transition: opacity 0.3s ease, transform 0.3s ease;
  border-radius: 4px;
  background: #e2e8f0;
}

.ag-grid-item.ag-visible {
  opacity: 1;
  transform: scale(1);
}

/* contain: foto portrait/landscape tampil utuh, tidak dipotong jadi landscape */
.ag-grid-item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.4s ease;
}

.ag-grid-item:hover img {
  transform: scale(1.08);
}

/* Highlight hover overlay */
.ag-grid-item::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(10, 131, 199, 0.0);
  transition: background 0.3s ease;
}

.ag-grid-item:hover::after {
  background: rgba(10, 131, 199, 0.18);
}

/* Foto pertama lebih besar (featured); tinggi tetap dari aspect-ratio, isi cover */
.ag-grid-item:first-child {
  grid-column: span 2;
  grid-row: span 2;
  aspect-ratio: 3/2;
}

/* Resolusi di atas 768px (layout 3 kolom): foto pertama lebih tinggi agar menutupi area kosong */
@media (min-width: 993px) {
  .airport-gallery-grid .ag-grid-item:first-child {
    aspect-ratio: 4/3;
  }
}

/* =========================
   LIGHTBOX
========================== */
#galleryLightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

#galleryLightbox.active {
  opacity: 1;
  pointer-events: auto;
}

.lb-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.9);
}

.lb-img-wrap {
  position: relative;
  z-index: 1;
  max-width: 90vw;
  max-height: 88vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lb-img {
  max-width: 90vw;
  max-height: 88vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
}

.lb-close {
  position: absolute;
  top: 20px;
  right: 24px;
  z-index: 2;
  background: rgba(255,255,255,0.15);
  border: none;
  color: #fff;
  font-size: 1.4rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}

.lb-close:hover { background: rgba(255,255,255,0.3); }

.lb-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: rgba(255,255,255,0.15);
  border: none;
  color: #fff;
  font-size: 2.2rem;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
  line-height: 1;
}

.lb-nav:hover { background: rgba(255,255,255,0.3); }
.lb-prev { left: 20px; }
.lb-next { right: 20px; }

.lb-counter {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.8);
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  z-index: 2;
  background: rgba(0,0,0,0.4);
  padding: 4px 14px;
  border-radius: 20px;
}

/* =========================
   RESPONSIVE GRID
========================== */
@media (max-width: 992px) {
  .airport-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    min-height: 360px;
  }
  .ag-grid-item:first-child {
    grid-column: span 2;
    grid-row: span 1;
  }
}

@media (max-width: 576px) {
  .airport-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    min-height: 260px;
    gap: 3px;
    padding: 3px;
  }
  .ag-grid-item:first-child {
    grid-column: span 2;
    grid-row: span 1;
  }
}

/* Di bawah 480px: foto terakhir mengisi 2 grid; tinggi sama dengan foto pertama */
@media (max-width: 480px) {
  .airport-gallery-grid .ag-grid-item:first-child,
  .airport-gallery-grid .ag-grid-item:last-child {
    aspect-ratio: 16/9;
  }
  .airport-gallery-grid .ag-grid-item:last-child {
    grid-column: span 2;
    width: 100%;
  }
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================
   RESPONSIVE
========================== */
@media (max-width: 1200px) {
  .featured-airport-image {
    max-height: 550px;
    min-height: 400px;
  }
  
  .overlay-title {
    font-size: 4rem;
  }
  
  .overlay-subtitle {
    font-size: 2rem;
  }
  
  .client-logo {
    width: 70px;
    height: 70px;
  }
}

@media (max-width: 992px) {
  .featured-image-section {
    margin-top: 40px;
    margin-bottom: 60px;
  }
  
  .featured-airport-image {
    max-height: 500px;
    min-height: 350px;
  }
  
  .featured-overlay {
    left: 6%;
  }
  
  .overlay-title {
    font-size: 3.5rem;
  }
  
  .overlay-subtitle {
    font-size: 1.8rem;
  }
  
  .client-badge {
    padding: 18px 6%;
  }
  
  .client-logo {
    width: 65px;
    height: 65px;
  }
  
  .client-name {
    font-size: 1rem;
  }
  
  .client-country {
    font-size: 0.85rem;
  }

  .airport-gallery-row {
    grid-template-columns: 1fr;
  }

  .airport-gallery-buttons {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .airport-gallery-button {
    min-height: 84px;
  }
}

@media (max-width: 768px) {
  .featured-image-section {
    margin-top: 35px;
    margin-bottom: 50px;
  }
  
  .featured-airport-image {
    max-height: 450px;
    min-height: 320px;
  }
  
  .featured-overlay {
    left: 5%;
    max-width: 85%;
  }
  
  .overlay-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 16px;
  }
  
  .overlay-badge,
  .overlay-project {
    font-size: 0.75rem;
  }
  
  .overlay-title {
    font-size: 2.5rem;
  }
  
  .overlay-subtitle {
    font-size: 1.3rem;
  }
  
  .client-badge {
    padding: 16px 5%;
    gap: 16px;
  }
  
  .client-logo {
    width: 60px;
    height: 60px;
  }
  
  .client-name {
    font-size: 0.9rem;
  }
  
  .client-country {
    font-size: 0.8rem;
  }
}

@media (max-width: 576px) {
  .featured-image-section {
    margin-top: 30px;
    margin-bottom: 40px;
  }
  
  .featured-airport-image {
    max-height: 380px;
    min-height: 280px;
  }
  
  .featured-overlay {
    left: 4%;
    max-width: 90%;
  }
  
  .overlay-badge,
  .overlay-project {
    font-size: 0.7rem;
  }
  
  .overlay-title {
    font-size: 2rem;
    margin-bottom: 8px;
  }
  
  .overlay-subtitle {
    font-size: 1.1rem;
  }
  
  .client-badge {
    padding: 14px 4%;
    gap: 12px;
  }
  
  .client-logo {
    width: 50px;
    height: 50px;
  }
  
  .client-name {
    font-size: 0.8rem;
  }
  
  .client-country {
    font-size: 0.72rem;
  }

  .airport-gallery-row {
    gap: 16px;
  }

  .airport-gallery-actions {
    padding: 20px;
  }

  .airport-gallery-buttons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .airport-gallery-image-frame {
    height: 300px;
  }
}

@media (max-width: 480px) {
  .featured-airport-image {
    max-height: 320px;
    min-height: 250px;
  }
  
  .overlay-title {
    font-size: 1.8rem;
  }
  
  .overlay-subtitle {
    font-size: 1rem;
  }
  
  .client-logo {
    width: 45px;
    height: 45px;
  }


  .airport-gallery-buttons {
    gap: 10px;
  }

  .airport-gallery-button {
    min-height: 72px;
    padding: 10px 8px;
  }

  .airport-gallery-button-icon {
    width: 30px;
    height: 30px;
  }

  .airport-gallery-button-icon img {
    width: 18px;
    height: 18px;
  }

  .airport-gallery-button-label {
    font-size: 0.74rem;
  }
}

/* =========================
   AUTOGATE BANNER BELOW HIGHLIGHTS
========================== */

.autogate-banner-section {
  width: min(1100px, 100%);
  margin: 0 auto 60px;
}

/* Satu card: Dhoho section (AOCC, BHS, Radio, Command Center, Video) — tidak terpisah seperti content-section di atas */
.project-dhoho-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.10);
}

.project-dhoho-card .autogate-banner-header {
  padding: 20px 24px 0;
}

/* Hanya gambar pertama (AOCC) rounded di atas */
.project-dhoho-card .aocc-image-wrap {
  border-radius: 18px 18px 0 0;
  box-shadow: none;
}

/* Gambar tengah tanpa radius / shadow terpisah */
.project-dhoho-card .bhs-image-wrap,
.project-dhoho-card .gsr-image-wrap,
.project-dhoho-card .soc-image-wrap {
  border-radius: 0;
  box-shadow: none;
}

/* Row AOCC/BHS/GSR/SOC tanpa radius sendiri — mengalir dalam satu card */
.project-dhoho-card .aocc-bottom-row,
.project-dhoho-card .bhs-bottom-row,
.project-dhoho-card .gsr-bottom-row,
.project-dhoho-card .soc-bottom-row {
  border-radius: 0;
  border-left: none;
  border-right: none;
  box-shadow: none;
}

/* Card: Project Autogate Imigrasi — judul di dalam card seperti Dhoho */
.project-autogate-imigrasi-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.10);
  margin-bottom: 32px;
}

.project-autogate-imigrasi-card .autogate-banner-header {
  padding: 20px 24px 14px;
}

/* Featured image tetap di dalam card (batalkan full-width breakout) */
.project-autogate-imigrasi-card .featured-image-section {
  width: 100%;
  left: auto;
  right: auto;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
  border-radius: 18px 18px 0 0;
}

.project-autogate-imigrasi-card .featured-airport-image {
  border-radius: 18px 18px 0 0;
}

.project-autogate-imigrasi-card .airport-map-section,
.project-autogate-imigrasi-card .airport-gallery-row {
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

/* Header kecil: logo + teks */
.autogate-banner-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding: 0 2px;
}

.autogate-banner-logo {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: 50%;
  flex-shrink: 0;
}

.autogate-banner-header-text {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #0b3a66;
  letter-spacing: 0.01em;
}

/* Judul card project — lebih besar dan sesuai */
.project-autogate-imigrasi-card .autogate-banner-header-text,
.project-dhoho-card .autogate-banner-header-text {
  font-size: clamp(1.25rem, 2.2vw, 1.6rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.project-autogate-imigrasi-card .autogate-banner-header .autogate-banner-logo,
.project-dhoho-card .autogate-banner-header .autogate-banner-logo {
  width: 40px;
  height: 40px;
}

/* Wrapper gambar */
.autogate-banner-image-wrap {
  position: relative;
  width: 100%;
  border-radius: 18px 18px 0 0;  /* ← ubah ini */
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}

/* Gambar utama */
.autogate-banner-img {
  width: 100%;
  height: auto;
  min-height: 360px;
  max-height: 560px;
  object-fit: cover;
  display: block;
  filter: brightness(0.82);
  transition: filter 0.4s ease, transform 0.5s ease;
}

.autogate-banner-image-wrap:hover .autogate-banner-img {
  filter: brightness(0.72);
  transform: scale(1.02);
}

/* Overlay teks di kiri tengah-bawah */
.autogate-banner-overlay {
  position: absolute;
  top: 50%;
  left: 7%;
  transform: translateY(-60%);
  color: #ffffff;
  z-index: 2;
  pointer-events: none;
}

.autogate-banner-title {
  font-family: Inter, sans-serif;
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 800;
  color: #ffffff;
  margin: 0 0 6px;
  line-height: 1;
  text-shadow: 0 4px 24px rgba(0, 0, 0, 0.45);
  letter-spacing: -0.02em;
}

.autogate-banner-subtitle {
  font-family: Inter, sans-serif;
  font-size: clamp(1.2rem, 2.8vw, 2.2rem);
  font-weight: 300;
  color: rgba(255, 255, 255, 0.95);
  margin: 0;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
  letter-spacing: 0.02em;
}

/* Client badge — strip bawah gambar */
.autogate-banner-client {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(91deg, rgba(119, 210, 225, 0.38) 0%, rgba(119, 210, 225, 0.22) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 2px solid rgba(255, 255, 255, 0.28);
  padding: 18px 7%;
  display: flex;
  align-items: center;
  gap: 18px;
  z-index: 3;
}

.autogate-banner-client-logo {
  width: 72px;
  height: 72px;
  object-fit: contain;
  background: #ffffff;
  border-radius: 50%;
  padding: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}

.autogate-banner-client-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.autogate-banner-client-name {
  font-family: Inter, sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0;
  line-height: 1.3;
}

.autogate-banner-client-country {
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: #1e293b;
  margin: 0;
  line-height: 1.3;
}

/* =========================
   RESPONSIVE
========================== */
@media (max-width: 992px) {
  .autogate-banner-img {
    min-height: 300px;
    max-height: 460px;
  }

  .autogate-banner-client-logo {
    width: 60px;
    height: 60px;
  }

  .autogate-banner-client-name {
    font-size: 0.95rem;
  }

  .autogate-banner-client-country {
    font-size: 0.82rem;
  }
}

@media (max-width: 768px) {
  .autogate-banner-section {
    margin-bottom: 40px;
  }

  .autogate-banner-img {
    min-height: 260px;
    max-height: 380px;
  }

  .autogate-banner-overlay {
    left: 5%;
    transform: translateY(-55%);
  }

  .autogate-banner-client {
    padding: 14px 5%;
    gap: 14px;
  }

  .autogate-banner-client-logo {
    width: 52px;
    height: 52px;
  }

  .autogate-banner-client-name {
    font-size: 0.88rem;
  }

  .autogate-banner-client-country {
    font-size: 0.76rem;
  }
}

@media (max-width: 576px) {
  .autogate-banner-section {
    margin-bottom: 32px;
  }

  .autogate-banner-img {
    min-height: 220px;
    max-height: 320px;
  }

  .autogate-banner-overlay {
    left: 4%;
    transform: translateY(-50%);
  }

  .autogate-banner-header-text {
    font-size: 0.88rem;
  }

  .project-autogate-imigrasi-card .autogate-banner-header-text,
  .project-dhoho-card .autogate-banner-header-text {
    font-size: 1.15rem;
  }

  .autogate-banner-logo {
    width: 26px;
    height: 26px;
  }

  .project-autogate-imigrasi-card .autogate-banner-header .autogate-banner-logo,
  .project-dhoho-card .autogate-banner-header .autogate-banner-logo {
    width: 36px;
    height: 36px;
  }

  .autogate-banner-client {
    padding: 12px 4%;
    gap: 12px;
  }

  .autogate-banner-client-logo {
    width: 44px;
    height: 44px;
    padding: 6px;
  }

  .autogate-banner-client-name {
    font-size: 0.82rem;
  }

  .autogate-banner-client-country {
    font-size: 0.7rem;
  }
}

@media (max-width: 400px) {
  .autogate-banner-img {
    min-height: 190px;
    max-height: 280px;
  }
}

/* =========================
   AOCC BOTTOM ROW - 2 KOLOM
========================== */
.aocc-bottom-row {
  display: grid;
  grid-template-columns: 1fr 50%;
  gap: 0;
  background: #ffffff;
  border-radius: 0 0 18px 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-top: none;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.10);
  overflow: hidden;
}

/* KOLOM KIRI */
/* AOCC row: kolom kiri = video, kolom kanan = 4 foto — border pemisah */
.aocc-bottom-row:not(.bhs-bottom-row) .aocc-photos-col {
  border-left: 1px solid rgba(15, 23, 42, 0.08);
}

/* BHS row: kolom kiri = video, kolom kanan = 4 foto — border pemisah */
.bhs-bottom-row .bhs-photos-col {
  border-left: 1px solid rgba(15, 23, 42, 0.08);
}

/* GSR row: format & ukuran sama seperti BHS (50%-50%) */
.gsr-bottom-row {
  grid-template-columns: 1fr 50%;
}

.gsr-bottom-row .gsr-photos-col {
  border-left: 1px solid rgba(15, 23, 42, 0.08);
}

/* SOC row: format & ukuran sama seperti BHS/GSR (50%-50%) */
.soc-bottom-row {
  grid-template-columns: 1fr 50%;
}

.soc-bottom-row .soc-photos-col {
  border-left: 1px solid rgba(15, 23, 42, 0.08);
}

.aocc-desc-col {
  padding: 28px 40px;
  border-right: 1px solid rgba(15, 23, 42, 0.08);

  display:flex;
  flex-direction:column;
  justify-content:flex-start;
gap:18px;
}

.aocc-desc-lead {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  color: #1e293b;
  margin: 0;
  line-height: 1.6;
}

.aocc-desc-body {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.75;
  margin: 0;
}

/* TAMBAHKAN DI BAWAH SINI */
.aocc-desc-lead,
.aocc-desc-body{
  max-width:none;
}

.aocc-desc-tagline {
  font-family: Inter, sans-serif;
  font-size:1.1rem;
  font-weight:900;
  color: #1e293b;
  margin: 0;
  font-style: normal;
}

/* KOLOM KANAN — video AOCC (menggantikan Solutions list) */
.aocc-solutions-col {
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Card 4 foto AOCC — compact di atas video */
.aocc-photos-card {
  margin-bottom: 16px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 4px 16px rgba(15, 23, 42, 0.08);
  background: #f8fafc;
}

.aocc-photos-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 6px;
}

.aocc-photos-grid img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  display: block;
  transition: transform 0.25s ease;
  cursor: pointer;
}

.aocc-photos-card:hover .aocc-photos-grid img {
  transform: scale(1.02);
}

.aocc-video-col .aocc-inline-video-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.1);
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.aocc-video-col .aocc-inline-video-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.14);
}

.aocc-video-col .aocc-video-thumb-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #0f172a;
}

.aocc-video-col .aocc-video-thumb-wrap .video-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.aocc-video-col .video-info {
  padding: 18px 20px;
  background: #fff;
}

.aocc-video-col .video-info-title {
  font-size: 1.1rem;
  margin: 0 0 4px;
}

.aocc-video-col .video-info-type {
  margin: 0;
  font-size: 0.8rem;
}

.aocc-video-col .aocc-video-caption {
  margin: 10px 0 0;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #64748b;
  font-weight: 400;
}

.autogate-solutions-heading {
  display: flex;
  align-items: center;
  gap: 10px;
}

.solutions-icon-svg {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  color: #64748b;
  stroke: #64748b;
}

.solutions-heading-text {
  font-family: Inter, sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: #0a83c7;
  letter-spacing: -0.01em;
}

.solutions-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.solutions-list li {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.solutions-list li strong {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.3;
}

.solutions-list li span {
  font-family: Inter, sans-serif;
  font-size: 0.82rem;
  font-weight: 400;
  color: #64748b;
  line-height: 1.4;
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .aocc-bottom-row {
    grid-template-columns: 1fr;
  }

  .aocc-desc-col {
    padding: 24px 24px;
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  }

  .aocc-solutions-col {
    padding: 24px 24px;
  }
}

@media (max-width: 576px) {
  .aocc-desc-col,
  .aocc-solutions-col {
    padding: 20px 18px;
  }

  .solutions-heading-text {
    font-size: 1.25rem;
  }

  .solutions-list li strong {
    font-size: 0.92rem;
  }

  .solutions-list li span {
    font-size: 0.78rem;
  }
}

/* =========================
   BHS BOTTOM ROW
========================== */
.bhs-bottom-row {
  grid-template-columns: 1fr 50%;
}

.bhs-desc-col {
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  gap: 16px;
  justify-content: flex-start;
}

/* Judul biru bold italic */
.bhs-desc-tagline {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 800;
  color: #0a83c7;
  margin: 0;
  line-height: 1.5;
  font-style: italic;
}

/* Our Solution Partner */
.bhs-partners {
  margin-top: 8px;
}

.bhs-partners-label {
  font-family: Inter, sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 12px;
}

.bhs-partners-logos {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.bhs-partner-logo {
  height: 28px;
  width: auto;
  object-fit: contain;
  filter: grayscale(0.2);
  transition: filter 0.3s ease;
}

.bhs-partner-logo:hover {
  filter: grayscale(0);
}

/* Kolom kanan: gambar penuh */
.bhs-img-col {
  overflow: hidden;
}

.bhs-side-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.bhs-img-col:hover .bhs-side-img {
  transform: scale(1.03);
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .bhs-bottom-row {
    grid-template-columns: 1fr;
  }

  .bhs-desc-col {
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  }

  .bhs-img-col {
    min-height: 260px;
  }
}

@media (max-width: 576px) {
  .bhs-desc-tagline {
    font-size: 0.92rem;
  }

  .bhs-partner-logo {
    height: 22px;
  }

  .bhs-img-col {
    min-height: 220px;
  }
}

/* =========================
   AOCC IMAGE WRAP — rounded atas, rata bawah
========================== */
.aocc-image-wrap {
  border-radius: 18px 18px 0 0;
  box-shadow: none;
}

/* =========================
   BHS IMAGE WRAP — sambung dari bawah, ada jarak dari AOCC
========================== */
.bhs-image-wrap {
  margin-top: 0;
  border-radius: 18px 18px 0 0;
  box-shadow: none;
}

.aocc-bottom-row:not(.bhs-bottom-row) {
  margin-bottom: 0;
  border-bottom: none;
  border-radius: 0;
  box-shadow: none;
}

/* Teks overlay BHS lebih ke bawah */
.bhs-overlay {
  top: auto;
  bottom: 14%;
  transform: none;
}

/* GSR header — ukuran & model sama seperti BHS */
.gsr-image-wrap {
  margin-top: 0;
  border-radius: 18px 18px 0 0;
  box-shadow: none;
}

.gsr-overlay {
  top: auto;
  bottom: 14%;
  transform: none;
}

/* SOC header — ukuran & model sama seperti BHS */
.soc-image-wrap {
  margin-top: 0;
  border-radius: 18px 18px 0 0;
  box-shadow: none;
}

.soc-overlay {
  top: auto;
  bottom: 14%;
  transform: none;
}

/* =========================
   AUTOGATE BORDER CONTROL SECTION
========================== */
.abc-section {
  width: min(1100px, 100%);
  margin: 0 auto 60px;
  background: #ffffff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.10);
}

/* ROW 1 — Full width teks */
.abc-row-1 {
  padding: 48px 52px 40px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

.abc-main-title {
  font-family: Inter, sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 14px;
  line-height: 1.2;
}

.abc-tagline {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #0a83c7;
  font-style: italic;
  margin: 0 0 16px;
  line-height: 1.5;
}

.abc-desc {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.75;
  margin: 0 0 12px;
  max-width: 700px;
}

.abc-desc-bold {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
  margin: 4px 0 12px;
  line-height: 1.5;
}

/* ROW 2 — 3 fitur + gambar */
.abc-row-2 {
  display: grid;
  grid-template-columns: 2fr 2fr 2fr 4fr;
  gap: 0;
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

.abc-feature-col {
  padding: 32px 24px;
  border-right: 1px solid rgba(15, 23, 42, 0.07);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.abc-feature-icon {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

.abc-feature-icon svg {
  width: 100%;
  height: 100%;
}

.abc-feature-title {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0;
  line-height: 1.3;
}

.abc-feature-desc {
  font-family: Inter, sans-serif;
  font-size: 0.82rem;
  font-weight: 400;
  color: #64748b;
  line-height: 1.6;
  margin: 0;
}

.abc-gate-img-col {
  overflow: hidden;
}

.abc-gate-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  min-height: 240px;
  transition: transform 0.5s ease;
}

.abc-gate-img-col:hover .abc-gate-img {
  transform: scale(1.04);
}

/* ROW 3 — Gambar full width */
.abc-row-3 {
  width: 100%;
  overflow: hidden;
  max-height: 520px;
}

.abc-full-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-height: 520px;
  min-height: 300px;
  transition: transform 0.5s ease;
}

.abc-row-3:hover .abc-full-img {
  transform: scale(1.02);
}

/* RESPONSIVE */
@media (max-width: 992px) {
  .abc-row-2 {
    grid-template-columns: 1fr 1fr;
  }

  .abc-gate-img-col {
    grid-column: 1 / -1;
  }

  .abc-gate-img {
    min-height: 300px;
  }

  .abc-row-1 {
    padding: 36px 32px 28px;
  }
}

@media (max-width: 768px) {
  .abc-row-1 {
    padding: 28px 24px;
  }

  .abc-row-2 {
    grid-template-columns: 1fr 1fr;
  }

  .abc-feature-col {
    padding: 24px 20px;
  }

  .abc-full-img {
    min-height: 220px;
  }
}

@media (max-width: 576px) {
  .abc-row-1 {
    padding: 24px 20px;
  }

  .abc-main-title {
    font-size: 1.5rem;
  }

  .abc-row-2 {
    grid-template-columns: 1fr;
  }

  .abc-feature-col {
    padding: 20px 18px;
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
  }

  .abc-full-img {
    min-height: 180px;
  }
}

.abc-feature-icon{
  width:160px !important;
  height:160px !important;
}

.abc-feature-icon img{
  width:100% !important;
  height:100% !important;
  object-fit:contain;
}

/* =========================
   ABC ROWS — DALAM CARD GABUNGAN
========================== */

/* ROW 1 — teks full width */
.abc-row-1-card {
  padding: 40px 48px;
  background: #ffffff;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.abc-main-title {
  font-family: Inter, sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 12px;
  line-height: 1.2;
}

.abc-tagline {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #0a83c7;
  font-style: italic;
  margin: 0 0 14px;
  line-height: 1.5;
}

.abc-desc {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.75;
  margin: 0 0 10px;
}

.abc-desc-bold {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
  margin: 4px 0 10px;
  line-height: 1.5;
}

/* ROW 2 — 3 fitur + gambar */
.abc-row-2-card {
  display: grid;
  grid-template-columns: 2fr 2fr 2fr 4fr;
  gap: 0;
  background: #ffffff;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

.abc-feature-col {
  padding: 28px 24px;
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: #ffffff;
}

.abc-feature-icon {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
}

.abc-feature-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.abc-feature-title {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0;
  line-height: 1.3;
}

.abc-feature-desc {
  font-family: Inter, sans-serif;
  font-size: 0.82rem;
  font-weight: 400;
  color: #64748b;
  line-height: 1.6;
  margin: 0;
}

.abc-gate-img-col {
  overflow: hidden;
  min-height: 220px;
}

.abc-gate-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.abc-gate-img-col:hover .abc-gate-img {
  transform: scale(1.04);
}

/* ROW 3 — gambar full width */
.abc-row-3-card {
  width: 100%;
  overflow: hidden;
  border-radius: 0 0 18px 18px;
  max-height: 500px;
}

.abc-full-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-height: 500px;
  min-height: 280px;
  filter: brightness(0.9);
  transition: transform 0.5s ease, filter 0.4s ease;
}

.abc-row-3-card:hover .abc-full-img {
  transform: scale(1.02);
  filter: brightness(0.82);
}

/* RESPONSIVE */
@media (max-width: 992px) {
  .abc-row-2-card {
    grid-template-columns: 1fr 1fr;
  }

  .abc-gate-img-col {
    grid-column: 1 / -1;
    min-height: 280px;
  }

  .abc-row-1-card {
    padding: 32px 36px;
  }
}

@media (max-width: 768px) {
  .abc-row-1-card {
    padding: 24px 24px;
  }

  .abc-row-2-card {
    grid-template-columns: 1fr 1fr;
  }

  .abc-feature-col {
    padding: 20px 18px;
  }
}

@media (max-width: 576px) {
  .abc-row-1-card {
    padding: 20px 18px;
  }

  .abc-main-title {
    font-size: 1.4rem;
  }

  .abc-row-2-card {
    grid-template-columns: 1fr;
  }

  .abc-feature-col {
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  }

  .abc-gate-img-col {
    min-height: 220px;
  }

  .abc-full-img {
    min-height: 180px;
  }
}

/* =========================
   VDESK PASSPORT SOLUTIONS SECTION
========================== */
.vdesk-section {
  width: min(1100px, 100%);
  margin: 0 auto 60px;
}

/* ROW 1 — Full width teks */
.vdesk-row-1-card {
  padding: 40px 48px;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-bottom: none;
  border-radius: 18px 18px 0 0;
}

.vdesk-main-title {
  font-family: Inter, sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 12px;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 16px;
}

.vdesk-main-title .icao-badge {
  width: 56px;
  height: 56px;
  flex-shrink: 0;
}

.vdesk-tagline {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #0a83c7;
  font-style: italic;
  margin: 0 0 14px;
  line-height: 1.5;
}

.vdesk-desc {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.75;
  margin: 0 0 10px;
}

.vdesk-desc-bold {
  font-family: Inter, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
  margin: 4px 0 10px;
  line-height: 1.5;
}

/* ROW 2 — Card gabungan: features list + gambar produk */
.vdesk-row-2-card {
  display: grid;
  grid-template-columns: 1fr 1fr 1.5fr;
  gap: 0;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-bottom: none;
  overflow: hidden;
}

/* Kolom Features */
.vdesk-features-col {
  padding: 32px 28px;
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.vdesk-features-heading {
  font-family: Inter, sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  color: #0a83c7;
  margin: 0 0 18px;
  letter-spacing: -0.01em;
}

.vdesk-features-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.vdesk-features-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: Inter, sans-serif;
  font-size: 0.88rem;
  font-weight: 400;
  color: #334155;
  line-height: 1.55;
}

.vdesk-features-list li::before {
  content: '';
  width: 7px;
  height: 7px;
  background: #0a83c7;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}

/* Kolom VDESK Application info */
.vdesk-app-col {
  padding: 32px 28px;
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.vdesk-app-heading {
  font-family: Inter, sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  color: #0a83c7;
  margin: 0;
  letter-spacing: -0.01em;
}

.vdesk-app-label {
  display: inline-block;
  background: linear-gradient(135deg, #e0f2fe, #bae6fd);
  color: #0369a1;
  font-family: Inter, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: 20px;
  border: 1px solid rgba(3, 105, 161, 0.2);
}

.vdesk-app-items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.vdesk-app-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.vdesk-app-item-dot {
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, #0a83c7, #77d2e1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.vdesk-app-item-dot svg {
  width: 14px;
  height: 14px;
  stroke: #ffffff;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.vdesk-app-item-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.vdesk-app-item-title {
  font-family: Inter, sans-serif;
  font-size: 0.88rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.3;
}

.vdesk-app-item-desc {
  font-family: Inter, sans-serif;
  font-size: 0.78rem;
  font-weight: 400;
  color: #64748b;
  line-height: 1.4;
}

/* Kolom kanan: gambar produk */
.vdesk-product-img-col {
  overflow: hidden;
  background: linear-gradient(145deg, #f0f9ff, #e0f2fe);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  min-height: 340px;
}

.vdesk-product-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  max-height: 360px;
  transition: transform 0.5s ease;
}

.vdesk-product-img-col:hover .vdesk-product-img {
  transform: scale(1.04);
}

/* ROW 3 — Full image / amadeus branding bar */
.vdesk-row-3-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 40px;
  gap: 24px;
}

.vdesk-partner-section {
  display: flex;
  align-items: center;
  gap: 16px;
}

.vdesk-partner-label {
  font-family: Inter, sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.vdesk-partner-logo {
  height: 28px;
  width: auto;
  object-fit: contain;
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.vdesk-partner-logo:hover {
  opacity: 1;
}

.vdesk-partner-tagline {
  font-family: Inter, sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  color: #94a3b8;
  font-style: italic;
}

.vdesk-compliance-badges {
  display: flex;
  align-items: center;
  gap: 12px;
}

.vdesk-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
  border: 1px solid rgba(3, 105, 161, 0.2);
  border-radius: 20px;
}

.vdesk-badge svg {
  width: 14px;
  height: 14px;
  stroke: #0369a1;
  stroke-width: 2;
  fill: none;
}

.vdesk-badge span {
  font-family: Inter, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  color: #0369a1;
}

/* RESPONSIVE */
@media (max-width: 992px) {
  .vdesk-row-2-card {
    grid-template-columns: 1fr 1fr;
  }

  .vdesk-product-img-col {
    grid-column: 1 / -1;
    min-height: 280px;
  }

  .vdesk-row-1-card {
    padding: 32px 32px;
  }
}

@media (max-width: 768px) {
  .vdesk-row-1-card {
    padding: 24px 24px;
  }

  .vdesk-row-2-card {
    grid-template-columns: 1fr;
  }

  .vdesk-features-col,
  .vdesk-app-col {
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  }

  .vdesk-row-3-card {
    flex-direction: column;
    align-items: flex-start;
    padding: 18px 24px;
    gap: 16px;
  }
}

@media (max-width: 576px) {
  .vdesk-row-1-card {
    padding: 20px 18px;
  }

  .vdesk-main-title {
    font-size: 1.4rem;
    flex-wrap: wrap;
  }

  .vdesk-features-col,
  .vdesk-app-col {
    padding: 20px 18px;
  }

  .vdesk-product-img-col {
    min-height: 220px;
    padding: 16px;
  }

  .vdesk-compliance-badges {
    flex-wrap: wrap;
  }
}

/* =========================
   VDESK / PASSPORT SOLUTIONS CARD
   Letakkan di projects.css — hapus semua CSS vdesk lama sebelum paste ini
========================== */

/* Card wrapper — nempel ke abc-row-3-card di atasnya */
.vdesk-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-top: none;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
}

/* Pastikan abc-row-3-card tidak rounded bawah jika diikuti vdesk-card */
.abc-row-3-card {
  border-radius: 0 !important;
}

/* -------------------------------------------------------
   ROW 1 — Judul + ICAO + tagline + features (full width)
------------------------------------------------------- */
.vdesk-row1 {
  padding: 36px 40px 32px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
}

/* Baris atas: judul kiri, ICAO kanan */
.vdesk-row1-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 10px;
}

.vdesk-main-title {
  font-family: Inter, sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 800;
  color: #0f172a;
  margin: 0;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.vdesk-icao-logo {
  width: 100px;
  height: 100px;
  object-fit: contain;
  flex-shrink: 0;
}

.vdesk-tagline {
  font-family: Inter, sans-serif;
  font-size: 0.92rem;
  font-weight: 700;
  color: #0a83c7;
  font-style: italic;
  margin: 0 0 20px;
  line-height: 1.5;
  max-width: 580px;
}

/* Features */
.vdesk-features-box {
  /* biarkan mengalir natural */
}

.vdesk-features-title {
  font-family: Inter, sans-serif;
  font-size: 1rem;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 10px;
}

.vdesk-features-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.vdesk-features-list li {
  font-family: Inter, sans-serif;
  font-size: 0.87rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.5;
  padding-left: 16px;
  position: relative;
}

.vdesk-features-list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: #0a83c7;
  font-size: 1rem;
  line-height: 1.5;
}

.vdesk-features-list li span {
  display: block;
  font-family: Inter, sans-serif;
  font-weight: 400;
  color: #64748b;
  font-size: 0.8rem;
  margin-top: 1px;
}

  /* -------------------------------------------------------
    ROW 2 — Device | Software | Scanner
  ------------------------------------------------------- */
  .vdesk-row2 {
    display: grid;
    grid-template-columns: 2.8fr 5fr 2fr; /* ← JADI INI */
    gap: 0;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    align-items: stretch;
  }

  /* Kolom kiri: device VDESK */
  .vdesk-device-col {
  background: #edf2f7;
  display: block; /* ← ubah dari flex */
  padding: 0;
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

  .vdesk-device-img {
  width: 100%;
  height: 100%;
  min-height: 350px;
  object-fit: cover;
  object-position: center top; /* ← tambah ini */
  display: block;
}

  /* Kolom tengah: software screenshot */
  .vdesk-software-col {
    padding: 16px 16px 12px;
    border-right: 1px solid rgba(15, 23, 42, 0.08);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
    background: #ffffff;
  }

  .vdesk-software-wrap {
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 6px 24px rgba(15, 23, 42, 0.14);
    border: 3px solid #8b5cf6;
    width: 100%;
  }

  .vdesk-software-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    /* Tidak ada max-height — biarkan natural */
  }

  .vdesk-software-caption {
    font-family: Inter, sans-serif;
    font-size: 0.76rem;
    color: #64748b;
    text-align: center;
    margin: 0;
    font-style: italic;
    line-height: 1.4;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
  }

  .vdesk-caption-dots {
    color: #94a3b8;
    font-style: normal;
    letter-spacing: 3px;
    font-size: 0.65rem;
  }

  /* Kolom kanan: scanner */
  .vdesk-scanner-col {
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 24px;
    background: #ffffff;
  }

  .vdesk-scanner-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    width: 100%;
  }

  .vdesk-scanner-img {
    width: 100%;
    max-width: 120px;
    height: auto;
    object-fit: contain;
  }

  .vdesk-scanner-label {
    font-family: Inter, sans-serif;
    font-size: 0.72rem;
    color: #475569;
    text-align: center;
    margin: 0;
    line-height: 1.4;
  }

  /* -------------------------------------------------------
    ROW 3 — VDESK Application full width + Amadeus bar
  ------------------------------------------------------- */
  .vdesk-row3 {
    position: relative;
    overflow: hidden;
    border-radius: 0 0 18px 18px;
  }

  .vdesk-app-img {
    width: 100%;
    height: auto;
    max-height: 520px;
    min-height: 280px;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
  }

  .vdesk-row3:hover .vdesk-app-img {
    transform: scale(1.02);
  }

  /* Amadeus bar — rata bawah di dalam gambar */
  .vdesk-amadeus-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: #ffffff;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
  }

  .vdesk-amadeus-logo {
    height: 28px;
    width: auto;
    object-fit: contain;
  }

  .vdesk-amadeus-tagline {
    font-family: Inter, sans-serif;
    font-size: 0.78rem;
    color: #64748b;
    font-style: italic;
  }

  /* =========================
    RESPONSIVE
  ========================== */
  @media (max-width: 992px) {
    .vdesk-row1 {
      padding: 28px 28px 24px;
    }

  .vdesk-row2 {
    grid-template-columns: 1fr 1fr;
  }

  .vdesk-device-col {
    grid-column: 1 / -1;
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    padding: 20px;
    min-height: 180px;
  }

  .vdesk-device-img {
    max-width: 130px;
  }

  .vdesk-software-col {
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    padding: 16px 20px;
  }

  .vdesk-scanner-col {
    flex-direction: row;
    justify-content: center;
    padding: 16px;
    gap: 28px;
  }
}

@media (max-width: 768px) {
  .vdesk-row1 {
    padding: 24px 20px;
  }

  .vdesk-icao-logo {
    width: 100px;
    height: 100px;
  }

  .vdesk-main-title {
    font-size: 1.8rem;
  }

  .vdesk-row2 {
    grid-template-columns: 1fr;
  }

  .vdesk-software-col {
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    padding: 16px 20px;
  }

  .vdesk-scanner-col {
    flex-direction: row;
    justify-content: center;
    padding: 16px 20px;
    gap: 32px;
  }

  .vdesk-amadeus-bar {
    padding: 12px 20px;
  }
}

@media (max-width: 576px) {
  .vdesk-row1 {
    padding: 20px 18px;
  }

  .vdesk-row1-top {
    gap: 12px;
  }

  .vdesk-icao-logo {
    width: 100px;
    height: 100px;
  }

  .vdesk-main-title {
    font-size: 1.5rem;
  }

  .vdesk-scanner-col {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }

  .vdesk-app-img {
    max-height: 320px;
    min-height: 200px;
  }

  .vdesk-amadeus-bar {
    padding: 12px 16px;
  }
}

@media (max-width: 400px) {
  .vdesk-main-title {
    font-size: 1.3rem;
  }

  .vdesk-icao-logo {
    width: 100px;
    height: 100px;
  }
}
