/*
 * File Name    : portal-ref-pemkab.css
 * Description  : Portal shell & beranda — acuan visual PEMKAB (strip gradien, navbar gelap, grid layanan, footer).
 * Author       : Erwin Youfilandy
 * Date         : 02/05/2026
 * Version      : 1.1.4
 *
 * Revision History :
 * Date        Comments
 * ------------------------------------------------------------------
 * 05/05/2026  Tabel Data Penduduk: font diperkecil 25% + padding sel lebih rapat
 * 05/05/2026  Palet kartu beranda diselaraskan ke nuansa tema CMS (navy-teal-amber) dengan kontras teks lebih nyaman
 * 05/05/2026  Kartu beranda metrik: label + angka besar dinamis pada tiap kartu layanan utama
 * 05/05/2026  Sidebar grup menu: judul subgrup (TIPE_NAV_GROUP bertingkat)
 * 05/05/2026  Layout profil dua kolom: main lebar col-9 + sidebar
 * 05/05/2026  Sidebar biodata: awalan >> / >>> / ---> berwarna; baris lebih rapat
 * 05/05/2026  Menu biodata pejabat: teks saja + judul samping tanpa ikon; status nonaktif
 * 03/05/2026  Tipografi isi (non-beranda): inherit dari .portal-ref-sheet, sel tabel Bootstrap, kelas .portal-data-penduduk-wilayah = metrik .portal-ref-brand-line
 * 03/05/2026  Topbar: judul dinas dua baris, ukuran font seragam & lebih kecil
 * 03/05/2026  Menu jenis layanan: satu baris judul (tanpa eyebrow kode)
 * 03/05/2026  Jenis layanan: daftar vertikal + garis; judul aktif biru / tidak aktif hitam (tebal)
 * 03/05/2026  Blok jenis layanan: tema terang selaras kolom «Ada pertanyaan»
 * 03/05/2026  Sidebar jenis layanan: grid kartu + palet footer
 * 03/05/2026  Kolom samping halaman layanan (nav + hubungi)
 * 02/05/2026  Gaya gambar lambang di marka merek portal (.portal-ref-brand-mark__img)
 * 02/05/2026  Initial release (Disdukcapil Kab. Fakfak; bukan salinan aset pihak ketiga)
 * 02/05/2026  Overrides grid/kartu vs Bootstrap reboot; monogram berita
 */

:root {
    /* Sama dengan judul topbar «Dinas Kependudukan…» (.portal-ref-brand-line); dipakai untuk isi halaman non-beranda */
    --portal-brand-line-font-size: clamp(0.68rem, 1.55vw, 0.82rem);
    --ref-radius-sheet: 1.35rem;
    --ref-radius-card: 1.15rem;
    --ref-radius-pill: 3rem;
    --ref-topbar-1: #0092d5;
    --ref-topbar-2: #0092d5;
    --ref-topbar-3: #0092d5;
    --ref-nav-bg: #0092d5;
    --ref-nav-active: #0092d5;
    --ref-footer: #0092d5;
    --ref-svc-1: #61538f;
    --ref-svc-2: #b44074;
    --ref-svc-3: #f58648;
    --ref-svc-4: #6dbe4f;
    --ref-svc-5: #0092d5;
}

/* --- Latar ilustratif ringan (tanpa berkas gambar) --- */
body.portal-ref-pemkab.portal-body-siak {
    background: #dfe8f0;
    font-family: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

body.portal-ref-pemkab.portal-body-siak::before {
    opacity: 0.55;
    background-image:
        radial-gradient(ellipse 55% 40% at 0% 20%, rgba(21, 38, 66, 0.14) 0%, transparent 55%),
        radial-gradient(ellipse 50% 45% at 100% 15%, rgba(26, 122, 78, 0.12) 0%, transparent 50%),
        repeating-linear-gradient(
            118deg,
            rgba(255, 255, 255, 0.06) 0 3px,
            transparent 3px 22px
        ),
        linear-gradient(165deg, rgba(249, 168, 37, 0.06) 0%, transparent 35%);
}

/* --- Top bar + navbar --- */
.portal-ref-topbar {
    background: #0092d5 !important;
    color: #fff;
    padding: 0.55rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.portal-ref-topbar__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.portal-ref-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.15);
    color: #fef3c7;
    font-size: 1.35rem;
    overflow: hidden;
}

