:root{
  --font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-heading: "Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --radius-xl: 1.25rem;
  --shadow-soft: 0 12px 30px rgba(18, 24, 40, 0.10);
  --shadow-soft-2: 0 8px 22px rgba(18, 24, 40, 0.08);

  --hero-grad-1: rgba(212, 178, 95, 0.16);
  --hero-grad-2: rgba(244, 221, 158, 0.10);

  --law-gold: #d4b25f;
  --law-gold-soft: #f4dd9e;
  --law-ink: #0b1220;
  --law-ink-2: #101a2c;
  --law-panel: rgba(17, 26, 44, .55);
  --law-panel-2: rgba(17, 26, 44, .35);
  --law-border: rgba(244, 221, 158, .14);
  --law-border-2: rgba(148, 163, 184, .14);
  --law-text: rgba(232, 237, 247, .92);
  --law-text-dim: rgba(232, 237, 247, .74);

  --section-surface-a: linear-gradient(180deg, #0d1628 0%, #0a1120 100%);
  --section-surface-b: linear-gradient(180deg, #101c30 0%, #0b1322 100%);
}

html[data-bs-theme="light"],
html[data-bs-theme="dark"]{
  --bs-body-bg: var(--law-ink);
  --bs-body-color: var(--law-text);
  --bs-body-color-rgb: 232, 237, 247;
  --bs-secondary-color: var(--law-text-dim);
  --bs-secondary-color-rgb: 232, 237, 247;
  --bs-border-color: var(--law-border-2);
  --bs-tertiary-bg: rgba(17, 26, 44, .55);
  --bs-link-color: var(--law-gold-soft);
  --bs-link-hover-color: var(--law-gold-soft);
  --bs-primary: var(--law-gold);
}

html, body { height: 100%; }
html{ scroll-padding-top: 120px; }
body{
  font-family: var(--font-body);
  letter-spacing: -0.005em;
  color: var(--bs-body-color);
  background:
    radial-gradient(1000px 700px at 18% -10%, rgba(244, 221, 158, .10), transparent 55%),
    radial-gradient(900px 650px at 85% 0%, rgba(212, 178, 95, .10), transparent 55%),
    radial-gradient(900px 650px at 55% 110%, rgba(148, 163, 184, .06), transparent 60%),
    linear-gradient(180deg, var(--law-ink) 0%, #070b14 100%);
}

/* Section blocks: 1 section = 1 background + divider */
main > section{
  position: relative;
  isolation: isolate;
  z-index: 0;
}

main > section + section{ margin-top: 0; }

main > section:not(.hero-section){
  background: var(--section-surface-a) !important;
  border-top: 1px solid rgba(232, 237, 247, .08);
  border-bottom: 0;
}

main > section:not(.hero-section):nth-of-type(odd){
  background: var(--section-surface-b) !important;
}

/* Bootstrap utility on sections can override backgrounds; keep section surfaces consistent */
main > section.bg-body-tertiary{
  background: var(--section-surface-b) !important;
}


h1, h2, h3, .navbar-brand .brand-text{
  font-family: var(--font-heading);
  letter-spacing: -0.02em;
}

/* Improve readability for hero copy on dark background */
.hero-title{ color: var(--law-text); }
.hero-subtitle{ color: var(--law-text-dim) !important; }
.hero-section .text-body-secondary{ color: var(--law-text-dim) !important; }

/* Bootstrap helper classes often used in the markup */
.text-body-secondary,
.text-secondary,
.text-muted{ color: var(--law-text-dim) !important; }

.shadow-soft{ box-shadow: var(--shadow-soft); border-radius: var(--radius-xl); }

.skip-link{
  position: absolute;
  left: -999px;
  top: 0;
  padding: .75rem 1rem;
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: 999px;
  z-index: 9999;
}
.skip-link:focus{ left: 1rem; top: 1rem; }

/* Minimal header (reference UI) */
.app-header{
  position: sticky;
  top: 0;
  z-index: 1030;
  padding: 0;
  background: transparent;
  border-bottom: 0;
}
.brand-minimal{ text-decoration: none; }
.brand-minimal .brand-text{ font-weight: 700; }

/* Law navbar (logo + menu) */
.law-navbar{
  background: transparent;
}

/* Ensure section anchors are not hidden behind sticky header */
section[id]{ scroll-margin-top: 120px; }
.nav-anchor{ scroll-margin-top: 120px; }

/* Footer anchor targets */
#kantor-pusat,
#kantor-cabang,
#layanan-kami,
#legal{ scroll-margin-top: 120px; }

/* Pill container (like reference) */
.law-navbar .container{
  border-radius: 999px;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  background:
    radial-gradient(520px 120px at 12% 0%, rgba(244, 221, 158, .10), transparent 62%),
    radial-gradient(520px 120px at 88% 0%, rgba(212, 178, 95, .08), transparent 62%),
    linear-gradient(180deg, rgba(11, 18, 32, .92) 0%, rgba(11, 18, 32, .72) 100%);
  border: 1px solid rgba(232, 237, 247, .10);
  box-shadow:
    0 20px 60px rgba(2, 6, 23, .55),
    inset 0 1px 0 rgba(232, 237, 247, .06);
  backdrop-filter: blur(14px);
}

.law-brand{
  padding-top: .25rem;
  padding-bottom: .25rem;
  gap: .75rem;
}

.brand-logo{
  width: 70px;
  height: 44px;
  object-fit: contain;
  display: block;
}

.brand-name{
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: -0.015em;
  color: rgba(232, 237, 247, .92);
  white-space: nowrap;
}

@media (max-width: 576px){
  .brand-name{ font-size: 1.02rem; }
}

.law-nav-link{
  text-transform: none;
  font-weight: 600;
  letter-spacing: .01em;
  font-size: 13px;
  color: rgba(232, 237, 247, .84);
  position: relative;
  padding-left: .85rem;
  padding-right: .85rem;
}

.law-nav-link:hover,
.law-nav-link:focus{
  color: var(--law-gold-soft);
}

.law-nav-link.active,
.law-nav-link[aria-current="page"]{
  color: var(--law-gold-soft);
}

.law-nav-link.active::after,
.law-nav-link[aria-current="page"]::after{
  content: "";
  position: absolute;
  left: .85rem;
  right: .85rem;
  bottom: .15rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--law-gold-soft), transparent);
}

/* Navbar dropdown */
.law-navbar .dropdown-menu{
  border-radius: 1rem;
  padding: .5rem;
  min-width: 14rem;
  background:
    radial-gradient(420px 160px at 20% 0%, rgba(244, 221, 158, .10), transparent 55%),
    linear-gradient(180deg, rgba(11, 18, 32, .96) 0%, rgba(11, 18, 32, .86) 100%);
  border: 1px solid rgba(232, 237, 247, .10);
  box-shadow: 0 18px 50px rgba(2, 6, 23, .55);
  backdrop-filter: blur(14px);
}

.law-navbar .dropdown-item{
  border-radius: .75rem;
  color: var(--law-text-dim);
  font-weight: 600;
  font-size: 13px;
  padding: .55rem .75rem;
}

.law-navbar .dropdown-item:hover,
.law-navbar .dropdown-item:focus{
  color: var(--law-gold-soft);
  background: rgba(244, 221, 158, .08);
}

.law-navbar .dropdown-item:active{
  color: var(--law-gold-soft);
  background: rgba(244, 221, 158, .12);
}

/* Footer */
.site-footer{
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(540px 280px at 0% 50%, rgba(244, 221, 158, .14), transparent 68%),
    radial-gradient(500px 260px at 100% 50%, rgba(212, 178, 95, .10), transparent 66%),
    linear-gradient(90deg, rgba(212, 178, 95, .16) 0%, rgba(26, 37, 58, .96) 34%, #0a1120 100%) !important;
  border-top: 1px solid rgba(232, 237, 247, .08);
}

.site-footer::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(244, 221, 158, .08) 50%, transparent 100%);
  opacity: .55;
  pointer-events: none;
}

