/* ---------- Theme tokens ---------- */
:root{
  --bg: #FCFBF9;           /* warm white */
  --sand: #F5F2ED;         /* soft sand */
  --text: #4A4A4A;         /* charcoal */
  --text-dark: #2D2D2D;
  --text-muted: #727272;
  --accent: #9CAF88;       /* sage green */
  --accent-hover: #8A9B77; /* darker sage */
  --shadow-soft: 0px 10px 30px rgba(0, 0, 0, 0.03);
}

/* ---------- Base ---------- */
body{
  background: var(--bg);
  color: var(--text);
}

/* Links */
a{ color: var(--accent); }
a:hover,
a:focus{ color: var(--accent-hover); }

/* Icons that should follow accent */
.colorlib-nav-toggle i,
.colorlib-social-icons i{ color: var(--accent); }

/* Typography */
p{ letter-spacing: 0.5px; }

h1,
h2,
h3{
  letter-spacing: 2px;
  text-transform: none;
}

/* Buttons */
.btn-primary{
  background: var(--accent);
  border: 2px solid var(--accent);
  color: #fff;
}

/* style.css uses !important on .btn-primary:hover */
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active{
  background: var(--accent-hover) !important;
  border-color: var(--accent-hover) !important;
  color: #fff;
}

/* Outline variant (used by "Contact Me" / "Say Hello") */
.btn-primary.btn-outline{
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--accent);
}

.btn-primary.btn-outline:hover,
.btn-primary.btn-outline:focus,
.btn-primary.btn-outline:active{
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
}

/* =========================================================
   Hero/About carousel heading (#colorlib-about)
========================================================= */
.about-desc .desc .item h2 span{
  font-family: "Dancing Script", cursive;
  font-size: 34px;
  line-height: 1.2;
  font-weight: 600;
}

@media (max-width: 768px){
  .about-desc .desc .item h2 span{ font-size: 26px; }
}

/* =========================================================
   Section: About Me (#colorlib-services)
========================================================= */
#colorlib-services .intro-heading{ margin-bottom: 1.2em; }
#colorlib-services .intro-heading h2{ margin-bottom: 0.4em; }

#colorlib-services .services p{ margin-bottom: 14px; }
#colorlib-services .services p:first-child{ margin-top: 0; }

/* Mobile layout fixes */
@media (max-width: 768px){
  #colorlib-services{ padding: 4em 0; }

  /* hide the rotated side title on mobile */
  #colorlib-services .rotate{ display: none; }

  /* stack columns */
  #colorlib-services .services-flex{ display: block; }
  #colorlib-services .services-flex .one-third,
  #colorlib-services .services-flex .one-forth{
    width: 100%;
    float: none;
  }
  #colorlib-services .services-flex .one-third{ padding: 0 15px; }

  /* center heading (your last fix wins) */
  #colorlib-services .intro-heading{ text-align: center; }
  #colorlib-services .intro-heading span,
  #colorlib-services .intro-heading h2{ text-align: center; }

  /* keep the ABOUT watermark visible (avoid double opacity stacking) */
  #colorlib-services .bold{ opacity: 1 !important; }

  #colorlib-services .services p{
    font-size: 15px;
    line-height: 1.8;
    margin-bottom: 12px;
  }

  /* image becomes banner below text */
  #colorlib-services .services-img{
    margin-top: 18px;
    height: 280px;
    background-position: center;
    background-size: cover;
  }
}

@media (max-width: 480px){
  #colorlib-services .services-img{ height: 220px; }
}

/* =========================================================
   Section: How I Live & Create (#colorlib-life-create)
========================================================= */
#colorlib-life-create{
  padding: 7em 0 6em;
  position: relative;
}

#colorlib-life-create .container-fluid{
  padding-left: 0;
  padding-right: 0;
}

#colorlib-life-create .life-grid{
  margin-left: 0;
  margin-right: 0;
}

#colorlib-life-create .life-grid > [class*="col-"]{
  padding-left: 0;
  padding-right: 0;
}

#colorlib-life-create .life-work-img{
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 280px;
  display: table;
  text-align: center;
  text-decoration: none;
  margin: 0;
}

/* Background layer (zoom target) */
#colorlib-life-create .life-work-img .life-bg{
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1);
  transition: transform 0.6s ease;
  will-change: transform;
}

/* Dark overlay */
#colorlib-life-create .life-work-img::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  transition: opacity 0.35s ease;
  z-index: 1;
}

/* Content above overlay */
#colorlib-life-create .life-work-img .display-t{
  position: relative;
  z-index: 2;
  display: table-cell;
  vertical-align: middle;
}

#colorlib-life-create .life-work-img .work-name{
  display: inline-block;
  background: #fff;
  padding: 18px 16px;
  max-width: 85%;
  box-shadow: 0px 2px 49px -4px rgba(0, 0, 0, 0.21);
  transform: scale(0.96);
  opacity: 0.95;
  transition: transform 0.35s ease, opacity 0.35s ease, box-shadow 0.35s ease;
}

#colorlib-life-create .life-work-img .work-name h2{
  margin: 0;
  font-size: 16px;
  line-height: 1.2;
}

/* Hover / focus */
#colorlib-life-create .life-work-img:hover .life-bg{ transform: scale(1.05); }
#colorlib-life-create .life-work-img:hover::after{ opacity: 1; }
#colorlib-life-create .life-work-img:hover .work-name{
  transform: translateY(-2px) scale(1.03);
  opacity: 1;
}

