/* =========================================================
   RUANG LEGAL — Premium Legal Services
   Color: #0F172A (navy)  #FFFFFF (white)  #C9A227 (gold)
   ========================================================= */

:root{
  --navy:#0F172A;
  --navy-2:#111C32;
  --navy-3:#1B2640;
  --navy-soft: #263354;
  --white:#FFFFFF;
  --gold:#C9A227;
  --gold-soft:#E2C24A;
  --ink:#0B1220;
  --muted:#5B6478;
  --line:#E6E8EE;
  --bg:#F7F7F5;
  --bg-2:#F1F2EE;
  --radius:18px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05);
  --shadow-md:0 10px 30px rgba(15,23,42,.08);
  --shadow-lg:0 30px 60px rgba(15,23,42,.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Manrope','Inter',system-ui,sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* Typography */
.font-display{font-family:'Fraunces','Playfair Display',Georgia,serif;letter-spacing:-0.02em;font-weight:500}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--gold)}
.eyebrow.center::before{display:none}
h1,h2,h3,h4{font-family:'Fraunces','Playfair Display',Georgia,serif;font-weight:500;letter-spacing:-0.02em;color:var(--navy);line-height:1.08}
h1{font-size:clamp(2.5rem,5.4vw,4.6rem);margin:.4rem 0 1rem}
h2{font-size:clamp(2rem,3.6vw,3.2rem);margin:.4rem 0 1rem}
h3{font-size:clamp(1.4rem,2vw,1.75rem);margin:.4rem 0 .75rem}
h4{font-size:1.1rem;margin:.25rem 0 .5rem;font-family:'Manrope',sans-serif;font-weight:600;letter-spacing:-.01em}
p{color:#3B4356;font-size:1rem}
.lead{font-size:1.125rem;color:#445064;line-height:1.7;max-width:62ch}

/* Layout */
.container{width:100%;max-width:1240px;margin:0 auto;padding:0 28px}
section{padding:120px 0;position:relative}
@media (max-width:768px){section{padding:80px 0}}
.section-head{max-width:780px;margin-bottom:64px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:14px 26px;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn i{transition:transform .25s ease}
.btn:hover i{transform:translateX(3px)}
.btn-primary{background:var(--navy);color:var(--white)}
.btn-primary:hover{background:#000;box-shadow:0 12px 30px rgba(15,23,42,.25)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-soft);box-shadow:0 12px 30px rgba(201,162,39,.35)}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid #D7DAE3}
.btn-ghost:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-light{background:rgba(255,255,255,.08);color:var(--white);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px)}
.btn-light:hover{background:rgba(255,255,255,.16)}
.btn-lg{padding:18px 32px;font-size:.98rem}

/* Navbar */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:18px 0;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
  background:rgba(255,255,255,0);
  backdrop-filter:blur(0);
}
.nav.scrolled{
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(20px);
  border-bottom-color:var(--line);
  padding:12px 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:1.35rem;color:var(--navy);letter-spacing:-0.01em}
.logo .dot{width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(201,162,39,.18)}
.logo .accent{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--navy);font-size:.92rem;font-weight:500;position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .3s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;align-items:center;justify-content:center;color:var(--navy)}
.burger i{font-size:1.05rem}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;background:var(--navy);color:var(--white);z-index:80;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.7,0,.2,1);
  padding:30px 28px;display:flex;flex-direction:column;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu .top{display:flex;justify-content:space-between;align-items:center}
.mobile-menu .logo{color:var(--white)}
.mobile-menu .close{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--white);display:flex;align-items:center;justify-content:center}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px;margin-top:60px}
.mobile-menu nav a{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:500;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);color:var(--white)}
.mobile-menu .foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:40px}

@media (max-width:980px){
  .nav-links,.nav-cta .btn{display:none}
  .burger{display:inline-flex}
}