.site-footer > *{
  position: relative;
  z-index: 1;
}

.site-footer .footer-divider{
  border-color: rgba(232, 237, 247, .10);
  opacity: 1;
}

.site-footer .footer-links a{
  color: var(--law-text-dim);
  text-decoration: none;
}

.site-footer .footer-links a:hover,
.site-footer .footer-links a:focus{
  color: var(--law-gold-soft);
}

.site-footer .footer-contact-list li{
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  color: var(--law-text-dim);
}

.site-footer .footer-contact-list i{
  color: var(--law-gold-soft);
  font-size: .95rem;
  line-height: 1.5;
}

.site-footer .footer-contact-list a,
.site-footer .footer-bottom-links a{
  color: var(--law-text-dim);
  text-decoration: none;
}

.site-footer .footer-contact-list a:hover,
.site-footer .footer-contact-list a:focus,
.site-footer .footer-bottom-links a:hover,
.site-footer .footer-bottom-links a:focus{
  color: var(--law-gold-soft);
}

.site-footer .footer-list li{
  color: var(--law-text-dim);
  position: relative;
  padding-left: 1.5rem;
}

.site-footer .footer-list li::before{
  content: "\2713";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--law-gold-soft);
  font-weight: 700;
}

/* Internal content pages */
.content-page main{
  padding: 3rem 0 4rem;
}

.content-page-hero{
  margin-bottom: 2rem;
}