/* Keyboard focus accessibility */
#colorlib-life-create .life-work-img:focus{ outline: none; }
#colorlib-life-create .life-work-img:focus-visible::after{ opacity: 1; }
#colorlib-life-create .life-work-img:focus-visible .work-name{
  transform: translateY(-2px) scale(1.03);
  opacity: 1;
}

@media (max-width: 768px){
  #colorlib-life-create{ padding: 4.5em 0 3em; }
  #colorlib-life-create .life-work-img{ height: 210px; }

  #colorlib-life-create .life-work-img .work-name{
    padding: 16px 14px;
    max-width: 90%;
  }

  #colorlib-life-create .life-work-img .work-name h2{ font-size: 13px; }

  /* Tap feedback */
  #colorlib-life-create .life-work-img:active::after,
  #colorlib-life-create .life-work-img:focus::after{ opacity: 1; }

  #colorlib-life-create .life-work-img:active .work-name,
  #colorlib-life-create .life-work-img:focus .work-name{
    transform: translateY(-2px) scale(1.03);
    opacity: 1;
  }

  #colorlib-life-create .life-work-img:active .life-bg,
  #colorlib-life-create .life-work-img:focus .life-bg{ transform: scale(1.02); }
}

@media (max-width: 480px){
  #colorlib-life-create .life-work-img .work-name{
    padding: 14px 12px;
    max-width: 92%;
  }

  #colorlib-life-create .life-work-img .work-name h2{ font-size: 12px; }
}

/* =========================================================
   Section: Done Project / What I Do (#colorlib-done-project)
========================================================= */
#colorlib-done-project{
  position: relative;
  overflow: hidden;

  /* your latest "gap" fix */
  margin-top: 0;
  padding: 6em 0 5em;
}

#colorlib-done-project .intro-heading{ margin-bottom: 2.5em; }

#colorlib-done-project .dp-item{
  display: flex;
  align-items: center;
  gap: 60px;
  margin-bottom: 70px;
}

#colorlib-done-project .dp-img{
  flex: 0 0 52%;
  height: 420px;
  background-size: cover;
  background-position: center;
  box-shadow: 0px 20px 60px rgba(0, 0, 0, 0.12);
}

#colorlib-done-project .dp-content{ flex: 1; }

#colorlib-done-project .dp-content h3{
  font-size: 28px;
  margin: 0 0 14px 0;
  letter-spacing: 1px;
}

#colorlib-done-project .dp-content p{
  font-size: 16px;
  line-height: 1.9;
  margin: 0;
  color: rgba(0, 0, 0, 0.65);
  max-width: 520px;
}

#colorlib-done-project .dp-right{ flex-direction: row-reverse; }

/* Size variants */
#colorlib-done-project .dp-big .dp-img{
  flex-basis: 58%;
  height: 460px;
}

#colorlib-done-project .dp-small .dp-img{
  flex-basis: 48%;
  height: 340px;
}

/* Background bold text (desktop) */
#colorlib-done-project .bold{
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  text-align: center;
  font-size: 200px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(156, 175, 136, 0.12);
  opacity: 1;
  z-index: 0;
  pointer-events: none;
}

#colorlib-done-project .intro-heading,
#colorlib-done-project .dp-item{
  position: relative;
  z-index: 1;
}

@media (max-width: 768px){
  /* merge: dp layout + your final spacing + watermark fix */
  #colorlib-done-project{
    padding: 5.2em 0 4em; /* your last padding-top adjustment wins */
  }

  #colorlib-done-project .dp-item{
    display: block;
    margin-bottom: 45px;
  }

  #colorlib-done-project .dp-img{
    width: 100%;
    height: 260px;
    margin-bottom: 18px;
  }

  #colorlib-done-project .dp-big .dp-img{ height: 300px; }

  #colorlib-done-project .dp-content h3{
    font-size: 22px;
    margin-bottom: 10px;
  }

  #colorlib-done-project .dp-content p{
    font-size: 15px;
    line-height: 1.8;
    max-width: 100%;
  }

  #colorlib-done-project .bold{
    top: 6px;
    font-size: 60px !important;
    color: rgba(156, 175, 136, 0.12) !important;
    opacity: 1 !important;
  }
}

@media (max-width: 480px){
  #colorlib-done-project{ padding: 4.8em 0 4em; }
  #colorlib-done-project .bold{ font-size: 54px !important; }
}

/* =========================================================
   Section: Creative Expressions (#colorlib-creative)
========================================================= */
#colorlib-creative{
  padding: 4em 0;
  background: var(--bg);
  position: relative;
}

#colorlib-creative .intro-heading{ margin-bottom: 1.5em; }
#colorlib-creative .creative-intro{ margin-bottom: 1.5em; }

#colorlib-creative .creative-intro p{
  font-size: 18px;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

#colorlib-creative .creative-intro p.not-products{
  margin: 0;
  font-style: italic;
  color: var(--accent);
  font-weight: 300;
}

#colorlib-creative .creative-grid{ margin-top: 0; }

#colorlib-creative .creative-item{
  padding: 2.5em 2em;
  background: #fff;
  border: 1px solid var(--sand);
  text-align: center;
  min-height: 350px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-shadow: var(--shadow-soft);
  transition: transform 0.3s ease, border-color 0.3s ease;
}

#colorlib-creative .creative-item:hover{
  transform: translateY(-5px);
  border-color: var(--accent);
}

#colorlib-creative .creative-item .icon{
  font-size: 30px;
  margin-bottom: 20px;
}