.portal-ref-brand-mark__img {
    width: 2.1rem;
    height: 2.1rem;
    object-fit: contain;
    display: block;
}

.portal-ref-brand-text {
    line-height: 1.15;
}

.portal-ref-brand-text--stack {
    display: flex;
    flex-direction: column;
    gap: 0.08rem;
    line-height: 1.22;
    max-width: min(100%, 26rem);
}

.portal-ref-brand-line {
    font-family: inherit;
    font-weight: 700;
    font-size: var(--portal-brand-line-font-size) !important;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #fff;
}

.portal-ref-navbar {
    background: #006d9c !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
}

.portal-ref-navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.35);
}

.portal-ref-navbar .nav-link {
    color: rgba(255, 255, 255, 0.88) !important;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.55rem 0.45rem !important;
    border-bottom: 0;
    border-radius: 0;
    position: relative;
    z-index: 1;
}

/* Samakan karakter tombol dropdown (menu bersubmenu) dengan nav-link biasa */
.portal-ref-navbar .dropdown-toggle.nav-link {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    appearance: none;
    -webkit-appearance: none;
}

.portal-ref-navbar .nav-link:hover,
.portal-ref-navbar .nav-link:focus {
    color: #fff !important;
}

.portal-ref-navbar .nav-link.active,
.portal-ref-navbar .dropdown-toggle.nav-link.active {
    color: #fff !important;
    background: #0092D5 !important;
}

.portal-ref-navbar .nav-link.active::before,
.portal-ref-navbar .dropdown-toggle.nav-link.active::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 6px;
    background: linear-gradient(to bottom, #FFFFFF 0, #FFFFFF 3px, #F58648 3px, #F58648 6px);
    pointer-events: none;
}

.portal-ref-navbar .dropdown-menu {
    font-size: 0.85rem;
    text-transform: none;
    letter-spacing: normal;
    font-weight: 500;
}

.portal-ref-search .form-control {
    border-radius: var(--ref-radius-pill);
    border: 0;
    min-width: 8rem;
    max-width: 14rem;
    font-size: 0.8rem;
}

.portal-ref-search .btn {
    border-radius: var(--ref-radius-pill);
}

.portal-ref-header .btn.btn-primary {
    background-color: #0092d5;
    border-color: #0092d5;
    color: #fff;
}

.portal-ref-header .btn.btn-primary:hover,
.portal-ref-header .btn.btn-primary:focus-visible {
    background-color: #007eb7;
    border-color: #0073a8;
    color: #fff;
}

/* --- Konten dalam lembar putih --- */
.portal-ref-stage {
    position: relative;
    z-index: var(--siak-z-content, 2);
    padding-bottom: 2rem;
}

.portal-ref-sheet {
    background: #fff;
    border-radius: var(--ref-radius-sheet);
    box-shadow: 0 8px 32px rgba(15, 39, 68, 0.1);
    padding: 1.1rem 1rem 1.35rem;
    margin-top: 0.5rem;
}

@media (min-width: 768px) {
    .portal-ref-sheet {
        padding: 1.35rem 1.5rem 1.65rem;
    }
}

/* --- Tombol mengambang --- */
.portal-ref-float {
    position: fixed;
    right: 0.55rem;
    bottom: 5rem;
    z-index: 1040;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    max-width: 8.5rem;
}

@media (min-width: 1200px) {
    .portal-ref-float {
        right: 1.25rem;
        bottom: 6rem;
    }
}