.content-page-kicker{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .45rem .8rem;
  border-radius: 999px;
  border: 1px solid rgba(244, 221, 158, .16);
  background: rgba(15, 23, 42, .45);
  color: var(--law-gold-soft);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .01em;
}

.content-page-title{
  margin-top: 1rem;
  margin-bottom: .75rem;
}

.content-page-grid{
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 1.5rem;
  align-items: start;
}

.content-page-card,
.content-page-nav{
  border: 1px solid var(--law-border-2);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}

.content-page-nav{
  padding: 1.25rem 1.35rem;
  position: sticky;
  top: 120px;
}

.content-page-nav-title{
  font-family: var(--font-heading);
  font-size: 1rem;
  margin-bottom: .85rem;
}

.content-page-nav-list{
  list-style: none;
  margin: 0;
  padding: 0;
}

.content-page-nav-list li + li{
  border-top: 1px solid rgba(232, 237, 247, .10);
}

.content-page-nav-list a{
  display: block;
  padding: .95rem 0;
  color: var(--law-text-dim);
  text-decoration: none;
  font-weight: 600;
}

.content-page-nav-list a:hover,
.content-page-nav-list a:focus,
.content-page-nav-list a.active{
  color: var(--law-gold-soft);
}

.content-page-card{
  padding: 1.75rem;
}

.content-page-card h2{
  margin-bottom: 1rem;
}

.content-page-card p,
.content-page-card li{
  color: var(--law-text-dim);
}

.content-page-card ul{
  padding-left: 1.2rem;
}

/* ── Founder profile block ── */
.founder-profile-block{
  margin-bottom: 1.5rem;
}

.founder-profile-header{
  display: flex;
  gap: 1.75rem;
  align-items: flex-start;
}

.founder-profile-meta{
  flex: 1;
}

.founder-bio{
  color: var(--law-text-dim);
  font-size: .93rem;
  line-height: 1.75;
}

.founder-divider{
  border-color: var(--law-border-2);
  margin: 2rem 0;
}

/* ── Career cards ── */
.founder-karir{
  margin-top: 1.5rem;
}

.founder-karir-title{
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 700;
  color: var(--law-gold-soft);
  margin-bottom: 1rem;
}

.founder-karir-title .bi{
  margin-right: .4rem;
}

.karir-card{
  border: 1px solid var(--law-border-2);
  border-radius: .75rem;
  overflow: hidden;
  height: 100%;
}

.karir-card-header{
  background: linear-gradient(135deg, rgba(212,175,55,.15), rgba(212,175,55,.05));
  border-bottom: 1px solid var(--law-border-2);
  padding: .6rem 1rem;
  font-family: var(--font-heading);
  font-size: .82rem;
  font-weight: 700;
  color: var(--law-gold-soft);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.karir-list{
  list-style: none;
  margin: 0;
  padding: .75rem 1rem;
}

.karir-list li{
  color: var(--law-text-dim);
  font-size: .88rem;
  line-height: 1.6;
  padding: .3rem 0;
  border-bottom: 1px solid rgba(232,237,247,.06);
}

.karir-list li:last-child{
  border-bottom: none;
}

.karir-list li::before{
  content: '–';
  margin-right: .5rem;
  color: var(--law-gold-soft);
}

@media (max-width: 767.98px){
  .founder-profile-header{
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}

/* ── Lingkup Pekerjaan sections ── */
.lingkup-section{
  margin-bottom: 1.75rem;
}

.lingkup-heading{
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--law-gold-soft);
  border-left: 3px solid var(--law-gold-soft);
  padding-left: .75rem;
  margin-bottom: .85rem;
}

/* ── Lingkup team photo card ── */
.lingkup-team-card{
  border: 1px solid var(--law-border-2);
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: 2rem;
}

.lingkup-team-img-wrap{
  width: 100%;
  max-height: 420px;
  overflow: hidden;
  background: #111;
}

.lingkup-team-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .4s ease;
}

.lingkup-team-card:hover .lingkup-team-img{
  transform: scale(1.03);
}

.lingkup-team-caption{
  padding: 1.25rem 1.5rem;
  background: linear-gradient(135deg, var(--law-panel), var(--law-panel-2));
  border-top: 1px solid var(--law-border-2);
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.lingkup-team-tagline{
  margin: 0;
  font-style: italic;
  font-size: .95rem;
  color: var(--law-text-dim);
  line-height: 1.65;
}

.lingkup-team-label{
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--law-gold-soft);
}

.lingkup-team-label .bi{
  margin-right: .35rem;
}

/* ── Org Chart branch row (side node below a tier) ── */
.org-branch-row{
  display: flex;
  align-items: stretch;
  position: relative;
}

.org-branch-line{
  width: 2px;
  min-height: 6rem;
  background: var(--law-gold-soft);
  flex-shrink: 0;
}