#colorlib-creative .creative-item h3{
  font-size: 20px;
  font-family: "Playfair Display", serif;
  margin-bottom: 25px;
  letter-spacing: 1px;
  text-transform: none;
}

#colorlib-creative .excerpt-content{
  margin-bottom: 30px;
  padding: 20px;
  background: var(--sand);
  border-radius: 4px;
}

#colorlib-creative .lyric-line,
#colorlib-creative .writing-line{
  font-style: italic;
  font-size: 16px;
  color: var(--text);
  margin-bottom: 0;
}

#colorlib-creative .minimal-context{
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #bfbfbf;
  margin-top: auto;
}

@media (max-width: 768px){
  #colorlib-creative{ padding: 3em 0; }
  #colorlib-creative .creative-item{
    margin-bottom: 20px;
    min-height: auto;
  }
}

/* =========================================================
   Section: Values (#colorlib-values)
========================================================= */
#colorlib-values{
  padding: 4em 0;
  position: relative;
  overflow: hidden;
}

#colorlib-values .intro-heading{ margin-bottom: 1.5em; }
#colorlib-values .bold{
  color: rgba(156, 175, 136, 0.12);
  top: 20px;
}

#colorlib-values .values-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px 50px;
  margin-top: 2em;
}

#colorlib-values .value-item{
  position: relative;
  padding-left: 30px;
}

#colorlib-values .value-line{
  position: absolute;
  left: 0;
  top: 15px;
  width: 20px;
  height: 1px;
  background: var(--accent);
}

#colorlib-values .value-item h3{
  font-family: "Playfair Display", serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--text-dark);
  letter-spacing: 1px;
  margin: 0 0 5px 0;
  line-height: 1.4;
  text-transform: none;
}

#colorlib-values .value-item p{
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-muted);
  font-weight: 300;
  margin: 0;
}

@media (max-width: 768px){
  #colorlib-values{ padding: 3em 0; }

  #colorlib-values .values-grid{
    grid-template-columns: 1fr;
    gap: 20px;
  }

  #colorlib-values .value-item h3{ font-size: 20px; }
}

/* =========================================================
   Section: Invitation (#colorlib-invitation)
========================================================= */
#colorlib-invitation{
  position: relative;
  padding: 5em 0;
  background: var(--bg);
  overflow: hidden;
}

#colorlib-invitation .bold{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
  color: rgba(156, 175, 136, 0.12);
  z-index: 0;
  pointer-events: none;
}

#colorlib-invitation .intro-heading,
#colorlib-invitation .invitation-content{
  position: relative;
  z-index: 1;
}

#colorlib-invitation .invitation-content p{
  margin-bottom: 4px;
  font-size: 18px;
}

#colorlib-invitation .invitation-btn{ margin-top: 2em; }

@media (max-width: 768px){
  #colorlib-invitation{ padding: 4em 0; }
}

/* =========================================================
   Footer (minimal)
========================================================= */
#footer.footer-minimal{
  padding: 2.25em 0;
  background: var(--sand);
}

#footer.footer-minimal p{ margin: 0; }

/* Links in footer: green */
#footer.footer-minimal a{
  color: var(--accent);
  text-decoration: none;
}

#footer.footer-minimal a:hover,
#footer.footer-minimal a:focus{
  color: var(--accent-hover);
  text-decoration: none;
}

/* Small, discreet private link (non-home pages) */
#footer.footer-minimal:not(.footer-home-only) .private-link a{
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: none;
}

/* Copyright style */
#footer.footer-minimal .footer-copyright{
  font-size: 12px;
  color: #a5a5a5;
}

/* Mobile: center everything */
@media (max-width: 768px){
  #footer.footer-minimal .footer-minimal-row,
  #footer.footer-minimal .footer-minimal-row .text-right{
    text-align: center;
  }

  #footer.footer-minimal .private-link{ margin-top: 10px; }
}

/* HOME-only footer tweaks */
#footer.footer-home-only{ text-align: center; }
#footer.footer-home-only .private-link{ margin: 0 0 8px 0; }

#footer.footer-home-only .private-notes-link{
  font-family: "Dancing Script", cursive;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  color: var(--accent, #9CAF88);
  text-decoration: none;
  font-size: 18px; /* consolidated (previously split across 2 selectors) */
}

#footer.footer-home-only .private-notes-link:hover,
#footer.footer-home-only .private-notes-link:focus{
  color: var(--accent-hover, #8A9B77);
  text-decoration: none;
}

#footer.footer-home-only .footer-copyright{
  margin: 0;
  font-size: 12px;
  color: #a5a5a5;
}

/* =========================================================
   Global: Mobile watermark + meta label (HOME)
   (kept at the end so it overrides template defaults)
========================================================= */
.bold{
  color: rgba(156, 175, 136, 0.12);
  text-transform: uppercase;
  letter-spacing: .10em;
  pointer-events: none;
}