.portal-ref-float__btn {
    display: block;
    text-align: center;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff !important;
    padding: 0.45rem 0.5rem;
    border-radius: 0.65rem;
    background: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.portal-ref-float__btn:hover {
    transform: translateX(-2px);
    color: #fef9c3 !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
}

/* --- Footer --- */
.portal-ref-footer {
    position: relative;
    z-index: var(--siak-z-content, 2);
    background: #0092d5 !important;
    color: rgba(255, 255, 255, 0.82);
    padding: 1.75rem 0 1.5rem;
    margin-top: auto;
    font-size: 0.82rem;
}

.portal-ref-footer h2,
.portal-ref-footer .portal-ref-footer__h {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #e6f6fd;
    margin-bottom: 0.65rem;
}

.portal-ref-footer a {
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
}

.portal-ref-footer a:hover {
    text-decoration: underline;
    color: #fff;
}

.portal-ref-footer__muted {
    color: rgba(255, 255, 255, 0.65);
    font-size: 0.78rem;
}

/* ========== Beranda ========== */
.portal-ref-home-intro {
    text-align: center;
    padding: 0.35rem 0 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    margin-bottom: 1rem;
}

.portal-ref-home-intro h1 {
    font-weight: 800;
    font-size: clamp(1.05rem, 2.8vw, 1.35rem);
    color: #0f172a;
    letter-spacing: 0.02em;
}

.portal-ref-home-intro p {
    color: #475569;
    font-size: 0.88rem;
    max-width: 40rem;
    margin: 0.35rem auto 0;
    line-height: 1.55;
}

.portal-ref-section-title {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 0.65rem;
}

.portal-ref-svc-grid {
    display: grid !important;
    gap: 0.65rem;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100%;
}

@media (min-width: 768px) {
    .portal-ref-svc-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (min-width: 1200px) {
    .portal-ref-svc-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 0.75rem;
    }
}

.portal-ref-svc-card,
a.portal-ref-svc-card {
    position: relative;
    display: flex !important;
    flex-direction: column !important;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    border-radius: var(--ref-radius-card);
    padding: 0.85rem 0.75rem 0.95rem;
    min-height: 11.5rem;
    color: #0f172a;
    text-decoration: none !important;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.portal-ref-svc-card:hover,
a.portal-ref-svc-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
    text-decoration: none !important;
}

.portal-ref-svc-card--1:hover,
.portal-ref-svc-card--3:hover,
.portal-ref-svc-card--4:hover {
    color: #0f172a !important;
}

.portal-ref-svc-card__icon {
    font-size: 1.6rem;
    margin-bottom: 0.4rem;
    opacity: 0.95;
}

.portal-ref-svc-card__title {
    font-weight: 800;
    font-size: 0.72rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    line-height: 1.25;
    margin-bottom: 0.35rem;
}

.portal-ref-svc-card__metric-value {
    margin-top: auto;
    font-size: clamp(1.75rem, 2.8vw, 2.2rem);
    line-height: 1.02;
    font-weight: 900;
    letter-spacing: 0.005em;
    margin-top: 0.15rem;
}

.portal-ref-svc-card__btn {
    align-self: center;
    margin-top: 0.65rem;
    padding: 0.32rem 0.85rem;
    border-radius: var(--ref-radius-pill);
    background: #fff;
    color: #0f172a !important;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
}

.portal-ref-svc-card__btn:hover {
    background: #f8fafc;
    color: #0f172a !important;
}

.portal-ref-svc-card--1 {
    background: #61538f;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.portal-ref-svc-card--2 {
    background: #b44074;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.portal-ref-svc-card--2 .portal-ref-svc-card__metric-value {
    color: #fff;
}

.portal-ref-svc-card--2 .portal-ref-svc-card__btn {
    color: #b44074 !important;
}

.portal-ref-svc-card--2:hover,
.portal-ref-svc-card--5:hover {
    color: #fff !important;
}

.portal-ref-svc-card--3 {
    background: #f58648;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.portal-ref-svc-card--4 {
    background: #6dbe4f;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.portal-ref-svc-card--5 {
    background: #0092d5;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.portal-ref-svc-card--5 .portal-ref-svc-card__metric-value {
    color: #fff;
}

.portal-ref-svc-card--5 .portal-ref-svc-card__btn {
    color: #0092d5 !important;
}

.portal-ref-svc-card--1 .portal-ref-svc-card__metric-value,
.portal-ref-svc-card--2 .portal-ref-svc-card__metric-value,
.portal-ref-svc-card--3 .portal-ref-svc-card__metric-value,
.portal-ref-svc-card--4 .portal-ref-svc-card__metric-value,
.portal-ref-svc-card--5 .portal-ref-svc-card__metric-value,
.portal-ref-svc-card--1 .portal-ref-svc-card__title,
.portal-ref-svc-card--2 .portal-ref-svc-card__title,
.portal-ref-svc-card--3 .portal-ref-svc-card__title,
.portal-ref-svc-card--4 .portal-ref-svc-card__title,
.portal-ref-svc-card--5 .portal-ref-svc-card__title,
.portal-ref-svc-card--1 .portal-ref-svc-card__icon,
.portal-ref-svc-card--2 .portal-ref-svc-card__icon,
.portal-ref-svc-card--3 .portal-ref-svc-card__icon,
.portal-ref-svc-card--4 .portal-ref-svc-card__icon,
.portal-ref-svc-card--5 .portal-ref-svc-card__icon {
    color: #fff !important;
}

.portal-ref-svc-card--1 .portal-ref-svc-card__btn { color: #61538f !important; }
.portal-ref-svc-card--3 .portal-ref-svc-card__btn { color: #f58648 !important; }
.portal-ref-svc-card--4 .portal-ref-svc-card__btn { color: #6dbe4f !important; }

/* Blok bawah: berita lebar + agenda + info */
.portal-ref-lower {
    display: grid;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

@media (min-width: 992px) {
    .portal-ref-lower {
        grid-template-columns: 2fr 1fr 1fr;
        align-items: stretch;
    }
}

.portal-ref-panel {
    border-radius: var(--ref-radius-card);
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.portal-ref-panel__head {
    padding: 0.55rem 0.85rem;
    font-weight: 800;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
}

.portal-ref-panel--news .portal-ref-panel__head {
    background: linear-gradient(90deg, var(--siak-brand-5) 0%, var(--siak-brand-3) 100%);
}

.portal-ref-panel--agenda .portal-ref-panel__head {
    background: linear-gradient(90deg, var(--siak-brand-4) 0%, var(--siak-brand-5) 100%);
}

.portal-ref-panel--info .portal-ref-panel__head {
    background: linear-gradient(90deg, var(--siak-brand-2) 0%, var(--siak-brand-1) 100%);
}

.portal-ref-panel__body {
    padding: 0.65rem 0.85rem 0.85rem;
    flex: 1 1 auto;
}

.portal-ref-news-grid {
    display: grid;
    gap: 0.55rem;
}

@media (min-width: 576px) {
    .portal-ref-news-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.portal-ref-news-item {
    display: flex;
    gap: 0.5rem;
    text-decoration: none !important;
    color: inherit;
    padding: 0.35rem;
    border-radius: 0.5rem;
    transition: background 0.15s ease;
}

.portal-ref-news-item:hover {
    background: rgba(0, 146, 213, 0.08);
    color: inherit;
    text-decoration: none !important;
}

.portal-ref-news-thumb {
    flex: 0 0 3.25rem;
    height: 3.25rem;
    border-radius: 0.45rem;
    background: linear-gradient(135deg, var(--siak-brand-5), var(--siak-brand-1));
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.1rem;
    overflow: hidden;
}

.portal-ref-news-thumb__letter {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 1.2rem;
    font-weight: 800;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
}

.portal-ref-news-meta {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #64748b;
}

.portal-ref-news-title {
    font-weight: 700;
    font-size: 0.8rem;
    color: #0f172a;
    line-height: 1.35;
    margin-top: 0.1rem;
}

.portal-ref-agenda-list,
.portal-ref-info-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.portal-ref-agenda-list li,
.portal-ref-info-list li {
    padding: 0.45rem 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 0.8rem;
}

.portal-ref-agenda-list li:last-child,
.portal-ref-info-list li:last-child {
    border-bottom: 0;
}

.portal-ref-agenda-date {
    font-size: 0.65rem;
    font-weight: 800;
    color: var(--siak-brand-4);
    letter-spacing: 0.04em;
}

.portal-ref-info-list i {
    margin-right: 0.35rem;
    color: var(--siak-brand-2);
}

/* --- Halaman layanan: tiga kolom (nav | isi | kontak) --- */
.portal-layanan-layout__main {
    min-width: 0;
}

.portal-layanan-side {
    border-radius: var(--ref-radius-card);
    padding: 0.9rem 1rem;
    box-shadow: 0 2px 12px rgba(15, 39, 68, 0.06);
}

.portal-layanan-side--nav,
.portal-layanan-side--hubungi {
    background: linear-gradient(160deg, rgba(21, 38, 66, 0.05) 0%, #f8f9fa 38%, #fff 100%);
    border: 1px solid rgba(15, 39, 68, 0.08);
    border-left: 4px solid var(--ref-svc-5);
    box-shadow: 0 2px 12px rgba(15, 39, 68, 0.06);
}

.portal-layanan-side__head {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #0f2744;
    margin-bottom: 0.35rem;
}

.portal-layanan-side__head-icon {
    font-size: 1rem;
    color: var(--ref-svc-1);
}

.portal-layanan-side__head-icon--accent {
    color: var(--ref-svc-5);
}

.portal-layanan-side__head--solo {
    margin-bottom: 0.5rem;
}

.portal-layanan-side__lede {
    line-height: 1.35;
}

/* Daftar vertikal jenis layanan (ikon + dua baris teks, garis pemisah) */
.portal-layanan-menu-list {
    margin: 0;
    padding: 0;
    list-style: none;
    border-top: 1px solid #eeeeee;
}

.portal-layanan-menu-item {
    border-bottom: 1px solid #eeeeee;
}

.portal-layanan-menu-link {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.25rem;
    text-decoration: none !important;
    color: inherit;
    border-radius: 0.4rem;
    transition: background 0.15s ease;
}

.portal-layanan-menu-link:hover {
    background: rgba(15, 23, 42, 0.04);
}

.portal-layanan-menu-item__icon {
    flex-shrink: 0;
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    background: #f0f0f0;
    color: #475569;
    font-size: 1.05rem;
}

.portal-layanan-menu-item__body {
    display: block;
    min-width: 0;
    flex: 1 1 auto;
    text-align: left;
}

.portal-layanan-menu-item__title {
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.22;
    color: #000000;
    overflow-wrap: break-word;
    word-break: break-word;
}

.portal-layanan-menu-link--active .portal-layanan-menu-item__title {
    color: #1a73e8;
}

.portal-layanan-menu-link:focus-visible {
    outline: 2px solid rgba(26, 115, 232, 0.45);
    outline-offset: 2px;
}

/* Daftar teks saja (mis. biodata pejabat) — tanpa ikon per baris */
.portal-layanan-menu-link--text-only {
    gap: 0;
}

.portal-layanan-menu-link--inactive {
    cursor: default;
    opacity: 0.55;
    pointer-events: none;
}

.portal-layanan-menu-link--inactive .portal-layanan-menu-item__title {
    color: #64748b;
}

/* Sidebar biodata pejabat: hierarki tanda >> / >>> / ---> + jarak vertikal rapat */
.portal-pejabat-sidebar .portal-layanan-side__head--solo {
    margin-bottom: 0.35rem;
}

.portal-pejabat-sidebar__lede {
    line-height: 1.28;
    margin-bottom: 0.35rem !important;
    font-size: 0.72rem;
}

.portal-pejabat-sidebar__menu {
    border-top-color: #ebebeb;
}

.portal-pejabat-sidebar__item {
    border-bottom-color: #ebebeb;
}

.portal-pejabat-sidebar__link.portal-layanan-menu-link {
    padding: 0.22rem 0.15rem;
    gap: 0.15rem;
    align-items: flex-start;
}

.portal-pejabat-sidebar__link .portal-layanan-menu-item__title {
    font-size: 0.74rem;
    line-height: 1.18;
    font-weight: 700;
}

.portal-pejabat-nav__prefix {
    flex-shrink: 0;
    min-width: 2.95rem;
    text-align: right;
    font-family: ui-monospace, "Cascadia Mono", "Consolas", monospace;
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: -0.05em;
    line-height: 1.2;
    padding-top: 0.14rem;
    padding-right: 0.12rem;
    white-space: nowrap;
}

.portal-pejabat-nav__prefix--root {
    min-width: 0;
    width: 0;
    padding: 0;
    overflow: hidden;
}

/* Biru tua (sekretaris, bidang) */
.portal-pejabat-nav__prefix--navy {
    color: #0b2f5f;
}

/* Biru muda (sub bagian, seksi, KJF, UPTD) */
.portal-pejabat-nav__prefix--sky {
    color: #2f6fbf;
}

.portal-layanan-menu-link--active .portal-pejabat-nav__prefix--navy,
.portal-layanan-menu-link--active .portal-pejabat-nav__prefix--sky {
    color: #1a73e8;
}

.portal-layanan-menu-link--inactive .portal-pejabat-nav__prefix {
    color: #94a3b8 !important;
}

/* Profil & biodata: dua kolom (submenu / daftar posisi | konten selebar kolom 6+3 lama) */
.portal-profil-layout__main {
    min-width: 0;
}

.portal-profil-sidebar__lede {
    line-height: 1.28;
    margin-bottom: 0.35rem !important;
    font-size: 0.72rem;
}

.portal-profil-sidebar__menu {
    border-top-color: #ebebeb;
}

.portal-profil-sidebar__item {
    border-bottom-color: #ebebeb;
}

.portal-profil-sidebar__link.portal-layanan-menu-link {
    padding: 0.32rem 0.2rem;
}

.portal-profil-sidebar__link .portal-layanan-menu-item__title {
    font-size: 0.78rem;
    line-height: 1.22;
}

.portal-profil-sidebar__item--subgroup {
    list-style: none;
}

.portal-profil-sidebar__subgroup-title {
    letter-spacing: 0.05em;
    font-size: 0.65rem;
}

.portal-layanan-kontak-list {
    margin: 0;
    padding: 0;
}

.portal-layanan-kontak-item {
    display: flex;
    gap: 0.55rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(15, 39, 68, 0.08);
}

.portal-layanan-kontak-item:last-child {
    border-bottom: 0;
}

.portal-layanan-kontak-item__icon {
    flex-shrink: 0;
    width: 1.85rem;
    height: 1.85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.45rem;
    background: rgba(21, 38, 66, 0.08);
    color: var(--ref-nav-bg);
    font-size: 0.95rem;
}

.portal-layanan-form-wrap {
    margin-top: 0.25rem;
    padding-top: 0.65rem;
    border-top: 1px dashed rgba(15, 39, 68, 0.12);
}

.portal-layanan-form-kontak .form-control {
    border-radius: 0.5rem;
    border-color: rgba(15, 39, 68, 0.14);
}

.portal-layanan-form-kontak .form-control:focus {
    border-color: rgba(21, 98, 192, 0.45);
    box-shadow: 0 0 0 0.2rem rgba(21, 98, 192, 0.12);
}

/*
 * Tipografi isi halaman (bukan beranda): ukuran teks = judul topbar dinas (.portal-ref-brand-line).
 * Kelas body portal-page--typography-match-brand di-set dari layout portal (selain route portal.beranda).
 * Akar ukuran di .portal-ref-sheet; turunan memakai inherit agar tidak kalah dari utilitas Bootstrap (fs-*, dsb.).
 */
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet {
    font-size: var(--portal-brand-line-font-size) !important;
    line-height: 1.45;
}

body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet *:not(canvas):not(svg):not(script):not(style):not(noscript):not(template) {
    font-size: inherit !important;
    line-height: 1.45;
}

/* Sel data tabel Bootstrap (spesifisitas tinggi) agar selalu mengikuti akar lembar, bukan aturan .table terpisah */
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .table > :not(caption) > * > * {
    font-size: inherit !important;
}

/* Nama distrik/desa: sama metrik tipografi dengan baris judul dinas di topbar (bukan hanya angka rem) */
html body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .portal-data-penduduk-wilayah {
    font-family: inherit;
    font-size: var(--portal-brand-line-font-size) !important;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.22;
}

body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h1,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h2,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h3,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h4,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h5,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet h6,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h1,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h2,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h3,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h4,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h5,
body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .h6 {
    font-weight: 700;
    line-height: 1.3;
}

body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .table th {
    font-weight: 700;
}

body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .portal-data-penduduk-table {
    font-size: 75% !important;
}

body.portal-ref-pemkab.portal-body-siak.portal-page--typography-match-brand #portal-main-content .portal-ref-sheet .portal-data-penduduk-table > :not(caption) > * > * {
    padding: 0.22rem 0.35rem;
}