.org-branch-side{
  display: flex;
  align-items: center;
  padding-left: 0;
}

.org-branch-h{
  width: 2.5rem;
  height: 2px;
  background: var(--law-gold-soft);
  flex-shrink: 0;
}

@media (max-width: 767.98px){
  .org-branch-row{
    flex-direction: column;
    align-items: center;
  }
  .org-branch-line{
    width: 2px;
    min-height: 1.5rem;
  }
  .org-branch-h{
    display: none;
  }
}

/* ── Org Chart ── */
.org-chart{
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow-x: auto;
  padding: .5rem 0 1rem;
}

.org-tier{
  display: flex;
  justify-content: center;
  align-items: center;
}

.org-tier--row2{
  display: flex;
  align-items: center;
}

.org-main-col{
  display: flex;
  justify-content: center;
}

.org-side-col{
  display: flex;
  align-items: center;
}

.org-side-connector{
  width: 3rem;
  height: 2px;
  background: var(--law-gold-soft);
}

.org-node{
  border: 2px solid var(--law-gold-soft);
  border-radius: .85rem;
  background: linear-gradient(135deg, rgba(212,175,55,.13), rgba(212,175,55,.03));
  padding: .85rem 1.25rem;
  min-width: 185px;
  max-width: 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: .35rem;
}

.org-avatar{
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  background: var(--law-gold-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #111;
  font-size: 1rem;
  margin-bottom: .15rem;
}

.org-node-role{
  font-family: var(--font-heading);
  font-size: .75rem;
  font-weight: 700;
  color: var(--law-gold-soft);
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: 1.3;
}

.org-node-name{
  font-size: .8rem;
  color: var(--law-text-dim);
  font-weight: 500;
  line-height: 1.4;
}

.org-v-connector{
  width: 2px;
  height: 1.75rem;
  background: var(--law-gold-soft);
}

.org-depts-row{
  display: flex;
  position: relative;
}

.org-depts-row::before{
  content: '';
  position: absolute;
  top: 0;
  left: 16.67%;
  right: 16.67%;
  height: 2px;
  background: var(--law-gold-soft);
}

.org-dept{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.75rem 1rem 0;
  position: relative;
}

.org-dept::before{
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 1.75rem;
  background: var(--law-gold-soft);
}

.org-members-list{
  list-style: none;
  margin: .65rem 0 0;
  padding: 0;
  border: 1px solid var(--law-border-2);
  border-radius: .6rem;
  overflow: hidden;
  min-width: 185px;
  max-width: 220px;
}

.org-members-list li{
  font-size: .8rem;
  color: var(--law-text-dim);
  padding: .45rem .85rem;
  border-bottom: 1px solid var(--law-border-2);
  text-align: center;
}

.org-members-list li:last-child{
  border-bottom: none;
}

@media (max-width: 767.98px){
  .org-tier--row2{
    flex-direction: column;
  }
  .org-side-connector{
    width: 2px;
    height: 1.5rem;
  }
  .org-depts-row{
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
  }
  .org-depts-row::before{
    display: none;
  }
  .org-dept{
    padding-top: 0;
  }
  .org-dept::before{
    display: none;
  }
  .org-node,
  .org-members-list{
    min-width: 220px;
    max-width: 300px;
  }
}

@media (max-width: 991.98px){
  .content-page-grid{
    grid-template-columns: 1fr;
  }

  .content-page-nav{
    position: static;
  }
}

/* ── Portfolio grid ── */
.portfolio-card{
  border: 1px solid var(--law-border-2);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
  height: 100%;
}
.portfolio-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(2, 6, 23, .4);
}
.portfolio-card-img{
  aspect-ratio: 16 / 10;
  overflow: hidden;
}
.portfolio-card-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.portfolio-card:hover .portfolio-card-img img{
  transform: scale(1.04);
}
.portfolio-card-body{
  padding: 1.25rem 1.35rem;
}
.portfolio-card-title{
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.45;
  margin: 0;
  color: var(--law-text);
}

/* ── Penghargaan cards ── */
.penghargaan-card{
  border: 1px solid var(--law-border-2);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
  overflow: hidden;
  height: 100%;
  transition: transform .25s ease, box-shadow .25s ease;
}
.penghargaan-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(2, 6, 23, .4);
}
.penghargaan-card-img{
  overflow: hidden;
  background: rgba(255,255,255,.04);
}
.penghargaan-card-img img{
  width: 100%;
  height: auto;
  display: block;
  transition: transform .35s ease;
}
.penghargaan-card:hover .penghargaan-card-img img{
  transform: scale(1.03);
}
.penghargaan-card-body{
  padding: 1.35rem 1.5rem;
}
.penghargaan-card-title{
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.45;
  margin: 0 0 .65rem;
  color: var(--law-text);
}
.penghargaan-card-desc{
  font-size: .9rem;
  color: var(--law-text-dim);
  margin-bottom: .75rem;
  line-height: 1.6;
}
.penghargaan-card-date{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  color: var(--law-gold-soft);
  font-weight: 600;
}