.intro-heading span{ color: var(--accent, #9CAF88); }

@media screen and (max-width: 768px){
  .bold{
    font-size: 44px !important;
    line-height: 1;
  }

  .intro-heading h2{
    font-size: 30px;
    line-height: 1.25;
    margin-bottom: 1.1em;
  }

  .intro-heading span{
    font-size: 12px;
    letter-spacing: 4px;
  }
}

@media screen and (max-width: 480px){
  .bold{ font-size: 40px; }
  .intro-heading h2{ font-size: 28px; }
}

/* =========================================================
   Header logo: remove template square/border + center on mobile
========================================================= */
header .colorlib-navbar-brand .colorlib-logo.logo-img{
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  letter-spacing: 0 !important;
  width: auto !important;
  height: auto !important;
  display: inline-block;
}

header .colorlib-navbar-brand .colorlib-logo.logo-img .site-logo{
  display: block;
  height: 80px;
  width: auto;
}

@media screen and (max-width: 768px){
  header .colorlib-navbar-brand{
    float: none !important;
    width: 100%;
    text-align: center;
  }

  header .colorlib-navbar-brand .colorlib-logo.logo-img{ display: inline-block; }
}

/* =========================================================
   ONE-PAGE WIREFRAME (Module 1)
   Scope: Only applies when wrapper has .onepage-wireframe
========================================================= */
.onepage-wireframe #colorlib-main-nav{ display: none; }

.onepage-wireframe .op-section{ padding: 6.5em 0; }

.onepage-wireframe .op-title{
  font-family: "Playfair Display", serif;
  font-size: 34px;
  margin: 0 0 18px 0;
  letter-spacing: 1px;
  text-transform: none;
  color: var(--text-dark);
}

.onepage-wireframe p{
  font-size: 17px;
  line-height: 1.95;
  color: rgba(0,0,0,0.65);
}

.onepage-wireframe .op-muted{
  color: var(--accent);
  font-style: italic;
  margin: 0;
}

/* 1) HERO / PRESENCE */
.onepage-wireframe .op-hero{
  position: relative;
  min-height: 92vh;
  width: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
}

.onepage-wireframe .op-hero-overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.35);
}

.onepage-wireframe .op-hero-content{
  position: relative;
  z-index: 1;
  max-width: 780px;
}

.onepage-wireframe .op-hero-title{
  font-family: "Playfair Display", serif;
  font-size: 52px;
  line-height: 1.15;
  letter-spacing: 1px;
  margin: 0 0 16px 0;
  color: #fff;
  text-transform: none;
}

.onepage-wireframe .op-hero-subtitle{
  color: rgba(255,255,255,0.92);
  font-size: 15px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin: 0 0 14px 0;
}

.onepage-wireframe .op-hero-lede{
  color: rgba(255,255,255,0.92);
  font-size: 18px;
  margin: 0;
}

/* 2) ABOUT */
.onepage-wireframe .op-about{ background: var(--bg); }

.onepage-wireframe .op-photo img{
  border-radius: 14px;
  box-shadow: 0px 20px 60px rgba(0,0,0,0.10);
}

/* 3) LIFE & EXPRESSION */
.onepage-wireframe .op-life{ background: var(--sand); }

.onepage-wireframe .op-icon-list{
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.onepage-wireframe .op-icon-list li{
  padding: 14px 16px;
  margin: 0 0 14px 0;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 12px;
  box-shadow: var(--shadow-soft);
  font-size: 16px;
  color: rgba(0,0,0,0.70);
}

/* 4) PROFESSIONAL WORK */
.onepage-wireframe .op-professional{ background: var(--bg); }

/* 5) CREATIVE EXPRESSIONS */
.onepage-wireframe .op-creative{ background: var(--bg); }
.onepage-wireframe .op-creative-intro{ margin-bottom: 28px; }
.onepage-wireframe .op-card-row{ margin-top: 5px; }

.onepage-wireframe .op-card{
  background: #fff;
  border: 1px solid var(--sand);
  border-radius: 14px;
  padding: 26px 24px;
  box-shadow: var(--shadow-soft);
  min-height: 260px;
}

.onepage-wireframe .op-card-title{
  margin: 0 0 8px 0;
  font-size: 20px;
  letter-spacing: 1px;
  text-transform: none;
}

.onepage-wireframe .op-card-meta{
  margin: 0 0 14px 0;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(0,0,0,0.35);
}

.onepage-wireframe .op-embed-placeholder{
  background: var(--sand);
  border-radius: 12px;
  padding: 22px;
  text-align: center;
  color: rgba(0,0,0,0.45);
}

.onepage-wireframe .op-quote{
  background: var(--sand);
  border-left: 3px solid var(--accent);
  padding: 16px 18px;
  border-radius: 10px;
  margin: 0;
  font-style: italic;
  color: rgba(0,0,0,0.65);
}

/* 6) VALUES */
.onepage-wireframe .op-values{ background: var(--sand); }

.onepage-wireframe .op-values-list{
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
}

.onepage-wireframe .op-values-list li{
  background: #fff;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 12px;
  padding: 14px 16px;
  box-shadow: var(--shadow-soft);
  color: rgba(0,0,0,0.70);
}

/* 7) INVITATION */
.onepage-wireframe .op-invitation{ background: var(--bg); }
.onepage-wireframe .op-cta{ margin-top: 22px; }

@media (max-width: 768px){
  .onepage-wireframe .op-section{ padding: 4.5em 0; }
  .onepage-wireframe .op-hero{ min-height: 76vh; }

  .onepage-wireframe .op-hero-title{
    font-size: 34px;
    line-height: 1.2;
  }

  .onepage-wireframe .op-hero-subtitle{ font-size: 12px; }
  .onepage-wireframe .op-values-list{ grid-template-columns: 1fr; }

  .onepage-wireframe .op-card{
    min-height: auto;
    margin-bottom: 18px;
  }
}

@media (max-width: 480px){
  .onepage-wireframe .op-hero-title{ font-size: 30px; }
}

/* =========================================================
   Section spacing tuning (Home)
   Reduce vertical gaps between:
   #colorlib-about -> #colorlib-services -> #colorlib-life-create
   -> #colorlib-done-project -> #colorlib-creative
========================================================= */

/* DESKTOP / TABLET */
#colorlib-about{
  padding-bottom: 3.2em !important; /* jarak ke section berikutnya */
}