/* =================== HERO =================== */
.hero{
  position:relative;
  padding:170px 0 100px;
  background:linear-gradient(180deg,#FAFAF7 0%, #F1EFE7 100%);
  overflow:hidden;
}
.hero .container{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero h1{margin-top:24px}
.hero h1 .ital{font-style:italic;color:var(--gold);font-weight:500}
.hero .lead{margin:18px 0 32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:46px}
.hero-meta{display:flex;gap:28px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}
.hero-meta div{display:flex;align-items:center;gap:8px}
.hero-meta i{color:var(--gold)}
.hero-visual{
  position:relative;border-radius:24px;overflow:hidden;
  aspect-ratio:4/5;
  background:#111;
  box-shadow:0 40px 80px rgba(15,23,42,.18);
}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,0) 40%,rgba(15,23,42,.6) 100%)}
.hero-badge{
  position:absolute;left:24px;bottom:24px;z-index:2;color:var(--white);
  display:flex;flex-direction:column;gap:6px
}
.hero-badge .num{font-family:'Fraunces',serif;font-size:2.2rem;line-height:1;color:var(--gold)}
.hero-bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(15,23,42,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.04) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 80% 60% at 30% 20%, #000 30%, transparent 80%);
}
@media (max-width:980px){
  .hero{padding-top:140px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{aspect-ratio:5/4;order:-1}
}

/* Hero (page) — interior pages */
.page-hero{
  position:relative;padding:170px 0 90px;
  background:var(--muted);color:var(--white);overflow:hidden
}
.page-hero h1{color:var(--white);max-width:18ch}
.page-hero p{color:rgba(255,255,255,.78);max-width:62ch;font-size:1.1rem}
.page-hero .crumbs{display:flex;gap:8px;align-items:center;color:rgba(255,255,255,.55);font-size:.85rem;margin-bottom:18px}
.page-hero .crumbs i{font-size:.6rem}
.page-hero .ornament{position:absolute;right:-100px;top:-100px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(201,162,39,.18), transparent 60%);filter:blur(20px)}

/* =================== TRUST BAR =================== */
.trust{padding:64px 0;border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust-item{
  display:flex;align-items:flex-start;gap:16px;padding:24px;
  border:1px solid var(--line);border-radius:18px;background:#fff;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.trust-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#D6DAE5}
.trust-icon{width:44px;height:44px;border-radius:12px;background:#FAF6E9;display:grid;place-items:center;color:var(--gold);flex-shrink:0}
.trust-item h4{margin:0 0 4px}
.trust-item p{margin:0;font-size:.88rem;color:var(--muted)}
@media (max-width:900px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.trust-grid{grid-template-columns:1fr}}

/* =================== CATEGORY GRID =================== */
.section-bg-alt{background:var(--bg)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cat-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;
  padding:36px;display:flex;flex-direction:column;gap:18px;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s;
  overflow:hidden;min-height:280px
}
.cat-card::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--gold);transition:width .4s ease;
}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#D6DAE5}
.cat-card:hover::after{width:100%}
.cat-num{font-family:'Fraunces',serif;color:var(--gold);font-size:.95rem;letter-spacing:.06em}
.cat-card h3{margin:0}
.cat-card p{color:var(--muted);font-size:.94rem;margin:0}
.cat-card .arrow{position:absolute;right:28px;bottom:28px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--navy);transition:background .25s ease, color .25s ease, transform .25s ease}
.cat-card:hover .arrow{background:var(--navy);color:var(--white);transform:rotate(-45deg)}
@media (max-width:980px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cat-grid{grid-template-columns:1fr}}