/* ── Gallery ── */
.gallery-tabs{
  gap: .5rem;
  flex-wrap: wrap;
}
.gallery-tabs .nav-link{
  background: var(--law-panel);
  border: 1px solid var(--law-border-2);
  color: var(--law-text-dim);
  border-radius: 999px;
  font-size: .88rem;
  font-weight: 600;
  padding: .55rem 1.2rem;
  transition: all .2s ease;
}
.gallery-tabs .nav-link:hover{
  color: var(--law-gold-soft);
  border-color: rgba(244, 221, 158, .3);
}
.gallery-tabs .nav-link.active{
  background: rgba(212, 178, 95, .12);
  border-color: var(--law-gold);
  color: var(--law-gold-soft);
}
.gallery-item{
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--law-border-2);
  aspect-ratio: 1;
  background: rgba(255,255,255,.03);
}
.gallery-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.gallery-item:hover img{
  transform: scale(1.06);
}

.navbar-toggler{
  border-color: rgba(244, 221, 158, .22);
}
.navbar-toggler:focus{
  box-shadow: 0 0 0 .25rem rgba(244, 221, 158, .14);
}

.nav-anchor{ scroll-margin-top: 96px; }

.header-actions{
  font-weight: 600;
}

.header-locale{
  font-size: .9rem;
  letter-spacing: .02em;
}

.header-icon{
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--bs-secondary-color);
}
.header-icon:hover{ color: var(--bs-body-color); }
.header-icon:focus-visible{
  outline: none;
  box-shadow: 0 0 0 .25rem color-mix(in srgb, var(--bs-primary) 25%, transparent);
}

.header-link{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  text-decoration: none;
  font-size: .95rem;
}
.header-link:hover{ color: var(--bs-body-color); }

.brand-mark{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: radial-gradient(circle at 30% 30%, #6366f1, #0ea5e9);
  box-shadow: var(--shadow-soft-2);
}

.hero-section{
  position: relative;
  isolation: isolate;
  padding: 0;
  overflow: hidden;
}

/* Hero has its own block; following sections use their own surfaces/dividers */
.hero-section{ border-bottom: 1px solid rgba(232, 237, 247, .08); }

@media (max-width: 576px){
  .hero-section > .container{ padding-top: 3.25rem; }
}

@media (min-width: 992px){
  .hero-section > .container{ padding-top: 4.25rem; }
}

/* Smooth separation so hero glow doesn't feel like it overlaps next section */
.hero-section::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 200px;
  background: linear-gradient(180deg, transparent 0%, var(--law-ink) 100%);
  pointer-events: none;
  z-index: -1;
}

.hero-section > .container{
  position: relative;
  z-index: 1;
  padding-top: 3.75rem;
  padding-bottom: 5rem;
}

.hero-glow{
  position: absolute;
  inset: -80px;
  background:
    radial-gradient(900px 650px at 18% 25%, var(--hero-grad-1), transparent 62%),
    radial-gradient(820px 600px at 85% 10%, var(--hero-grad-2), transparent 64%);
  pointer-events: none;
  z-index: -2;
}



.hero-title{ line-height: 1.05; }
.hero-subtitle{ max-width: 54ch; }

.hero-badge{
  padding: .5rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--law-border-2);
  background: rgba(15, 23, 42, .40);
  box-shadow: 0 10px 30px rgba(2, 6, 23, .30);
  font-size: .92rem;
}

.hero-card{ border-radius: var(--radius-xl); }

.feature-row{
  display: flex;
  gap: .75rem;
  align-items: flex-start;
}
.feature-row i{ color: var(--law-gold-soft); font-size: 1.1rem; margin-top: .15rem; }

.mini-stat{
  display: flex;
  gap: .75rem;
  padding: .9rem 1rem;
  border: 1px solid var(--bs-border-color);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--bs-body-bg) 88%, transparent);
  box-shadow: var(--shadow-soft-2);
}
.mini-stat-icon{
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: color-mix(in srgb, var(--bs-primary) 10%, transparent);
}
.mini-stat-title{ font-weight: 700; }
.mini-stat-sub{ font-size: .9rem; }

.trust-card{
  height: 100%;
  padding: 1rem 1rem;
  border: 1px solid var(--law-border-2);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}
.trust-icon{
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: rgba(244, 221, 158, .10);
  margin-bottom: .75rem;
}
.trust-icon i{ color: var(--law-gold-soft); font-size: 1.1rem; }