#colorlib-services{
  padding: 4.6em 0 !important;
}

#colorlib-life-create{
  padding: 5.0em 0 4.2em !important;
}

#colorlib-done-project{
  padding: 5.0em 0 4.2em !important;
  margin-top: 0 !important; /* pastikan tidak ada gap tambahan */
}

#colorlib-creative{
  padding: 4.2em 0 !important;
}

/* MOBILE */
@media (max-width: 768px){
  #colorlib-about{
    padding-bottom: 2.4em !important;
  }

  #colorlib-services{
    padding: 3.6em 0 !important;
  }

  #colorlib-life-create{
    padding: 3.8em 0 3.2em !important;
  }

  #colorlib-done-project{
    padding: 3.8em 0 3.2em !important;
  }

  #colorlib-creative{
    padding: 3.4em 0 !important;
  }
}
/* =========================================================
   DONE PROJECT watermark: align like CREATIVE (behind heading)
========================================================= */

/* Pastikan heading jadi anchor */
#colorlib-done-project .intro-heading{
  position: relative;
  z-index: 2;
}

/* Watermark diposisikan relatif ke intro-heading */
#colorlib-done-project .intro-heading .bold{
  position: absolute;
  top: -35px;          /* ini bikin dia “naik sedikit” tapi masih di belakang heading */
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  text-align: center;

  font-size: 220px;
  line-height: 1;
  letter-spacing: .08em;

  white-space: nowrap;
  word-spacing: -0.22em;

  z-index: -1;         /* penting: dia benar-benar di belakang judul & subjudul */
  pointer-events: none;
}

/* Biar jarak "WORKS" dan "What I Do" tetap rapi */
#colorlib-done-project .intro-heading span{
  position: relative;
  z-index: 3;
}
#colorlib-done-project .intro-heading h2{
  position: relative;
  z-index: 3;
}

/* Laptop */
@media (max-width: 1200px){
  #colorlib-done-project .intro-heading .bold{
    font-size: 190px;
    top: -28px;
  }
}

/* Mobile (ikut gaya kamu yang sudah bagus) */
@media (max-width: 768px){
  #colorlib-done-project .intro-heading .bold{
    top: -10px;
    font-size: 60px !important;
    width: 100%;
    word-spacing: 0;
  }
}
@media (max-width: 480px){
  #colorlib-done-project .intro-heading .bold{
    font-size: 54px !important;
  }
}

/* DONE PROJECT: move watermark down (match Creative) */
#colorlib-done-project{
  position: relative;
}

#colorlib-done-project .row.text-center{
  position: relative;   /* jadi anchor watermark */
  z-index: 1;
}

/* watermark yg benar (row text-center) */
#colorlib-done-project .row.text-center .bold{
  position: absolute;
  top: -70px;           /* TURUNIN watermark (coba -30 / -25 kalau mau lebih turun) */
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  text-align: center;

  font-size: 220px;
  line-height: 1;
  letter-spacing: .08em;

  white-space: nowrap;
  word-spacing: -0.22em;

  z-index: -1;          /* benar2 di belakang heading */
  pointer-events: none;
}

/* Laptop */
@media (max-width: 1200px){
  #colorlib-done-project .row.text-center .bold{
    top: -28px;
    font-size: 190px;
  }
}
/* =========================================================
   FIX: VALUES section spacing + watermark positioning
========================================================= */

/* Rapatkan jarak dari CREATIVE -> VALUES */
#colorlib-creative{
  padding-bottom: 3.0em !important;
}

/* Rapatkan padding section VALUES */
#colorlib-values{
  padding: 3.2em 0 3.4em !important;
}

/* Naikkan watermark "VALUES" supaya lebih rapi di belakang heading,
   dan tidak ganggu list item */
#colorlib-values .bold{
  top: -5px !important;      /* sebelumnya terlalu turun */
  font-size: 220px !important; /* sedikit lebih kecil biar elegan */
  line-height: 1 !important;
}

/* Naikkan konten list biar tidak terlalu jauh dari heading */
#colorlib-values .values-grid{
  margin-top: 1.2em !important; /* sebelumnya 2em */
}

/* Mobile tuning */
@media (max-width: 768px){
  #colorlib-creative{
    padding-bottom: 2.4em !important;
  }

  #colorlib-values{
    padding: 2.8em 0 3.0em !important;
  }

  #colorlib-values .bold{
    top: -12px !important;
    font-size: 44px !important;  /* ikutin style watermark mobile kamu */
  }

  #colorlib-values .values-grid{
    margin-top: 1.0em !important;
  }
}


/* =========================================================
   IronClad adaptation layer
   Append-only overrides so the PMV theme remains intact
========================================================= */
.menu-tagline-wrap{
  margin-bottom: 18px;
}

.menu-tagline{
  color: #ffffff;
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin: 0;
  opacity: 0.8;
}

.pmv-button-group{
  margin-top: 18px;
}

.pmv-button-group .btn{
  margin-right: 10px;
  margin-bottom: 10px;
}

.pmv-mini-note{
  font-size: 13px;
  color: var(--accent);
  font-style: italic;
}

#colorlib-about .desc > p{
  max-width: 540px;
}

#colorlib-done-project .pmv-service-list{
  list-style: none;
  padding: 0;
  margin: 18px 0 0 0;
}