/* =================== WHY US (split) =================== */
.why{background:var(--navy);color:var(--white);position:relative;overflow:hidden}
.why h2{color:var(--white)}
.why p{color:rgba(255,255,255,.7)}
.why .eyebrow{color:rgba(255,255,255,.6)}
.why .eyebrow::before{background:var(--gold)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:50px}
.why-card{
  padding:36px;border:1px solid rgba(255,255,255,.1);border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  transition:border-color .3s ease, transform .3s ease;
  position:relative;overflow:hidden
}
.why-card:hover{border-color:rgba(201,162,39,.5);transform:translateY(-4px)}
.why-card .icn{width:48px;height:48px;border-radius:12px;background:rgba(201,162,39,.15);color:var(--gold);display:grid;place-items:center;margin-bottom:18px;font-size:1.2rem}
.why-card h3{color:var(--white);margin:0 0 8px;font-size:1.35rem}
.why-card p{margin:0;color:rgba(255,255,255,.7);font-size:.95rem}
.why-orn{position:absolute;left:-200px;bottom:-200px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle, rgba(201,162,39,.16), transparent 60%);filter:blur(20px)}
@media (max-width:780px){.why-grid{grid-template-columns:1fr}}

/* =================== PROCESS TIMELINE =================== */
.process-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:50px;position:relative}
.process-timeline::before{
  content:"";position:absolute;left:0;right:0;top:38px;height:1px;background:var(--line);
}
.proc{position:relative;text-align:left}
.proc .dot{
  width:76px;height:76px;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;font-family:'Fraunces',serif;font-size:1.4rem;color:var(--navy);
  position:relative;z-index:2;margin-bottom:24px;
  transition:background .3s ease, color .3s ease, border-color .3s ease, transform .3s ease
}
.proc:hover .dot{background:var(--navy);color:var(--gold);border-color:var(--navy);transform:translateY(-2px)}
.proc h4{margin:0 0 6px;font-size:1.1rem}
.proc p{margin:0;color:var(--muted);font-size:.88rem}
@media (max-width:900px){
  .process-timeline{grid-template-columns:repeat(2,1fr)}
  .process-timeline::before{display:none}
}
@media (max-width:520px){.process-timeline{grid-template-columns:1fr}}

/* =================== PRODUCTS GRID =================== */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.product-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#D6DAE5}
.product-card .img{aspect-ratio:5/3;background:#eee;overflow:hidden;position:relative}
.product-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.product-card:hover .img img{transform:scale(1.06)}
.product-card .body{padding:28px;display:flex;flex-direction:column;gap:10px;flex:1}
.product-card .tag{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
.product-card h3{margin:0;font-size:1.4rem}
.product-card p{margin:0;font-size:.92rem;color:var(--muted)}
.product-card .foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line)}
.product-card .foot .arrow{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:background .25s ease, color .25s ease}
.product-card:hover .foot .arrow{background:var(--navy);color:var(--white)}
@media (max-width:980px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.product-grid{grid-template-columns:1fr}}

/* =================== ARTICLES =================== */
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.article-card{
  display:flex;flex-direction:column;gap:18px;
  background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;padding:0;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease
}
.article-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.article-card .img{aspect-ratio:16/10;overflow:hidden}
.article-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.article-card:hover .img img{transform:scale(1.05)}
.article-card .body{padding:24px 28px 30px;display:flex;flex-direction:column;gap:10px}
.article-meta{display:flex;gap:14px;font-size:.78rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.article-meta .cat{color:var(--gold);font-weight:600}
.article-card h3{margin:0;font-size:1.3rem;line-height:1.25}
.article-card h3:hover{color:var(--gold);transition:color .25s}
.article-card p{margin:0;font-size:.92rem;color:var(--muted)}
@media (max-width:980px){.article-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.article-grid{grid-template-columns:1fr}}

/* =================== FINAL CTA =================== */
.final-cta{
  position:relative;
  background:var(--navy);color:var(--white);overflow:hidden;border-radius:32px;
  padding:90px 64px;text-align:center;
}
.final-cta h2{color:var(--white)}
.final-cta p{color:rgba(255,255,255,.75);max-width:60ch;margin-left:auto;margin-right:auto}
.final-cta .btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.final-cta .orn{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle, rgba(201,162,39,.18), transparent 60%);filter:blur(40px)}
.final-cta .orn.a{top:-200px;left:-150px}
.final-cta .orn.b{bottom:-200px;right:-150px}
@media (max-width:780px){.final-cta{padding:60px 28px}}