.step-card{
  height: 100%;
  padding: 1.1rem 1.1rem;
  border-radius: var(--radius-xl);
  border: 1px solid var(--law-border-2);
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}
.step-number{
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(244, 221, 158, .10);
  color: var(--law-gold-soft);
  font-weight: 800;
  margin-bottom: .75rem;
}

.progress-thin{ height: 10px; border-radius: 999px; }
.progress-thin .progress-bar{ border-radius: 999px; }

.segmented{
  display: inline-flex;
  border: 1px solid var(--bs-border-color);
  border-radius: 999px;
  padding: .35rem;
  gap: .35rem;
  background: var(--bs-body-bg);
}
.segmented .btn{
  border-radius: 999px;
  padding: .5rem 1rem;
}

/* Gradient buttons (smooth click) */
.btn-grad{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(244, 221, 158, .18);
  border-radius: 999px;
  color: #0b1220;
  font-weight: 700;
  letter-spacing: -0.005em;
  transform: translateZ(0);
  will-change: transform, box-shadow;
  transition: transform 140ms ease, box-shadow 220ms ease;
  box-shadow: 0 14px 42px rgba(2, 6, 23, .35);
  touch-action: manipulation;
}
.btn-grad > *{ position: relative; z-index: 1; }
.btn-grad:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 56px rgba(2, 6, 23, .42);
}
.btn-grad:active{
  transform: translateY(0) scale(.99);
  box-shadow: 0 12px 36px rgba(2, 6, 23, .38);
}
.btn-grad:focus-visible{
  outline: none;
  box-shadow:
    0 0 0 .25rem rgba(244, 221, 158, .18),
    0 18px 56px rgba(2, 6, 23, .42);
}
.btn-grad::after{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.26), rgba(255,255,255,.08) 46%, transparent 70%);
  opacity: .55;
  pointer-events: none;
}

/* Outline CTAs (like reference secondary buttons) */
.btn-law-outline{
  background-image: none;
  background: rgba(15, 23, 42, .18);
  color: var(--law-text);
  border: 1px solid rgba(244, 221, 158, .40);
  box-shadow: none;
}
.btn-law-outline::after{ opacity: .22; }
.btn-law-outline:hover{
  background: rgba(15, 23, 42, .28);
  box-shadow: 0 16px 44px rgba(2, 6, 23, .34);
}
.btn-law-outline:focus-visible{
  box-shadow: 0 0 0 .25rem rgba(244, 221, 158, .16);
}

.btn-law-outline.btn-law-outline-muted{
  border-color: rgba(232, 237, 247, .18);
  color: rgba(248, 250, 252, .92);
}
.btn-law-outline.btn-law-outline-muted:hover{
  border-color: rgba(232, 237, 247, .26);
}

/* Normalize when old markup still uses rounded-pill */
.btn-grad.rounded-pill{ border-radius: 999px !important; }

.hero-checks i{
  color: var(--law-gold-soft);
  font-size: 1.1rem;
}

/* Variants */
.btn-grad-ocean{ background-image: linear-gradient(180deg, var(--law-gold-soft), var(--law-gold)); }
.btn-grad-emerald{ background-image: linear-gradient(180deg, var(--law-gold-soft), var(--law-gold)); }
.btn-grad-sunset{
  background-image: none;
  background: rgba(15, 23, 42, .30);
  color: var(--law-text);
  border: 1px solid rgba(244, 221, 158, .24);
  box-shadow: none;
}
.btn-grad-sunset:hover{
  background: rgba(15, 23, 42, .42);
  box-shadow: 0 16px 44px rgba(2, 6, 23, .30);
}

/* Segmented toggle uses btn-grad (outline when not selected) */
.segmented .btn.btn-grad{
  background-image: none;
  background-color: rgba(15, 23, 42, .25);
  border: 1px solid rgba(244, 221, 158, .24);
  color: var(--law-text);
  box-shadow: none;
}
.segmented .btn.btn-grad:hover{
  transform: none;
  filter: none;
  box-shadow: none;
}
.segmented .btn.btn-grad:active{ transform: scale(.98); }
.segmented .btn-check:checked + .btn.btn-grad{
  background-image: linear-gradient(180deg, var(--law-gold-soft), var(--law-gold));
  border-color: rgba(244, 221, 158, .18);
  color: #0b1220;
}
.segmented .btn-check:focus-visible + .btn.btn-grad{
  box-shadow: 0 0 0 .25rem rgba(244, 221, 158, .18);
}

html[data-theme="dark"] .btn-grad{
  box-shadow: 0 18px 60px rgba(2, 6, 23, .42);
}
html[data-theme="dark"] .btn-grad:hover{
  box-shadow: 0 22px 74px rgba(2, 6, 23, .48);
}