#colorlib-done-project .pmv-service-list li{
  position: relative;
  padding-left: 18px;
  margin-bottom: 10px;
  color: rgba(0, 0, 0, 0.68);
  line-height: 1.8;
}

#colorlib-done-project .pmv-service-list li:before{
  content: "\2022";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
}

.pmv-team-role{
  color: var(--accent) !important;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px !important;
  margin-bottom: 10px !important;
}

.pmv-contact-form{
  margin-top: 24px;
  padding: 34px 28px;
  background: #ffffff;
  border: 1px solid var(--sand);
  box-shadow: var(--shadow-soft);
}

.pmv-contact-form .form-control{
  min-height: 48px;
  border: 1px solid #e9e3da;
  box-shadow: none;
  border-radius: 0;
}

.pmv-contact-form .form-control:focus{
  border-color: var(--accent);
  box-shadow: none;
}

.pmv-consent{
  display: block;
  margin: 6px 0 22px;
  font-size: 13px;
  font-weight: 300;
  color: var(--text-muted);
  line-height: 1.7;
}

.pmv-consent input{
  margin-right: 8px;
}

.pmv-legal-note,
.pmv-footer-disclaimer{
  font-size: 12px;
  color: #8a8a8a;
  line-height: 1.8;
}

.pmv-footer-disclaimer{
  max-width: 760px;
  margin: 0 auto 14px;
}

@media (max-width: 768px){
  .menu-tagline{
    letter-spacing: 2px;
    line-height: 1.7;
  }

  .pmv-contact-form{
    padding: 26px 20px;
  }
}

.pmv-button-group{
  margin-top: 18px;
}

.pmv-button-group .btn{
  margin-right: 10px;
  margin-bottom: 10px;
}

.pmv-mini-note{
  font-size: 13px;
  color: var(--accent);
  font-style: italic;
}

#colorlib-about .desc > p{
  max-width: 540px;
}

#colorlib-done-project .pmv-service-list{
  list-style: none;
  padding: 0;
  margin: 18px 0 0 0;
}

#colorlib-done-project .pmv-service-list li{
  position: relative;
  padding-left: 18px;
  margin-bottom: 10px;
  color: rgba(0, 0, 0, 0.68);
  line-height: 1.8;
}

#colorlib-done-project .pmv-service-list li:before{
  content: "\2022";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
}

.pmv-team-role{
  color: var(--accent) !important;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px !important;
  margin-bottom: 10px !important;
}

.pmv-contact-form{
  margin-top: 24px;
  padding: 34px 28px;
  background: #ffffff;
  border: 1px solid var(--sand);
  box-shadow: var(--shadow-soft);
}

.pmv-contact-form .form-control{
  min-height: 48px;
  border: 1px solid #e9e3da;
  box-shadow: none;
  border-radius: 0;
}

.pmv-contact-form .form-control:focus{
  border-color: var(--accent);
  box-shadow: none;
}

.pmv-consent{
  display: block;
  margin: 6px 0 22px;
  font-size: 13px;
  font-weight: 300;
  color: var(--text-muted);
  line-height: 1.7;
}

.pmv-consent input{
  margin-right: 8px;
}

.pmv-legal-note,
.pmv-footer-disclaimer{
  font-size: 12px;
  color: #8a8a8a;
  line-height: 1.8;
}

.pmv-footer-disclaimer{
  max-width: 760px;
  margin: 0 auto 14px;
}

@media (max-width: 768px){
  .menu-tagline{
    letter-spacing: 2px;
    line-height: 1.7;
  }

  .pmv-contact-form{
    padding: 26px 20px;
  }
}

/* =========================
   PMV TEAM SECTION - COMPACT 4 IN A ROW
========================= */

.pmv-team-section {
	padding-top: 55px;
	padding-bottom: 35px;
}

.pmv-team-section .container {
	max-width: 1280px;
}

.pmv-team-row {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 20px;
}

.pmv-team-col {
	display: flex;
	margin-bottom: 25px;
	padding-left: 12px;
	padding-right: 12px;
}

.pmv-team-card {
	background: #fff;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.05);
	border: 1px solid rgba(0, 0, 0, 0.04);
	transition: all 0.3s ease;
}

.pmv-team-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

.pmv-team-image-wrap {
	width: 100%;
	height: 220px;
	overflow: hidden;
	background: #ececec;
}

.pmv-team-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.pmv-team-body {
	padding: 14px 14px 16px;
	text-align: left;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.pmv-team-body h3 {
	margin: 0 0 8px;
	font-size: 18px;
	line-height: 1.25;
	letter-spacing: 0.3px;
	color: #2f2f2f;
	min-height: 46px;
}

.pmv-team-role {
	margin: 0 0 10px;
	font-size: 11px;
	line-height: 1.5;
	letter-spacing: 2.2px;
	text-transform: uppercase;
	color: #a9b88f;
	font-weight: 600;
	min-height: 34px;
}

.pmv-team-desc {
	margin: 0;
	font-size: 13px;
	line-height: 1.8;
	color: #666;
	flex-grow: 1;
}

.pmv-team-section .intro-heading {
	margin-bottom: 10px;
}

.pmv-team-section .intro-heading h2 {
	font-size: 34px;
}

.pmv-team-section .intro-heading p {
	max-width: 640px;
	margin: 0 auto;
	font-size: 14px;
	line-height: 1.8;
}

@media (max-width: 1199px) {
	.pmv-team-image-wrap {
		height: 200px;
	}

	.pmv-team-body h3 {
		font-size: 17px;
	}
}

@media (max-width: 991px) {
	.pmv-team-col {
		width: 50%;
	}

	.pmv-team-image-wrap {
		height: 240px;
	}

	.pmv-team-body h3,
	.pmv-team-role {
		min-height: auto;
	}
}

@media (max-width: 767px) {
	.pmv-team-col {
		width: 100%;
		padding-left: 15px;
		padding-right: 15px;
	}

	.pmv-team-image-wrap {
		height: 260px;
	}

	.pmv-team-body {
		padding: 16px;
	}

	.pmv-team-body h3 {
		font-size: 20px;
	}

	.pmv-team-role {
		font-size: 12px;
		letter-spacing: 2px;
	}

	.pmv-team-desc {
		font-size: 14px;
	}
}

/* =========================
   PMV TRUSTED PARTNER - CLEAN BADGE
========================= */

#colorlib-creative .intro-heading {
	margin-bottom: 10px;
}