/* =================== FOOTER =================== */
footer{background:var(--ink);color:#A8B0C2;padding:90px 0 30px;margin-top:120px}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
footer h5{color:#fff;font-family:'Manrope',sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 18px}
footer a{display:block;padding:6px 0;color:#A8B0C2;font-size:.92rem}
footer a:hover{color:var(--gold)}
footer .brand .logo{color:#fff;margin-bottom:18px}
footer .brand p{color:#A8B0C2;font-size:.92rem;max-width:36ch}
footer .socials{display:flex;gap:10px;margin-top:18px}
footer .socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;padding:0}
footer .bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:#6F7790;font-size:.84rem}
@media (max-width:900px){footer .grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:520px){footer .grid{grid-template-columns:1fr}}

/* =================== ABOUT PAGE =================== */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.who-img{aspect-ratio:4/5;border-radius:22px;overflow:hidden}
.who-img img{width:100%;height:100%;object-fit:cover}
@media (max-width:900px){.who-grid{grid-template-columns:1fr;gap:40px}}

.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vm{padding:48px;border-radius:22px;background:#fff;border:1px solid var(--line)}
.vm.dark{background:var(--navy);color:var(--white);border:none}
.vm.dark h3,.vm.dark p,.vm.dark li{color:var(--white)}
.vm.dark li::before{background:var(--gold)}
.vm h3 .ital{color:var(--gold);font-style:italic}
.vm ul{list-style:none;padding:0;margin:18px 0 0}
.vm li{position:relative;padding:10px 0 10px 26px;color:#445064;font-size:.96rem;border-bottom:1px dashed rgba(0,0,0,.06)}
.vm li:last-child{border-bottom:none}
.vm li::before{content:"";position:absolute;left:0;top:18px;width:12px;height:1px;background:var(--gold)}
@media (max-width:780px){.vm-grid{grid-template-columns:1fr}.vm{padding:36px}}

.principles{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.principle{padding:32px;border:1px solid var(--line);border-radius:18px;background:#fff;text-align:left}
.principle .num{font-family:'Fraunces',serif;color:var(--gold);font-size:.95rem;margin-bottom:24px;display:block}
.principle h4{margin:0 0 6px}
.principle p{margin:0;font-size:.9rem;color:var(--muted)}
@media (max-width:900px){.principles{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.principles{grid-template-columns:1fr}}

/* =================== LAYANAN PAGE =================== */
.cat-section{padding:90px 0;border-bottom:1px solid var(--line)}
.cat-section:last-of-type{border-bottom:none}
.cat-head{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start;margin-bottom:50px}
.cat-head .label{font-family:'Fraunces',serif;color:var(--gold);font-size:1rem;letter-spacing:.04em;margin-bottom:8px}
.cat-head h2{margin:0}
.cat-head p{margin:0;color:var(--muted)}
.cat-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cat-item{
  padding:30px;border:1px solid var(--line);border-radius:18px;background:#fff;
  display:flex;flex-direction:column;gap:8px;
  transition:transform .3s, border-color .3s, box-shadow .3s
}
.cat-item:hover{transform:translateY(-4px);border-color:#D6DAE5;box-shadow:var(--shadow-md)}
.cat-item h4{margin:0;font-size:1.1rem}
.cat-item p{margin:0;font-size:.88rem;color:var(--muted)}
.cat-item .arrow{margin-top:14px;display:inline-flex;align-items:center;gap:8px;color:var(--navy);font-size:.85rem;font-weight:600}
.cat-item:hover .arrow{color:var(--gold)}
@media (max-width:900px){.cat-head{grid-template-columns:1fr;gap:20px}.cat-list{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cat-list{grid-template-columns:1fr}}

/* =================== PRODUCT DETAIL PAGE =================== */
.pd-overview{display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:start}
.pd-overview .lead{font-size:1.05rem}
.pd-side{background:var(--bg);border-radius:22px;padding:36px;border:1px solid var(--line)}
.pd-side h4{margin:0 0 14px}
.pd-side ul{list-style:none;padding:0;margin:0}
.pd-side li{padding:10px 0;border-bottom:1px dashed rgba(0,0,0,.08);display:flex;align-items:center;gap:10px;font-size:.92rem;color:#445064}
.pd-side li:last-child{border-bottom:none}
.pd-side li i{color:var(--gold)}
@media (max-width:900px){.pd-overview{grid-template-columns:1fr;gap:40px}}

.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.pkg{
  background:#fff;border:1px solid var(--line);border-radius:22px;padding:40px;
  display:flex;flex-direction:column;gap:14px;position:relative;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease
}
.pkg:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.pkg.featured{background:var(--navy);color:var(--white);border:none}
.pkg.featured h3,.pkg.featured .price{color:var(--white)}
.pkg.featured li{color:rgba(255,255,255,.85)}
.pkg.featured li i{color:var(--gold)}
.pkg.featured .ribbon{background:var(--gold);color:var(--navy)}
.pkg .ribbon{
  position:absolute;top:18px;right:18px;background:#FAF6E9;color:var(--navy);
  font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:999px
}
.pkg .name{color:var(--gold);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700}
.pkg .price{font-family:'Fraunces',serif;font-size:1.8rem;color:var(--navy);margin:4px 0 8px}
.pkg p.tag{margin:0;color:inherit;opacity:.75;font-size:.9rem}
.pkg ul{list-style:none;padding:0;margin:18px 0;display:flex;flex-direction:column;gap:10px}
.pkg li{display:flex;gap:10px;align-items:flex-start;color:#3B4356;font-size:.92rem}
.pkg li i{color:var(--gold);margin-top:3px}
.pkg .btn{margin-top:auto;justify-content:center}
@media (max-width:980px){.pkg-grid{grid-template-columns:1fr}}

.docs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:30px}
.docs-grid .row{display:flex;align-items:center;gap:14px;padding:18px 22px;border:1px solid var(--line);border-radius:14px;background:#fff;color:#3B4356;font-size:.94rem}
.docs-grid .row i{color:var(--gold);font-size:1rem}
@media (max-width:780px){.docs-grid{grid-template-columns:1fr}}

.timeline-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--navy);color:#fff;border-radius:18px;padding:28px 36px;margin-top:30px;flex-wrap:wrap;gap:18px
}
.timeline-bar .item{display:flex;align-items:center;gap:14px}
.timeline-bar .item i{color:var(--gold);font-size:1.2rem}
.timeline-bar h4{margin:0;color:#fff;font-size:1rem;font-family:'Manrope',sans-serif}
.timeline-bar small{color:rgba(255,255,255,.6)}

.faq{display:flex;flex-direction:column;gap:12px;max-width:880px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:14px;background:#fff;padding:22px 28px;transition:border-color .25s, background .25s}
.faq details[open]{background:#fff;border-color:#D6DAE5}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-weight:600;color:var(--navy);font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"\f067";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--gold);transition:transform .25s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:16px 0 0;color:#445064}

/* =================== BLOG PAGE =================== */
.blog-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:40px}
.search-box{flex:1;display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:999px;padding:10px 22px;max-width:420px;background:#fff}
.search-box input{border:none;outline:none;width:100%;font-size:.94rem;font-family:inherit;color:var(--ink)}
.search-box i{color:var(--muted)}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:.85rem;color:var(--ink);cursor:pointer;transition:all .25s ease}
.chip:hover{border-color:var(--navy)}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}

.featured-article{
  display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;margin-bottom:60px
}
.featured-article .img{aspect-ratio:5/4;overflow:hidden}
.featured-article .img img{width:100%;height:100%;object-fit:cover}
.featured-article .body{padding:50px}
.featured-article h2{margin:14px 0 18px;font-size:clamp(1.6rem,2.4vw,2.4rem)}
.featured-article p{color:var(--muted);font-size:1rem}
@media (max-width:900px){.featured-article{grid-template-columns:1fr}.featured-article .body{padding:36px}}

/* =================== ARTICLE DETAIL =================== */
.article-hero{position:relative;height:60vh;min-height:480px;overflow:hidden;color:#fff}
.article-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.article-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.3) 0%, rgba(15,23,42,.9) 100%)}
.article-hero .container{position:absolute;left:0;right:0;bottom:60px;z-index:2}
.article-hero h1{color:#fff;max-width:22ch}
.article-hero .article-meta{color:rgba(255,255,255,.75);margin-top:18px;display:flex;gap:24px;flex-wrap:wrap}
.article-hero .article-meta .cat{color:var(--gold)}

.article-layout{display:grid;grid-template-columns:.32fr 1fr;gap:80px;align-items:start}
.toc{position:sticky;top:120px;padding:28px;background:var(--bg);border-radius:18px;border:1px solid var(--line)}
.toc h5{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.toc ol{padding-left:18px;margin:0;color:#3B4356;font-size:.92rem;line-height:2}
.toc a{color:#3B4356}
.toc a:hover{color:var(--gold)}
.article-body p{font-size:1.05rem;line-height:1.85;margin:0 0 22px;color:#2F3849}
.article-body h2{font-size:1.9rem;margin-top:50px}
.article-body h3{font-size:1.4rem;margin-top:32px}
.article-body blockquote{border-left:3px solid var(--gold);padding:14px 24px;margin:30px 0;font-family:'Fraunces',serif;font-size:1.2rem;color:var(--navy);font-style:italic;background:var(--bg);border-radius:0 12px 12px 0}
.article-body ul{padding-left:22px;line-height:2;color:#2F3849}
.share{display:flex;align-items:center;gap:12px;margin:40px 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.share span{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.share a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--navy);transition:all .25s}
.share a:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
@media (max-width:900px){.article-layout{grid-template-columns:1fr;gap:40px}.toc{position:static}}

/* =================== KONTAK =================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px}
.info-card{background:var(--navy);color:#fff;border-radius:24px;padding:50px 44px;display:flex;flex-direction:column;gap:30px;position:relative;overflow:hidden}
.info-card h3{color:#fff}
.info-row{display:flex;align-items:flex-start;gap:18px}
.info-row .icn{width:44px;height:44px;border-radius:12px;background:rgba(201,162,39,.15);color:var(--gold);display:grid;place-items:center;flex-shrink:0}
.info-row h5{margin:0;color:#fff;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}
.info-row p{margin:4px 0 0;color:rgba(255,255,255,.85);font-size:1rem}
.info-card .orn{position:absolute;right:-100px;bottom:-100px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.18),transparent 60%);filter:blur(30px)}

.form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:50px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field.full{grid-column:1/-1}
.field label{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.field input,.field select,.field textarea{
  border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;outline:none;
  transition:border-color .2s, box-shadow .2s
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy);box-shadow:0 0 0 4px rgba(15,23,42,.06)}
.field textarea{resize:vertical;min-height:140px}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}.form-card{padding:36px}.form-grid{grid-template-columns:1fr}}

.map-wrap{margin-top:60px;border-radius:24px;overflow:hidden;border:1px solid var(--line);height:480px}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.4) contrast(.95)}

/* =================== UTILITIES & ANIMATIONS =================== */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s ease}
.fade-up.in{opacity:1;transform:translateY(0)}
[data-stagger]>*{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease;transition-delay:calc(var(--i,0) * 80ms)}
[data-stagger].in>*{opacity:1;transform:translateY(0)}

.split-line{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}

/* Toast */
.toast{
  position:fixed;bottom:30px;left:50%;transform:translate(-50%,30px);
  background:var(--navy);color:#fff;padding:14px 24px;border-radius:999px;font-size:.92rem;
  display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;
  transition:opacity .25s, transform .25s;z-index:200
}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast i{color:var(--gold)}

/* Logo wordmark for footer/mobile */
.brand-tag{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:6px;display:block}