.form-step{ display: none; opacity: 0; transform: translateY(6px); }
.form-step.active{ display: block; animation: stepIn 180ms ease-out forwards; }
@keyframes stepIn{ to { opacity: 1; transform: translateY(0); } }

.info-strip{
  display: flex;
  gap: .75rem;
  padding: 1rem;
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--bs-info) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--bs-info) 25%, var(--bs-border-color));
}
.info-strip i{ color: var(--bs-info); font-size: 1.1rem; margin-top: .1rem; }

.summary-list{
  display: grid;
  gap: .6rem;
}
.summary-item{
  padding: .65rem .75rem;
  border-radius: 1rem;
  border: 1px solid var(--bs-border-color);
  background: var(--bs-body-bg);
}
.summary-item .k{ font-weight: 700; font-size: .9rem; }
.summary-item .v{ color: var(--bs-secondary-color); font-size: .95rem; margin-top: .1rem; white-space: pre-wrap; }

.score-card{
  padding: 1rem;
  border-radius: var(--radius-xl);
  border: 1px solid var(--bs-border-color);
  background: var(--bs-body-bg);
  box-shadow: var(--shadow-soft-2);
}

/* Form controls (match dark reference UI) */
.form-control,
.form-select{
  background-color: rgba(15, 23, 42, .28);
  border-color: var(--law-border-2);
  color: var(--law-text);
}
.form-control::placeholder{ color: rgba(232, 237, 247, .55); }
.form-control:focus,
.form-select:focus{
  background-color: rgba(15, 23, 42, .34);
  border-color: rgba(244, 221, 158, .55);
  box-shadow: 0 0 0 .25rem rgba(244, 221, 158, .12);
}

/* Dark mode (kept for compatibility; now aligns with gold theme) */
html[data-theme="dark"]{
  --neon-border: var(--law-border);
  --neon-border-2: var(--law-border-2);
  --neon-bg: var(--law-panel);
  --neon-bg-2: var(--law-panel-2);
  --neon-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}

html[data-theme="dark"] body{
  background:
    radial-gradient(1000px 700px at 18% -10%, rgba(244, 221, 158, .10), transparent 55%),
    radial-gradient(900px 650px at 85% 0%, rgba(212, 178, 95, .10), transparent 55%),
    radial-gradient(900px 650px at 55% 110%, rgba(148, 163, 184, .06), transparent 60%),
    linear-gradient(180deg, var(--law-ink) 0%, #070b14 100%);
}

html[data-theme="dark"] .hero-glow{
  background:
    radial-gradient(900px 650px at 18% 25%, rgba(212, 178, 95, .18), transparent 62%),
    radial-gradient(820px 600px at 85% 10%, rgba(244, 221, 158, .14), transparent 64%);
}

html[data-theme="dark"] .brand-mark{
  box-shadow:
    0 0 0 1px rgba(34, 211, 238, .25),
    0 18px 60px rgba(34, 211, 238, .18),
    0 16px 48px rgba(167, 139, 250, .14);
}

html[data-theme="dark"] .shadow-soft,
html[data-theme="dark"] .trust-card,
html[data-theme="dark"] .step-card,
html[data-theme="dark"] .mini-stat,
html[data-theme="dark"] .score-card,
html[data-theme="dark"] .hero-card{
  background: linear-gradient(180deg, var(--law-panel), var(--law-panel-2));
  border: 1px solid var(--law-border-2);
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}

html[data-theme="dark"] .hero-badge{
  border-color: var(--law-border-2);
  background: rgba(15, 23, 42, .40);
  box-shadow: 0 18px 50px rgba(2, 6, 23, .28);
}

html[data-theme="dark"] .segmented{
  border-color: var(--law-border-2);
  background: rgba(2, 6, 23, .45);
}

html[data-theme="dark"] .progress-thin{ background: rgba(148, 163, 184, .18); }
html[data-theme="dark"] .progress-thin .progress-bar{
  background: linear-gradient(90deg, var(--law-gold-soft), var(--law-gold));
}

html[data-theme="dark"] .btn-primary{
  box-shadow: 0 10px 30px rgba(244, 221, 158, .14);
}
html[data-theme="dark"] .btn-primary:hover{
  box-shadow: 0 14px 42px rgba(244, 221, 158, .18);
}

html[data-theme="dark"] .hero-title{
  filter: drop-shadow(0 14px 34px rgba(244, 221, 158, .12));
}

html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select{
  background-color: rgba(2, 6, 23, .35);
  border-color: var(--neon-border-2);
}
html[data-theme="dark"] .form-control::placeholder{
  color: rgba(226, 232, 240, .55);
}
html[data-theme="dark"] .form-control:focus,
html[data-theme="dark"] .form-select:focus{
  border-color: rgba(34, 211, 238, .85);
  box-shadow: 0 0 0 .25rem rgba(34, 211, 238, .16);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)){
  html[data-theme="dark"] .hero-title,
  html[data-theme="dark"] h2.h3,
  html[data-theme="dark"] h2.h4,
  html[data-theme="dark"] h3.h5,
  html[data-theme="dark"] .navbar-brand .brand-text{
    background: linear-gradient(90deg, var(--law-gold-soft), var(--law-gold));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  html[data-theme="dark"] .navbar-brand .brand-text{
    filter: drop-shadow(0 10px 26px rgba(244, 221, 158, .12));
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .form-step.active{ animation: none; opacity: 1; transform: none; }
}

/* ── Service Cards (Layanan Hukum) ──────────────────────── */
.service-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(212,178,95,.15);
  border-radius: 1rem;
  padding: 2rem 1.5rem 1.5rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 36px rgba(212,178,95,.15);
  border-color: var(--law-gold);
}
.service-card-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--law-gold), var(--law-gold-soft));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
  flex-shrink: 0;
}
.service-card-icon i {
  font-size: 1.5rem;
  color: var(--law-ink);
}
.service-card-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--law-gold);
  margin-bottom: .75rem;
}
.service-card-desc {
  font-size: .9rem;
  color: var(--law-text-dim);
  line-height: 1.65;
  flex-grow: 1;
  margin-bottom: 1.25rem;
}
.service-card-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--law-gold);
  text-decoration: none;
  padding: .5rem 1rem;
  border-radius: 2rem;
  background: rgba(212,178,95,.1);
  transition: background .2s ease, color .2s ease;
  width: fit-content;
}
.service-card-link:hover {
  background: var(--law-gold);
  color: var(--law-ink);
}
.service-card-link i {
  font-size: .9rem;
  transition: transform .2s ease;
}
.service-card-link:hover i {
  transform: translateX(4px);
}