#colorlib-creative .creative-intro {
	margin-bottom: 10px;
}

.pmv-partner-badge {
	display: inline-block;
	margin: 8px auto 18px;
	padding: 10px 16px;
	background: #fff;
	border: 1px solid rgba(169, 184, 143, 0.22);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.05);
	border-radius: 2px;
	position: relative;
}

.pmv-partner-badge:after {
	content: "";
	position: absolute;
	left: 18px;
	right: 18px;
	bottom: -8px;
	height: 14px;
	background: rgba(0, 0, 0, 0.06);
	filter: blur(10px);
	border-radius: 50%;
	z-index: -1;
}

.pmv-partner-badge-logo {
	display: block;
	margin: 0 auto;
	width: 400px;
	max-width: 100%;
	height: auto;
}

#colorlib-creative .creative-grid {
	margin-top: 10px;
}

#colorlib-creative .creative-item {
	min-height: 420px;
}

@media (max-width: 991px) {
	.pmv-partner-badge-logo {
		width: 220px;
	}
}

@media (max-width: 767px) {
	.pmv-partner-badge {
		margin: 8px auto 14px;
		padding: 8px 12px;
	}

	.pmv-partner-badge-logo {
		width: 190px;
	}
}
/* =========================
   PMV TEAM MODAL - PROFILE LAYOUT
========================= */

.pmv-team-card {
	cursor: pointer;
}

.pmv-team-card:focus {
	outline: 2px solid rgba(169, 184, 143, 0.65);
	outline-offset: 4px;
}

.pmv-team-link {
	display: inline-block;
	margin-top: 18px;
	font-size: 14px;
	letter-spacing: 0.04em;
	color: #6e6e6e;
	transition: color 0.25s ease, transform 0.25s ease;
}

.pmv-team-card:hover .pmv-team-link,
.pmv-team-card:focus .pmv-team-link {
	color: #8ea071;
	transform: translateX(2px);
}

.pmv-team-modal {
	padding-right: 0 !important;
}

.pmv-team-modal .modal-dialog {
	width: calc(100% - 40px);
	max-width: 1080px;
	margin: 38px auto;
}

.pmv-team-modal-content {
	position: relative;
	background: #f6f3ed;
	border: none;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.24);
}

.pmv-team-modal-content:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 6px;
	background: linear-gradient(90deg, #d57392 0%, #d57392 48%, #a9b88f 52%, #a9b88f 100%);
}

.pmv-team-modal-close {
	position: absolute;
	right: 24px;
	top: 20px;
	width: 44px;
	height: 44px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: #ffffff;
	color: #4f4f4f;
	font-size: 28px;
	line-height: 1;
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
	z-index: 12;
}

.pmv-team-modal-close:hover,
.pmv-team-modal-close:focus {
	background: #ffffff;
	color: #1f1f1f;
}

.pmv-team-modal-body {
	padding: 38px 42px 34px;
	max-height: calc(100vh - 90px);
	overflow-y: auto;
	background: #f6f3ed;
}

.pmv-team-modal-shell {
	display: grid;
	grid-template-columns: 230px minmax(0, 1fr);
	gap: 34px;
	align-items: start;
}

.pmv-team-modal-sidebar {
	position: relative;
}

.pmv-team-modal-photo-wrap {
	text-align: center;
	margin-bottom: 24px;
}

.pmv-team-modal-photo {
	width: 190px;
	height: 190px;
	object-fit: cover;
	object-position: center top;
	border-radius: 50%;
	border: 7px solid #ffffff;
	box-shadow: 0 18px 38px rgba(0, 0, 0, 0.14);
	margin: 0 auto;
}

.pmv-team-modal-contact-card {
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid rgba(169, 184, 143, 0.18);
	padding: 18px 18px 8px;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.05);
}

.pmv-team-modal-contact-row {
	margin-bottom: 12px;
}

.pmv-team-modal-contact-row span {
	display: block;
	margin-bottom: 4px;
	font-size: 11px;
	line-height: 1.5;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: #97a67d;
	font-weight: 700;
}

.pmv-team-modal-contact-row a {
	font-size: 16px;
	line-height: 1.7;
	color: #2d2d2d;
	word-break: break-word;
}

.pmv-team-modal-contact-row a:hover,
.pmv-team-modal-contact-row a:focus {
	color: #0069b1;
}

.pmv-team-modal-main {
	min-width: 0;
}

.pmv-team-modal-kicker {
	display: inline-block;
	margin-bottom: 12px;
	font-size: 12px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: #9cac84;
	font-weight: 700;
}

.pmv-team-modal-name {
	margin: 0;
	font-size: 52px;
	line-height: 1.05;
	color: #006cb3;
	font-weight: 700;
}