/* Light mode overrides for service cards */
[data-bs-theme="light"] .service-card {
  background: #fff;
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
[data-bs-theme="light"] .service-card:hover {
  border-color: var(--law-gold);
  box-shadow: 0 12px 36px rgba(212,178,95,.12);
}
[data-bs-theme="light"] .service-card-title {
  color: #1a2332;
}
[data-bs-theme="light"] .service-card-desc {
  color: #5a6a7e;
}
[data-bs-theme="light"] .service-card-link {
  color: #1a2332;
  background: rgba(212,178,95,.12);
}
[data-bs-theme="light"] .service-card-link:hover {
  background: var(--law-gold);
  color: #fff;
}

/* ── Founder Cards ──────────────────────────────────────── */
.founder-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(212,178,95,.15);
  border-radius: 1rem;
  padding: 2rem 1.5rem;
  transition: transform .25s ease, box-shadow .25s ease;
}
.founder-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(212,178,95,.12);
}
.founder-photo-wrapper {
  width: 180px;
  height: 180px;
  margin: 0 auto 1.25rem;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--law-gold);
  box-shadow: 0 4px 20px rgba(212,178,95,.2);
}
.founder-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.founder-name {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--law-gold);
  margin-bottom: .35rem;
}
.founder-role {
  display: inline-block;
  font-size: .85rem;
  font-weight: 600;
  color: var(--law-text-dim);
  background: rgba(212,178,95,.1);
  padding: .3rem .9rem;
  border-radius: 2rem;
}
[data-bs-theme="light"] .founder-card {
  background: #fff;
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
[data-bs-theme="light"] .founder-name {
  color: #1a2332;
}
[data-bs-theme="light"] .founder-role {
  color: #5a6a7e;
}

.founder-photo-portrait {
  width: 220px;
  height: 260px;
  border-radius: 1.25rem;
}

.kurator-copy-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(212,178,95,.14);
  border-radius: 1rem;
  padding: 1.5rem;
  display: grid;
  gap: 1rem;
}

.kurator-copy-item {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 1rem;
  align-items: start;
}

.kurator-copy-item i {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(212,178,95,.12);
  color: var(--law-gold);
  font-size: 1.1rem;
}

.kurator-copy-item h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.05rem;
  margin-bottom: .35rem;
  color: var(--law-gold);
}

.kurator-copy-item p {
  margin-bottom: 0;
  color: var(--law-text-dim);
  line-height: 1.7;
}

[data-bs-theme="light"] .kurator-copy-card {
  background: #fff;
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

[data-bs-theme="light"] .kurator-copy-item h3 {
  color: #1a2332;
}

[data-bs-theme="light"] .kurator-copy-item p {
  color: #5a6a7e;
}

@media (max-width: 575.98px) {
  .founder-photo-portrait {
    width: 180px;
    height: 220px;
  }
}