.pmv-team-modal-role {
	margin: 10px 0 26px;
	font-size: 18px;
	line-height: 1.5;
	color: #4a4a4a;
}

.pmv-team-modal-summary {
	margin-bottom: 26px;
}

.pmv-team-modal-summary-block {
	margin-bottom: 20px;
}

.pmv-team-modal-summary-block:last-child {
	margin-bottom: 0;
}

.pmv-team-modal-summary-title {
	margin: 0 0 8px;
	font-size: 17px;
	line-height: 1.7;
	color: #2d2d2d;
}

.pmv-team-modal-inline-link {
	display: block;
	margin-bottom: 4px;
	font-size: 16px;
	line-height: 1.7;
	color: #006cb3;
}

.pmv-team-modal-inline-link:hover,
.pmv-team-modal-inline-link:focus {
	color: #004e82;
}

.pmv-team-modal-sections {
	border-top: 1px solid rgba(0, 0, 0, 0.08);
	padding-top: 22px;
}

.pmv-team-modal-section {
	margin-bottom: 18px;
}

.pmv-team-modal-section:last-child {
	margin-bottom: 0;
}

.pmv-team-modal-section h5 {
	margin: 0 0 10px;
	font-size: 15px;
	line-height: 1.6;
	font-weight: 700;
	color: #006cb3;
}

.pmv-team-modal-section:first-child h5 {
	font-size: 17px;
	color: #1d1d1d;
}

.pmv-team-modal-section ul {
	margin: 0;
	padding-left: 26px;
}

.pmv-team-modal-section li {
	margin-bottom: 8px;
	font-size: 16px;
	line-height: 1.75;
	color: #313131;
}

.pmv-team-modal-section li:last-child {
	margin-bottom: 0;
}

body.modal-open .pmv-team-modal {
	overflow-y: auto !important;
}

@media (max-width: 1199px) {
	.pmv-team-modal-name {
		font-size: 44px;
	}
}

@media (max-width: 991px) {
	.pmv-team-modal-body {
		padding: 34px 28px 28px;
	}

	.pmv-team-modal-shell {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.pmv-team-modal-sidebar {
		display: grid;
		grid-template-columns: 220px 1fr;
		gap: 22px;
		align-items: center;
	}

	.pmv-team-modal-photo-wrap {
		margin-bottom: 0;
	}

	.pmv-team-modal-name {
		font-size: 38px;
	}
}

@media (max-width: 767px) {
	.pmv-team-modal .modal-dialog {
		width: calc(100% - 20px);
		margin: 24px auto;
	}

	.pmv-team-modal-body {
		padding: 28px 18px 22px;
		max-height: calc(100vh - 50px);
	}

	.pmv-team-modal-close {
		right: 12px;
		top: 12px;
		width: 40px;
		height: 40px;
		font-size: 24px;
	}

	.pmv-team-modal-sidebar {
		display: block;
	}

	.pmv-team-modal-photo {
		width: 150px;
		height: 150px;
	}

	.pmv-team-modal-contact-card {
		margin-top: 18px;
	}

	.pmv-team-modal-name {
		font-size: 30px;
		padding-right: 36px;
	}

	.pmv-team-modal-role {
		margin-bottom: 22px;
		font-size: 16px;
	}

	.pmv-team-modal-summary-title,
	.pmv-team-modal-inline-link,
	.pmv-team-modal-section li,
	.pmv-team-modal-contact-row a {
		font-size: 15px;
	}
}


/* =========================================================
   PMV HELP GRID - 5 COLUMNS DESKTOP
   tempel blok ini di PALING BAWAH custom.css
========================================================= */
#colorlib-life-create .pmv-help-grid{
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  margin-left: 0;
  margin-right: 0;
}

#colorlib-life-create .pmv-help-grid .pmv-help-col{
  float: none;
  width: 20%;
  max-width: 20%;
  flex: 0 0 20%;
  padding-left: 0;
  padding-right: 0;
}

#colorlib-life-create .pmv-help-grid .life-work-img{
  height: 320px;
}

#colorlib-life-create .pmv-help-grid .life-work-img .work-name{
  max-width: 84%;
  padding: 16px 12px;
}

#colorlib-life-create .pmv-help-grid .life-work-img .work-name h2{
  font-size: 14px;
  line-height: 1.35;
}

@media (max-width: 991px){
  #colorlib-life-create .pmv-help-grid{
    flex-wrap: wrap;
  }

  #colorlib-life-create .pmv-help-grid .pmv-help-col{
    width: 33.3333%;
    max-width: 33.3333%;
    flex: 0 0 33.3333%;
  }

  #colorlib-life-create .pmv-help-grid .life-work-img{
    height: 280px;
  }
}

@media (max-width: 767px){
  #colorlib-life-create .pmv-help-grid .pmv-help-col{
    width: 50%;
    max-width: 50%;
    flex: 0 0 50%;
  }

  #colorlib-life-create .pmv-help-grid .life-work-img{
    height: 240px;
  }

  #colorlib-life-create .pmv-help-grid .life-work-img .work-name{
    max-width: 88%;
    padding: 14px 12px;
  }

  #colorlib-life-create .pmv-help-grid .life-work-img .work-name h2{
    font-size: 13px;
  }
}

@media (max-width: 480px){
  #colorlib-life-create .pmv-help-grid .pmv-help-col{
    width: 100%;
    max-width: 100%;
    flex: 0 0 100%;
  }

  #colorlib-life-create .pmv-help-grid .life-work-img{
    height: 220px;
  }
}
