:root {
--c-white:      #FFFFFF;
--c-bg:         #F9F7F7;
--c-bg-alt:     #DBE2EF;
--c-primary:    #3F72AF;
--c-primary-dk: #2d5a92;
--c-dark:       #112D4E;
--c-text:       #112D4E;
--c-muted:      #6B7B8D;
--c-border:     #E2E8F0;
--c-gold:       #F9A825;
--radius-sm:  6px;
--radius:     12px;
--radius-lg:  20px;
--shadow-sm:  0 1px 3px rgba(17,45,78,.06), 0 1px 2px rgba(17,45,78,.04);
--shadow:     0 4px 16px rgba(17,45,78,.08);
--shadow-md:  0 8px 32px rgba(17,45,78,.12);
--ease:       cubic-bezier(.4,0,.2,1);
--duration:   .25s;
} body {
background: var(--c-bg);
color: var(--c-text);
-webkit-font-smoothing: antialiased;
}
a { color: var(--c-primary); }
img { max-width: 100%; height: auto; } .upatik-brand {
display: flex !important;
align-items: center;
gap: 12px;
text-decoration: none !important;
} .upatik-brand .custom-logo-link {
display: flex;
align-items: center;
flex-shrink: 0;
}
.upatik-brand .custom-logo {
height: 44px !important;
width: auto !important;
object-fit: contain;
}
.upatik-brand-text {
display: flex;
flex-direction: column;
line-height: 1.2;
}
.upatik-brand-short {
font-size: 1rem;
font-weight: 800;
color: var(--c-dark);
letter-spacing: -.3px;
}
.upatik-brand-long {
font-size: 0.65rem;
color: var(--c-muted);
font-weight: 500;
letter-spacing: .2px;
max-width: 200px;
line-height: 1.3;
} .topbar-search {
display: flex;
align-items: center;
gap: 0;
}
.topbar-search input[type="search"] {
background: rgba(255,255,255,.1);
border: 1px solid rgba(255,255,255,.2);
color: #fff;
font-size: .78rem;
padding: 0 10px;
height: 24px;
line-height: 24px;
border-radius: 4px;
outline: none;
width: 160px;
transition: background .2s, width .2s;
}
.topbar-search input[type="search"]::placeholder { color: rgba(255,255,255,.5); }
.topbar-search input[type="search"]:focus {
background: rgba(255,255,255,.18);
width: 200px;
} .upatik-hero {
background: var(--c-dark);
min-height: 640px;
display: flex;
align-items: center;
padding: 120px 0;
position: relative;
overflow: hidden;
} .upatik-hero::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);
background-size: 32px 32px;
pointer-events: none;
} .upatik-hero::after {
content: '';
position: absolute;
right: -80px; top: -80px;
width: 480px; height: 480px;
border-radius: 50%;
background: radial-gradient(circle, rgba(63,114,175,.35) 0%, transparent 70%);
pointer-events: none;
}
.upatik-hero .container { position: relative; z-index: 1; }
.hero-label {
display: inline-flex;
align-items: center;
gap: 8px;
background: rgba(63,114,175,.15);
border: 1px solid rgba(63,114,175,.3);
color: #90b8e0;
font-size: 11px;
font-weight: 700;
letter-spacing: 1.5px;
text-transform: uppercase;
padding: 6px 14px;
border-radius: 100px;
margin-bottom: 24px;
}
.hero-label::before { content: '●'; color: #64b5f6; font-size: 8px; }
.upatik-hero h1 {
font-size: clamp(2rem, 4vw, 3rem);
font-weight: 700;
color: var(--c-white);
line-height: 1.15;
letter-spacing: -.5px;
margin-bottom: 20px;
}
.upatik-hero h1 em {
font-style: normal;
color: var(--c-gold);
}
.upatik-hero p.lead {
color: rgba(255,255,255,.65);
font-size: 1rem;
line-height: 1.75;
max-width: 500px;
margin-bottom: 36px;
}
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.btn-primary {
display: inline-flex;
align-items: center;
gap: 8px;
background: var(--c-primary);
color: var(--c-white) !important;
font-weight: 600;
font-size: .9rem;
padding: 13px 28px;
border-radius: 100px;
text-decoration: none !important;
transition: background var(--duration) var(--ease),
transform var(--duration) var(--ease),
box-shadow var(--duration) var(--ease);
}
.btn-primary:hover {
background: var(--c-primary-dk);
transform: translateY(-2px);
box-shadow: 0 8px 24px rgba(63,114,175,.35);
}
.btn-ghost {
display: inline-flex;
align-items: center;
gap: 8px;
background: transparent;
color: rgba(255,255,255,.8) !important;
font-weight: 600;
font-size: .9rem;
padding: 12px 28px;
border-radius: 100px;
border: 1px solid rgba(255,255,255,.2);
text-decoration: none !important;
transition: background var(--duration) var(--ease),
border-color var(--duration) var(--ease);
}
.btn-ghost:hover {
background: rgba(255,255,255,.08);
border-color: rgba(255,255,255,.35);
}
.hero-stats {
display: flex;
gap: 40px;
margin-top: 52px;
padding-top: 32px;
border-top: 1px solid rgba(255,255,255,.08);
flex-wrap: wrap;
}
.hero-stat strong {
display: block;
font-size: 1.6rem;
font-weight: 800;
color: var(--c-white);
letter-spacing: -.5px;
}
.hero-stat span {
font-size: .75rem;
color: rgba(255,255,255,.45);
text-transform: uppercase;
letter-spacing: 1px;
} .hero-visual { position: relative; }
.float-card {
position: absolute;
background: rgba(255,255,255,.07);
backdrop-filter: blur(12px);
border: 1px solid rgba(255,255,255,.12);
border-radius: var(--radius);
padding: 12px 16px;
display: flex;
align-items: center;
gap: 10px;
animation: floatY 4s var(--ease) infinite;
}
.float-card-icon { font-size: 1.4rem; }
.float-card-title { font-size: .78rem; font-weight: 700; color: #fff; }
.float-card-sub   { font-size: .68rem; color: rgba(255,255,255,.5); }
.float-card:nth-child(2) { animation-delay: 2s; }
@keyframes floatY {
0%,100% { transform: translateY(0); }
50%      { transform: translateY(-10px); }
}
.hero-circle {
width: 260px; height: 260px;
border-radius: 50%;
background: rgba(63,114,175,.12);
border: 1px solid rgba(63,114,175,.2);
display: flex; align-items: center; justify-content: center;
margin: 0 auto;
}
.hero-circle-inner {
width: 180px; height: 180px;
border-radius: 50%;
background: rgba(63,114,175,.15);
border: 1px solid rgba(63,114,175,.25);
display: flex; align-items: center; justify-content: center;
font-size: 4rem;
} .upatik-section { padding: 72px 0; background: var(--c-bg); }
.upatik-section.alt  { background: var(--c-bg-alt); }
.upatik-section.dark { background: var(--c-dark); }
.upatik-section.white { background: var(--c-white); }
.sec-header { margin-bottom: 48px; }
.sec-header.center { text-align: center; }
.sec-label {
display: inline-block;
background: rgba(63,114,175,.1);
color: var(--c-primary);
font-size: 11px;
font-weight: 700;
letter-spacing: 1.5px;
text-transform: uppercase;
padding: 5px 14px;
border-radius: 100px;
margin-bottom: 12px;
}
.sec-header h2 {
font-size: clamp(1.5rem, 3vw, 2rem);
font-weight: 700;
color: var(--c-dark);
letter-spacing: -.4px;
margin-bottom: 10px;
line-height: 1.25;
}
.sec-header p {
color: var(--c-muted);
font-size: .95rem;
line-height: 1.75;
max-width: 540px;
}
.sec-header.center p { margin: 0 auto; } .layanan-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
}
@media (max-width: 900px) { .layanan-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .layanan-grid { grid-template-columns: 1fr; } }
.layanan-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px 24px;
text-decoration: none !important;
display: flex;
flex-direction: column;
gap: 12px;
transition: border-color var(--duration) var(--ease),
box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.layanan-card:hover {
border-color: var(--c-primary);
box-shadow: var(--shadow-md);
transform: translateY(-4px);
}
.layanan-icon {
width: 48px; height: 48px;
background: rgba(63,114,175,.1);
border-radius: var(--radius-sm);
display: flex; align-items: center; justify-content: center;
font-size: 1.4rem;
transition: background var(--duration) var(--ease);
}
.layanan-card:hover .layanan-icon { background: var(--c-primary); }
.layanan-card h3 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin: 0;
line-height: 1.3;
}
.layanan-card p {
font-size: .83rem;
color: var(--c-muted);
line-height: 1.65;
margin: 0;
flex: 1;
}
.card-link {
font-size: .8rem;
font-weight: 600;
color: var(--c-primary);
display: inline-flex;
align-items: center;
gap: 4px;
transition: gap var(--duration) var(--ease);
}
.layanan-card:hover .card-link { gap: 8px; }  .hero-visual--img {
display: flex;
align-items: center;
justify-content: center;
position: relative;
} .hero-visual--img::before {
content: '';
position: absolute;
inset: 10%;
background: radial-gradient(ellipse at center, rgba(68,96,132,.45) 0%, transparent 70%);
border-radius: 50%;
filter: blur(32px);
z-index: 0;
}
.hero-dc-img {
position: relative;
z-index: 1;
width: 100%;
max-width: 100%;
height: auto;
object-fit: contain;
filter:
brightness(0.88)
sepia(0.25)
hue-rotate(300deg)
saturate(1.1)
drop-shadow(0 16px 36px rgba(17,45,78,.4));
animation: hero-float 4s ease-in-out infinite;
}
@keyframes hero-float {
0%, 100% { transform: translateY(0); }
50%       { transform: translateY(-10px); }
}
.ppid-banner.ppid-banner--blue {
background: var(--c-primary);
}
.ppid-banner {
background: var(--c-dark);
border-radius: var(--radius-lg);
padding: 52px 48px;
display: flex;
align-items: center;
justify-content: space-between;
gap: 32px;
flex-wrap: wrap;
}
.ppid-banner h2 {
font-size: 1.6rem;
font-weight: 700;
color: var(--c-white);
letter-spacing: -.3px;
margin-bottom: 8px;
}
.ppid-banner p {
color: rgba(255,255,255,.6);
font-size: .9rem;
line-height: 1.7;
max-width: 500px;
margin: 0;
}
.btn-ppid {
display: inline-flex;
align-items: center;
gap: 8px;
background: var(--c-primary);
color: var(--c-white) !important;
font-weight: 600;
font-size: .9rem;
padding: 13px 28px;
border-radius: 100px;
text-decoration: none !important;
white-space: nowrap;
transition: background var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.btn-ppid:hover { background: var(--c-primary-dk); transform: translateY(-2px); }
.btn-ppid.btn-ppid--gold { background: var(--c-gold); color: var(--c-dark) !important; }
.btn-ppid.btn-ppid--gold:hover { background: #e09600; } .berita-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 20px;
}
@media (max-width: 1024px) { .berita-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px)  { .berita-grid { grid-template-columns: 1fr; } }
.berita-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
overflow: hidden;
position: relative;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.berita-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-4px);
}
.berita-card-link {
position: absolute;
inset: 0;
z-index: 1;
}
.berita-body { position: relative; z-index: 2; pointer-events: none; }
.berita-thumb {
height: 168px;
background: var(--c-bg-alt);
display: flex;
align-items: center;
justify-content: center;
font-size: 2.5rem;
overflow: hidden;
}
.berita-thumb img { width:100%; height:100%; object-fit:cover; }
.berita-body { padding: 18px; }
.berita-meta {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 8px;
}
.berita-cat {
background: rgba(63,114,175,.1);
color: var(--c-primary);
font-size: 10px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
padding: 3px 9px;
border-radius: 100px;
}
.berita-date { font-size: .75rem; color: var(--c-muted); }
.berita-card h3 {
font-size: .9rem;
font-weight: 700;
color: var(--c-dark);
line-height: 1.4;
margin-bottom: 8px;
}
.berita-card p {
font-size: .82rem;
color: var(--c-muted);
line-height: 1.65;
margin: 0;
}
.btn-outline {
display: inline-flex;
align-items: center;
gap: 8px;
border: 1.5px solid var(--c-primary);
color: var(--c-primary) !important;
font-weight: 600;
font-size: .88rem;
padding: 11px 28px;
border-radius: 100px;
text-decoration: none !important;
transition: background var(--duration) var(--ease),
color var(--duration) var(--ease);
}
.btn-outline:hover {
background: var(--c-primary);
color: var(--c-white) !important;
} .faq-list { max-width: 720px; margin: 0 auto; }
.faq-item {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
margin-bottom: 8px;
overflow: hidden;
transition: border-color var(--duration) var(--ease);
}
.faq-item[open] { border-color: var(--c-primary); }
.faq-question {
padding: 18px 22px;
font-size: .93rem;
font-weight: 600;
color: var(--c-dark);
cursor: pointer;
display: flex;
justify-content: space-between;
align-items: center;
gap: 16px;
list-style: none;
user-select: none;
transition: color var(--duration) var(--ease);
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question:hover { color: var(--c-primary); }
.faq-chevron {
width: 22px; height: 22px;
border-radius: 50%;
background: rgba(63,114,175,.1);
display: flex; align-items: center; justify-content: center;
font-size: .7rem;
color: var(--c-primary);
flex-shrink: 0;
transition: transform var(--duration) var(--ease),
background var(--duration) var(--ease);
}
details[open] .faq-chevron {
transform: rotate(180deg);
background: var(--c-primary);
color: #fff;
}
.faq-answer {
padding: 0 22px 18px;
font-size: .87rem;
color: var(--c-muted);
line-height: 1.75;
border-top: 1px solid var(--c-border);
padding-top: 14px;
}
.faq-answer a { color: var(--c-primary); font-weight: 600; }
.faq-answer ol {
padding: 0;
margin: 10px 0 0;
list-style: none;
counter-reset: faq-counter;
display: flex;
flex-direction: column;
gap: 8px;
}
.faq-answer ol li {
counter-increment: faq-counter;
display: grid;
grid-template-columns: 22px 1fr;
gap: 10px;
align-items: start;
line-height: 1.6;
overflow-wrap: break-word;
word-break: break-word;
}
.faq-answer ol li::before {
content: counter(faq-counter);
flex-shrink: 0;
width: 22px;
height: 22px;
background: var(--c-primary);
color: #fff;
font-size: .72rem;
font-weight: 700;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin-top: 1px;
} .kontak-strip {
background: var(--c-primary);
padding: 44px 0;
}
.kontak-strip-inner {
display: flex;
align-items: center;
justify-content: space-between;
gap: 24px;
flex-wrap: wrap;
}
.kontak-strip h3 {
color: var(--c-white);
font-size: 1.2rem;
font-weight: 700;
margin: 0 0 4px;
letter-spacing: -.2px;
}
.kontak-strip p { color: rgba(255,255,255,.7); margin: 0; font-size: .88rem; }
.btn-kontak {
display: inline-flex;
align-items: center;
gap: 8px;
background: var(--c-white);
color: var(--c-primary) !important;
font-weight: 700;
font-size: .88rem;
padding: 12px 26px;
border-radius: 100px;
text-decoration: none !important;
white-space: nowrap;
transition: background var(--duration) var(--ease),
color var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.btn-kontak:hover {
background: var(--c-dark);
color: var(--c-white) !important;
transform: translateY(-2px);
} .text-center { text-align: center; }
.mt-40 { margin-top: 40px; } .page-hero {
background: var(--c-dark);
padding: 56px 0 48px;
position: relative;
overflow: hidden;
}
.page-hero::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
background-size: 32px 32px;
pointer-events: none;
}
.page-hero .sec-label {
display: inline-block;
margin-bottom: 12px;
background: rgba(255,255,255,.1);
border: 1px solid rgba(255,255,255,.2);
color: rgba(255,255,255,.85);
}
.page-hero h1 {
font-size: clamp(1.8rem, 3.5vw, 2.6rem);
font-weight: 700;
color: #fff;
letter-spacing: -.3px;
margin-bottom: 12px;
}
.page-hero p {
color: rgba(255,255,255,.6);
font-size: .95rem;
max-width: 520px;
line-height: 1.7;
margin: 0;
} .page-hero--short {
padding: 40px 0 36px;
}
.single-hero-meta {
display: flex;
gap: 8px;
align-items: center;
font-size: .85rem;
color: rgba(255,255,255,.55) !important;
margin-top: 10px !important;
}
.single-wrap {
display: grid;
grid-template-columns: 1fr 300px;
gap: 48px;
align-items: start;
}
.single-featured-img {
margin-bottom: 28px;
}
.single-body {
font-size: .95rem;
line-height: 1.8;
color: var(--c-text);
}
.single-body h2, .single-body h3 {
font-weight: 700;
color: var(--c-dark);
margin-top: 28px;
margin-bottom: 10px;
}
.single-body h2 { font-size: 1.3rem; }
.single-body h3 { font-size: 1.1rem; }
.single-body p { margin-bottom: 16px; }
.single-body ul, .single-body ol {
padding-left: 1.4rem;
margin-bottom: 16px;
}
.single-body li { margin-bottom: 6px; }
.single-body strong { font-weight: 600; }
.single-body a { color: var(--c-primary); }
.single-body hr {
border: none;
border-top: 1px solid var(--c-border);
margin: 28px 0;
}
.single-footer {
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
gap: 12px;
padding-top: 24px;
margin-top: 32px;
border-top: 1px solid var(--c-border);
}
.single-tags {
font-size: .85rem;
color: var(--c-muted);
}
.single-tags a {
color: var(--c-primary);
}
.single-back {
font-size: .85rem;
font-weight: 600;
color: var(--c-primary);
text-decoration: none;
}
.single-back:hover { text-decoration: underline; }
.single-sidebar-card {
background: #fff;
border: 1px solid var(--c-border);
border-radius: 12px;
padding: 20px 20px 22px;
margin-bottom: 20px;
}
.single-sidebar-card h4 {
font-size: .88rem;
font-weight: 700;
color: var(--c-dark);
margin: 0 0 14px;
padding-bottom: 10px;
border-bottom: 1px solid var(--c-border);
text-transform: uppercase;
letter-spacing: .05em;
}
.single-recent-list {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 2px;
}
.single-recent-list li a {
display: flex;
flex-direction: column;
padding: 8px 10px;
border-radius: 6px;
text-decoration: none;
transition: background .15s;
color: var(--c-dark);
font-size: .86rem;
line-height: 1.4;
}
.single-recent-list li a:hover {
background: var(--c-bg);
color: var(--c-primary);
}
.single-recent-date {
font-size: .72rem;
color: var(--c-muted);
margin-bottom: 3px;
}
@media (max-width: 768px) {
.single-wrap { grid-template-columns: 1fr; }
.single-sidebar { order: 1; }
} .tentang-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 56px;
align-items: start;
}
.tentang-konten p {
color: var(--c-muted);
line-height: 1.8;
margin-bottom: 16px;
font-size: .95rem;
}
.tentang-konten .sec-header { margin-bottom: 24px; } .tentang-timeline {
display: flex;
flex-direction: column;
gap: 0;
position: relative;
padding-left: 16px;
}
.tentang-timeline::before {
content: '';
position: absolute;
left: 0;
top: 8px;
bottom: 8px;
width: 2px;
background: var(--c-border);
}
.timeline-item {
display: flex;
gap: 20px;
padding-bottom: 28px;
position: relative;
}
.timeline-item::before {
content: '';
position: absolute;
left: -20px;
top: 6px;
width: 10px;
height: 10px;
border-radius: 50%;
background: var(--c-primary);
border: 2px solid var(--c-bg);
box-shadow: 0 0 0 2px var(--c-primary);
}
.timeline-year {
font-size: .78rem;
font-weight: 700;
color: var(--c-primary);
text-transform: uppercase;
letter-spacing: .06em;
min-width: 44px;
padding-top: 2px;
}
.timeline-title {
font-weight: 700;
color: var(--c-dark);
font-size: .92rem;
margin-bottom: 4px;
}
.timeline-desc {
font-size: .83rem;
color: var(--c-muted);
line-height: 1.65;
} .fungsi-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
}
.fungsi-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px 24px;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.fungsi-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.fungsi-icon {
font-size: 1.8rem;
margin-bottom: 12px;
}
.fungsi-card h3 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 8px;
}
.fungsi-card p {
font-size: .83rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
} .tentang-komitmen {
display: flex;
align-items: center;
gap: 48px;
flex-wrap: wrap;
}
.komitmen-quote {
flex: 1;
min-width: 280px;
display: flex;
gap: 20px;
align-items: flex-start;
}
.komitmen-icon {
font-size: 2rem;
flex-shrink: 0;
}
.komitmen-quote blockquote {
font-size: .95rem;
color: var(--c-muted);
line-height: 1.8;
border-left: 3px solid var(--c-primary);
padding-left: 20px;
margin: 0;
font-style: italic;
}
.komitmen-actions {
display: flex;
gap: 12px;
flex-wrap: wrap;
flex-shrink: 0;
}
@media (max-width: 768px) {
.tentang-grid   { grid-template-columns: 1fr; gap: 32px; }
.fungsi-grid    { grid-template-columns: 1fr 1fr; }
.tentang-komitmen { flex-direction: column; gap: 24px; }
.komitmen-actions { width: 100%; }
}
@media (max-width: 480px) {
.fungsi-grid { grid-template-columns: 1fr; }
} .visi-wrap {
display: flex;
gap: 48px;
align-items: flex-start;
max-width: 860px;
margin: 0 auto;
}
.visi-label { flex-shrink: 0; padding-top: 4px; }
.visi-content {
flex: 1;
position: relative;
}
.visi-quote-icon {
font-size: 5rem;
color: var(--c-primary);
opacity: .12;
line-height: 1;
position: absolute;
top: -16px;
left: -8px;
font-family: Georgia, serif;
}
.visi-quote {
font-size: 1.25rem;
font-weight: 500;
color: var(--c-dark);
line-height: 1.75;
border-left: 4px solid var(--c-primary);
padding: 16px 0 16px 28px;
margin: 0;
font-style: italic;
position: relative;
z-index: 1;
} .misi-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 24px;
max-width: 860px;
margin: 0 auto;
}
.misi-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px;
display: flex;
gap: 20px;
align-items: flex-start;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.misi-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.misi-number {
font-size: 2rem;
font-weight: 800;
color: var(--c-primary);
opacity: .2;
line-height: 1;
flex-shrink: 0;
min-width: 44px;
}
.misi-body h3 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 6px;
}
.misi-body p {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
} .nilai-grid {
display: flex;
justify-content: center;
gap: 24px;
flex-wrap: wrap;
max-width: 900px;
margin: 0 auto;
}
.nilai-item {
background: var(--c-bg);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 24px 20px;
text-align: center;
width: 152px;
flex-shrink: 0;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.nilai-item:hover {
box-shadow: var(--shadow);
transform: translateY(-3px);
}
.nilai-icon { font-size: 1.8rem; margin-bottom: 8px; }
.nilai-name {
font-weight: 700;
font-size: .9rem;
color: var(--c-dark);
margin-bottom: 6px;
}
.nilai-desc {
font-size: .76rem;
color: var(--c-muted);
line-height: 1.6;
}
@media (max-width: 768px) {
.visi-wrap  { flex-direction: column; gap: 16px; }
.misi-grid  { grid-template-columns: 1fr; }
.nilai-item { width: calc(50% - 12px); }
}  .orgchart {
display: flex;
flex-direction: column;
align-items: center;
padding: 16px 0 8px;
}
.orgchart-level {
display: flex;
justify-content: center;
gap: 24px;
}
.orgchart-node {
border-radius: var(--radius);
padding: 20px 24px;
text-align: center;
position: relative;
}
.orgchart-node--head {
background: var(--c-dark);
color: #fff;
min-width: 280px;
box-shadow: var(--shadow-md);
}
.orgchart-node--head .orgnode-title { color: #fff; }
.orgchart-node--head .orgnode-sub   { color: rgba(255,255,255,.6); }
.orgchart-node--mid {
background: var(--c-primary);
color: #fff;
min-width: 220px;
box-shadow: var(--shadow);
}
.orgchart-node--mid .orgnode-title { color: #fff; }
.orgchart-node--mid .orgnode-sub   { color: rgba(255,255,255,.7); }
.orgchart-node--div {
background: var(--c-white);
border: 1px solid var(--c-border);
border-top: 3px solid var(--c-primary);
flex: 1;
box-shadow: var(--shadow-sm);
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.orgchart-node--div:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
} .orgnode-icon {
display: flex;
justify-content: center;
margin-bottom: 10px;
width: 28px;
height: 28px;
margin-left: auto;
margin-right: auto;
}
.orgnode-icon svg {
width: 28px !important;
height: 28px !important;
max-width: 28px;
stroke: var(--c-primary);
flex-shrink: 0;
}
.orgchart-node--head .orgnode-icon svg,
.orgchart-node--mid  .orgnode-icon svg { stroke: rgba(255,255,255,.85); }
.orgnode-badge {
display: inline-block;
background: var(--c-bg-alt);
color: var(--c-primary);
font-size: .68rem;
font-weight: 700;
letter-spacing: .08em;
text-transform: uppercase;
padding: 3px 10px;
border-radius: 100px;
margin-bottom: 10px;
}
.orgnode-title {
font-weight: 700;
font-size: .95rem;
color: var(--c-dark);
margin-bottom: 6px;
}
.orgnode-sub {
font-size: .78rem;
color: var(--c-muted);
line-height: 1.6;
} .orgchart-connector--down {
width: 2px;
height: 32px;
background: var(--c-border);
} .orgchart-branch {
display: flex !important;
flex-direction: row !important;
flex-wrap: nowrap;
gap: 20px;
width: 100%;
max-width: 880px;
position: relative;
} .orgchart-branch::before,
.orgchart-branch::after,
.orgchart-branch > .orgchart-node--div::before { display: none !important; }
.orgchart-note {
text-align: center;
font-size: .78rem;
color: var(--c-muted);
margin-top: 32px;
font-style: italic;
} .tupoksi-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 24px;
}
.tupoksi-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 24px;
}
.tupoksi-head {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 16px;
padding-bottom: 14px;
border-bottom: 1px solid var(--c-border);
}
.tupoksi-icon {
display: flex;
align-items: center;
flex-shrink: 0;
}
.tupoksi-icon svg {
width: 22px !important;
height: 22px !important;
max-width: 22px;
stroke: var(--c-primary);
flex-shrink: 0;
}
.tupoksi-head h3 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin: 0;
}
.tupoksi-card ul {
padding-left: 18px;
margin: 0;
display: flex;
flex-direction: column;
gap: 8px;
}
.tupoksi-card ul li {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.6;
}
@media (max-width: 768px) {
.orgchart-branch { flex-direction: column; padding-top: 0; gap: 12px; }
.orgchart-branch::before,
.orgchart-branch::after,
.orgchart-branch > .orgchart-node--div::before { display: none; }
.tupoksi-grid { grid-template-columns: 1fr; }
} .pimpinan-wrap {
display: flex;
justify-content: center;
}
.pimpinan-card {
display: flex;
align-items: center;
gap: 36px;
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius-lg);
border-left: 4px solid var(--c-primary);
padding: 36px 44px;
max-width: 600px;
width: 100%;
box-shadow: var(--shadow);
}
.staf-foto {
width: 88px;
height: 88px;
border-radius: 50%;
overflow: hidden;
flex-shrink: 0;
background: var(--c-bg-alt);
border: 3px solid var(--c-border);
}
.staf-foto--lg {
width: 112px;
height: 112px;
}
.staf-foto img {
width: 100%;
height: 100%;
object-fit: cover;
} .staf-avatar-placeholder {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
background: var(--c-bg-alt);
}
.staf-avatar-placeholder svg {
width: 52% !important;
height: 52% !important;
max-width: 100%;
stroke: var(--c-primary);
opacity: .6;
}
.staf-jabatan-badge {
display: inline-block;
background: var(--c-bg-alt);
color: var(--c-primary);
font-size: .7rem;
font-weight: 700;
letter-spacing: .07em;
text-transform: uppercase;
padding: 4px 12px;
border-radius: 100px;
margin-bottom: 8px;
}
.staf-nama {
font-size: 1.1rem;
font-weight: 700;
color: var(--c-dark);
margin: 0 0 4px;
}
.staf-card .staf-nama { font-size: .92rem; }
.staf-nip {
font-size: .78rem;
color: var(--c-muted);
margin-bottom: 8px;
}
.staf-email {
font-size: .82rem;
color: var(--c-primary);
text-decoration: none;
font-weight: 600;
}
.staf-email:hover { text-decoration: underline; } .bidang-header {
display: flex;
align-items: center;
gap: 16px;
margin-bottom: 28px;
padding-bottom: 20px;
border-bottom: 2px solid var(--c-border);
}
.bidang-icon {
display: flex;
align-items: center;
justify-content: center;
width: 48px;
height: 48px;
background: var(--c-primary);
border-radius: var(--radius);
flex-shrink: 0;
}
.bidang-icon svg {
width: 24px;
height: 24px;
stroke: #fff;
}
.bidang-header .sec-label { margin-bottom: 2px; }
.bidang-title {
font-size: 1.2rem;
font-weight: 700;
color: var(--c-dark);
margin: 0;
}
.bidang-count {
margin-left: auto;
background: var(--c-bg-alt);
color: var(--c-primary);
font-size: .75rem;
font-weight: 700;
padding: 6px 14px;
border-radius: 100px;
white-space: nowrap;
} .staf-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 20px;
}
.staf-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 24px 16px;
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
gap: 12px;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.staf-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.staf-card .staf-foto {
width: 72px;
height: 72px;
}
.staf-info { text-align: center; }
.staf-jabatan {
font-size: .75rem;
color: var(--c-primary);
font-weight: 600;
margin-bottom: 4px;
line-height: 1.4;
}
@media (max-width: 1024px) {
.staf-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
.pimpinan-card { flex-direction: column; text-align: center; padding: 28px 24px; border-left: none; border-top: 4px solid var(--c-primary); }
.staf-grid     { grid-template-columns: repeat(2, 1fr); }
.bidang-header { flex-wrap: wrap; }
.bidang-count  { margin-left: 0; }
}
@media (max-width: 480px) {
.staf-grid { grid-template-columns: repeat(2, 1fr); }
} .renstra-intro {
display: grid;
grid-template-columns: 1fr auto;
gap: 48px;
align-items: start;
}
.renstra-intro-text p {
color: var(--c-muted);
line-height: 1.8;
font-size: .95rem;
margin-bottom: 14px;
}
.renstra-stats {
display: flex;
flex-direction: column;
gap: 16px;
flex-shrink: 0;
}
.renstra-stat {
background: var(--c-dark);
color: #fff;
border-radius: var(--radius);
padding: 20px 28px;
text-align: center;
min-width: 140px;
}
.renstra-stat-num {
font-size: 2rem;
font-weight: 800;
color: var(--c-gold);
line-height: 1;
margin-bottom: 4px;
}
.renstra-stat-label {
font-size: .75rem;
color: rgba(255,255,255,.6);
text-transform: uppercase;
letter-spacing: .06em;
} .prioritas-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 24px;
}
.prioritas-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px;
position: relative;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.prioritas-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.prioritas-num {
font-size: 3.5rem;
font-weight: 800;
color: var(--c-primary);
opacity: .08;
position: absolute;
top: 16px;
right: 20px;
line-height: 1;
}
.prioritas-icon {
font-size: 1.6rem;
margin-bottom: 10px;
}
.prioritas-card h3 {
font-size: 1rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 8px;
}
.prioritas-card > p {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.7;
margin-bottom: 14px;
}
.prioritas-card ul {
padding-left: 16px;
margin: 0;
display: flex;
flex-direction: column;
gap: 5px;
}
.prioritas-card ul li {
font-size: .82rem;
color: var(--c-muted);
line-height: 1.5;
} .roadmap {
max-width: 700px;
margin: 0 auto;
position: relative;
padding-left: 32px;
}
.roadmap::before {
content: '';
position: absolute;
left: 0;
top: 8px;
bottom: 8px;
width: 2px;
background: linear-gradient(to bottom, var(--c-primary), var(--c-bg-alt));
}
.roadmap-item {
display: flex;
gap: 24px;
padding-bottom: 32px;
position: relative;
}
.roadmap-item::before {
content: '';
position: absolute;
left: -38px;
top: 6px;
width: 12px;
height: 12px;
border-radius: 50%;
background: var(--c-primary);
border: 2px solid var(--c-bg);
box-shadow: 0 0 0 3px rgba(63,114,175,.2);
}
.roadmap-item--last::before {
background: var(--c-gold);
box-shadow: 0 0 0 3px rgba(249,168,37,.2);
}
.roadmap-year {
font-size: .88rem;
font-weight: 800;
color: var(--c-primary);
min-width: 40px;
padding-top: 2px;
}
.roadmap-item--last .roadmap-year { color: var(--c-gold); }
.roadmap-content h4 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 4px;
}
.roadmap-content p {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
}
@media (max-width: 768px) {
.renstra-intro  { grid-template-columns: 1fr; }
.renstra-stats  { flex-direction: row; flex-wrap: wrap; }
.renstra-stat   { flex: 1; min-width: 100px; }
.prioritas-grid { grid-template-columns: 1fr; }
} .layanan-overview {
display: grid;
grid-template-columns: 1fr auto;
gap: 48px;
align-items: start;
}
.layanan-overview-text p {
color: var(--c-muted);
line-height: 1.8;
font-size: .95rem;
margin-bottom: 14px;
}
.layanan-overview-stats {
display: flex;
flex-direction: column;
gap: 16px;
flex-shrink: 0;
}
.overview-stat {
background: var(--c-bg);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 18px 24px;
text-align: center;
min-width: 140px;
}
.overview-stat-icon { font-size: 1.3rem; margin-bottom: 4px; }
.overview-stat-val {
font-size: 1.6rem;
font-weight: 800;
color: var(--c-primary);
line-height: 1;
margin-bottom: 4px;
}
.overview-stat-label {
font-size: .72rem;
color: var(--c-muted);
text-transform: uppercase;
letter-spacing: .06em;
}
.layanan-detail-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
}
.layanan-detail-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 24px;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.layanan-detail-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.ldc-icon { font-size: 1.8rem; margin-bottom: 12px; line-height: 1; }
.ldc-icon svg { width: 28px !important; height: 28px !important; }
.layanan-icon svg { width: 24px !important; height: 24px !important; }
.fungsi-icon svg,
.komitmen-icon svg,
.prioritas-icon svg { width: 32px !important; height: 32px !important; }
.nilai-icon svg,
.alur-info-icon svg { width: 28px !important; height: 28px !important; }
.overview-stat-icon svg { width: 22px !important; height: 22px !important; }
.hc-icon svg { width: 36px !important; height: 36px !important; }
.layanan-detail-card h3 {
font-size: .92rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 8px;
}
.layanan-detail-card p {
font-size: .83rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
} .cakupan-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 24px;
max-width: 760px;
margin: 0 auto;
}
.cakupan-card {
background: var(--c-bg);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px;
}
.cakupan-card--primary {
background: var(--c-dark);
border-color: var(--c-dark);
}
.cakupan-card--primary h3,
.cakupan-card--primary p,
.cakupan-card--primary li { color: rgba(255,255,255,.85) !important; }
.cakupan-card--primary ul li::marker { color: var(--c-gold); }
.cakupan-card h3 {
font-size: 1rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 4px;
}
.cakupan-card p {
font-size: .78rem;
color: var(--c-muted);
margin-bottom: 14px;
padding-bottom: 14px;
border-bottom: 1px solid rgba(255,255,255,.1);
}
.cakupan-card:not(.cakupan-card--primary) p {
border-bottom-color: var(--c-border);
}
.cakupan-card ul {
padding-left: 18px;
margin: 0;
display: flex;
flex-direction: column;
gap: 6px;
}
.cakupan-card ul li {
font-size: .85rem;
color: var(--c-muted);
}
@media (max-width: 768px) {
.layanan-overview  { grid-template-columns: 1fr; }
.layanan-overview-stats { flex-direction: row; flex-wrap: wrap; }
.overview-stat     { flex: 1; min-width: 100px; }
.layanan-detail-grid { grid-template-columns: 1fr 1fr; }
.cakupan-grid      { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
.layanan-detail-grid { grid-template-columns: 1fr; }
} .we-tabs {
display: flex;
gap: 8px;
border-bottom: 2px solid var(--c-border);
padding-bottom: 0;
}
.we-tab {
background: none;
border: none;
border-bottom: 3px solid transparent;
margin-bottom: -2px;
padding: 12px 24px;
font-size: .9rem;
font-weight: 600;
color: var(--c-muted);
cursor: pointer;
transition: color var(--duration) var(--ease),
border-color var(--duration) var(--ease);
}
.we-tab:hover { color: var(--c-primary); }
.we-tab.active {
color: var(--c-primary);
border-bottom-color: var(--c-primary);
}
.email-domain-list {
display: flex;
flex-direction: column;
gap: 10px;
margin: 16px 0;
}
.email-domain-item {
display: flex;
align-items: center;
gap: 12px;
background: var(--c-bg);
border: 1px solid var(--c-border);
border-radius: var(--radius-sm);
padding: 10px 16px;
}
.email-domain-badge {
font-size: .7rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .07em;
padding: 3px 10px;
border-radius: 100px;
flex-shrink: 0;
}
.email-domain-badge--student {
background: rgba(63,114,175,.12);
color: var(--c-primary);
}
.email-domain-badge--staff {
background: rgba(17,45,78,.1);
color: var(--c-dark);
}
.email-domain-addr {
font-size: .88rem;
font-weight: 600;
color: var(--c-dark);
font-family: monospace;
}
.we-divider {
height: 1px;
background: var(--c-border);
margin: 40px 0;
}
.we-steps {
display: flex;
flex-direction: column;
gap: 20px;
max-width: 680px;
margin: 0 auto;
}
.we-step {
display: flex;
gap: 20px;
align-items: flex-start;
}
.we-step-num {
width: 36px;
height: 36px;
border-radius: 50%;
background: var(--c-primary);
color: #fff;
font-size: .85rem;
font-weight: 700;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.we-step-body h4 {
font-size: .95rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 4px;
}
.we-step-body p {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
}
@media (max-width: 768px) {
.we-tabs { overflow-x: auto; }
.we-tab  { white-space: nowrap; padding: 10px 16px; }
} .si-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
}
.si-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 24px;
display: flex;
flex-direction: column;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.si-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-3px);
}
.si-card-top {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 14px;
}
.si-icon { font-size: 1.8rem; }
.si-label {
font-size: .68rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .07em;
padding: 3px 10px;
border-radius: 100px;
}
.si-label--primary {
background: rgba(63,114,175,.12);
color: var(--c-primary);
}
.si-label--blue {
background: rgba(63,114,175,.08);
color: var(--c-primary);
}
.si-label--dark {
background: rgba(17,45,78,.08);
color: var(--c-dark);
}
.si-nama {
font-size: 1.05rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 2px;
}
.si-kepanjangan {
font-size: .75rem;
color: var(--c-muted);
margin-bottom: 10px;
}
.si-desc {
font-size: .83rem;
color: var(--c-muted);
line-height: 1.7;
flex: 1;
margin-bottom: 16px;
}
.si-link {
font-size: .82rem;
font-weight: 600;
color: var(--c-primary);
text-decoration: none;
margin-top: auto;
}
.si-link:hover { text-decoration: underline; }
.si-internal {
font-size: .78rem;
color: var(--c-muted);
background: var(--c-bg);
padding: 4px 10px;
border-radius: 100px;
display: inline-block;
margin-top: auto;
} .sintesys-features {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 20px;
max-width: 860px;
margin: 0 auto;
}
.sf-item {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 20px;
display: flex;
gap: 12px;
align-items: flex-start;
}
.sf-icon { font-size: 1.4rem; flex-shrink: 0; }
.sf-text {
display: flex;
flex-direction: column;
gap: 4px;
}
.sf-text strong {
font-size: .88rem;
font-weight: 700;
color: var(--c-dark);
}
.sf-text span {
font-size: .78rem;
color: var(--c-muted);
line-height: 1.5;
}
@media (max-width: 768px) {
.si-grid          { grid-template-columns: 1fr 1fr; }
.sintesys-features { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
.si-grid { grid-template-columns: 1fr; }
.sintesys-features { grid-template-columns: 1fr; }
} .helpdesk-cta-wrap {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
}
.helpdesk-cta-card {
background: var(--c-bg);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 28px 24px;
display: flex;
flex-direction: column;
}
.helpdesk-cta-card--wa {
background: var(--c-dark);
border-color: var(--c-dark);
}
.helpdesk-cta-card--wa h3,
.helpdesk-cta-card--wa p { color: rgba(255,255,255,.85) !important; }
.helpdesk-cta-card--wa .hc-contact { color: #fff; }
.hc-icon { font-size: 2rem; margin-bottom: 12px; }
.helpdesk-cta-card h3 {
font-size: 1rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 8px;
}
.helpdesk-cta-card p {
font-size: .85rem;
color: var(--c-muted);
line-height: 1.6;
margin-bottom: 12px;
flex: 1;
}
.hc-contact {
font-size: 1rem;
font-weight: 700;
color: var(--c-primary);
margin-bottom: 4px;
}
.hc-schedule {
display: flex;
flex-direction: column;
gap: 8px;
margin-top: 4px;
}
.hc-schedule-row {
display: flex;
justify-content: space-between;
gap: 24px;
font-size: .83rem;
color: var(--c-text);
padding: 9px 0;
border-bottom: 1px solid var(--c-border);
}
.hc-schedule-row span:last-child { white-space: nowrap; }
.hc-schedule-row:last-child { border-bottom: none; }
.hc-schedule-row--off span { color: var(--c-muted); } .sla-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
max-width: 760px;
margin: 0 auto;
}
.sla-card {
border-radius: var(--radius);
padding: 28px 24px;
text-align: center;
border-top: 4px solid transparent;
}
.sla-card--high {
background: #fff5f5;
border-top-color: #e53e3e;
}
.sla-card--med {
background: #fffbeb;
border-top-color: var(--c-gold);
}
.sla-card--low {
background: #f0fff4;
border-top-color: #38a169;
}
.sla-priority {
font-size: .72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .09em;
color: var(--c-muted);
margin-bottom: 8px;
}
.sla-time {
font-size: 1.6rem;
font-weight: 800;
color: var(--c-dark);
margin-bottom: 10px;
}
.sla-desc {
font-size: .82rem;
color: var(--c-muted);
line-height: 1.65;
}
@media (max-width: 768px) {
.helpdesk-cta-wrap { grid-template-columns: 1fr; }
.sla-grid          { grid-template-columns: 1fr; }
} .alur-steps {
max-width: 680px;
margin: 0 auto;
display: flex;
flex-direction: column;
}
.alur-step {
display: flex;
gap: 20px;
align-items: flex-start;
position: relative;
}
.alur-step-num {
width: 40px;
height: 40px;
border-radius: 50%;
background: var(--c-primary);
color: #fff;
font-size: .9rem;
font-weight: 700;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
position: relative;
z-index: 1;
}
.alur-step-connector {
position: absolute;
left: 19px;
top: 40px;
width: 2px;
height: calc(100% + 8px);
background: var(--c-border);
z-index: 0;
}
.alur-step-body {
padding-bottom: 32px;
flex: 1;
}
.alur-step-body h3 {
font-size: .98rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 6px;
padding-top: 8px;
}
.alur-step-body p {
font-size: .87rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
} .jenis-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 16px;
}
.jenis-card {
background: var(--c-white);
border: 1px solid var(--c-border);
border-radius: var(--radius);
padding: 20px;
display: flex;
gap: 14px;
align-items: flex-start;
transition: box-shadow var(--duration) var(--ease),
transform var(--duration) var(--ease);
}
.jenis-card:hover {
box-shadow: var(--shadow);
transform: translateY(-2px);
}
.jenis-icon { font-size: 1.4rem; flex-shrink: 0; }
.jenis-icon svg { width: 28px !important; height: 28px !important; }
.jenis-body h4 {
font-size: .88rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 4px;
}
.jenis-body p {
font-size: .8rem;
color: var(--c-muted);
line-height: 1.65;
margin: 0;
} .alur-info-wrap {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 20px;
max-width: 760px;
margin: 0 auto;
}
.alur-info-card {
border-radius: var(--radius);
padding: 24px;
display: flex;
gap: 16px;
align-items: flex-start;
}
.alur-info-card--note {
background: #fffbeb;
border: 1px solid #f6e05e;
}
.alur-info-card--hours {
background: var(--c-bg);
border: 1px solid var(--c-border);
}
.alur-info-icon { font-size: 1.4rem; flex-shrink: 0; }
.alur-info-card h4 {
font-size: .88rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 8px;
}
.alur-info-card ul {
padding-left: 16px;
margin: 0;
display: flex;
flex-direction: column;
gap: 6px;
}
.alur-info-card ul li {
font-size: .82rem;
color: var(--c-muted);
line-height: 1.6;
}
@media (max-width: 768px) {
.jenis-grid     { grid-template-columns: 1fr 1fr; }
.alur-info-wrap { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
.jenis-grid { grid-template-columns: 1fr; }
} .ppid-intro {
display: flex;
align-items: center;
justify-content: space-between;
gap: 24px;
flex-wrap: wrap;
margin-bottom: 40px;
padding: 24px 28px;
background: var(--c-bg);
border-radius: var(--radius);
border-left: 4px solid var(--c-primary);
}
.ppid-intro p {
font-size: .92rem;
color: var(--c-muted);
line-height: 1.7;
margin: 0;
flex: 1;
}
.ppid-doc-intro {
margin-bottom: 32px;
}
.ppid-doc-intro p {
font-size: .92rem;
color: var(--c-muted);
line-height: 1.75;
max-width: 720px;
}
.ppid-section {
margin-bottom: 40px;
}
.ppid-section-title {
display: flex;
align-items: center;
gap: 12px;
font-size: 1rem;
font-weight: 700;
color: var(--c-dark);
margin-bottom: 16px;
}
.ppid-section-badge {
background: var(--c-primary);
color: #fff;
font-size: .72rem;
font-weight: 700;
padding: 4px 12px;
border-radius: 100px;
flex-shrink: 0;
}
.ppid-table-wrap {
overflow-x: auto;
border-radius: var(--radius);
border: 1px solid var(--c-border);
}
.ppid-table {
width: 100%;
border-collapse: collapse;
font-size: .85rem;
}
.ppid-table thead {
background: var(--c-dark);
color: #fff;
}
.ppid-table thead th {
padding: 12px 16px;
text-align: left;
font-weight: 600;
font-size: .78rem;
letter-spacing: .03em;
}
.ppid-table tbody tr {
border-bottom: 1px solid var(--c-border);
transition: background var(--duration) var(--ease);
}
.ppid-table tbody tr:last-child { border-bottom: none; }
.ppid-table tbody tr:hover { background: var(--c-bg); }
.ppid-table tbody td {
padding: 12px 16px;
color: var(--c-text);
vertical-align: middle;
}
.ppid-link {
color: var(--c-primary);
font-weight: 600;
text-decoration: none;
font-size: .82rem;
}
.ppid-link:hover { text-decoration: underline; }
.ppid-badge {
display: inline-block;
font-size: .72rem;
font-weight: 700;
padding: 3px 10px;
border-radius: 100px;
}
.ppid-badge--available {
background: #f0fff4;
color: #38a169;
}
.ppid-badge--soon {
background: #fffbeb;
color: #d69e2e;
}
.ppid-note {
display: flex;
gap: 10px;
align-items: flex-start;
background: var(--c-bg);
border-radius: var(--radius-sm);
padding: 14px 18px;
margin-top: 24px;
font-size: .82rem;
color: var(--c-muted);
line-height: 1.65;
}
.ppid-note a { color: var(--c-primary); font-weight: 600; }
@media (max-width: 768px) {
.ppid-intro { flex-direction: column; }
} .kontak-grid {
display: grid;
grid-template-columns: 1fr 1.3fr;
gap: 48px;
align-items: start;
}
.kontak-info {
display: flex;
flex-direction: column;
gap: 24px;
}
.kontak-info-block {
display: flex;
align-items: flex-start;
gap: 16px;
}
.kontak-info-icon {
font-size: 1.3rem;
flex-shrink: 0;
width: 44px;
height: 44px;
color: var(--c-primary);
background: var(--c-bg-alt);
border-radius: var(--radius);
display: flex;
align-items: center;
justify-content: center;
}
.kontak-info-icon svg { width: 22px !important; height: 22px !important; }
.kontak-info-label {
font-size: .72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .08em;
color: var(--c-muted);
margin-bottom: 4px;
}
.kontak-info-value {
font-size: .9rem;
color: var(--c-text);
line-height: 1.65;
}
.kontak-info-value a {
color: var(--c-primary);
text-decoration: none;
font-weight: 600;
}
.kontak-info-value a:hover { text-decoration: underline; }
.btn-wa-kontak {
display: inline-flex;
align-items: center;
gap: 10px;
background: var(--c-primary);
color: #fff !important;
font-weight: 600;
font-size: .9rem;
padding: 13px 24px;
border-radius: 100px;
text-decoration: none !important;
width: fit-content;
margin-top: 8px;
border: 2px solid transparent;
transition: background var(--duration) var(--ease),
transform var(--duration) var(--ease),
box-shadow var(--duration) var(--ease);
box-shadow: 0 4px 16px rgba(63,114,175,.35);
}
.btn-wa-kontak:hover {
background: var(--c-primary-dk);
transform: translateY(-2px);
box-shadow: 0 8px 24px rgba(63,114,175,.45);
}
.kontak-map-wrap {
display: flex;
flex-direction: column;
gap: 10px;
}
.kontak-map-label {
font-size: .78rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .08em;
color: var(--c-muted);
}
.kontak-map {
height: 420px;
border-radius: var(--radius);
overflow: hidden;
border: 1px solid var(--c-border);
box-shadow: var(--shadow);
}
@media (max-width: 768px) {
.kontak-grid { grid-template-columns: 1fr; gap: 32px; }
.kontak-map  { height: 280px; }
.page-hero   { padding: 40px 0 32px; }
} .upatik-footer {
background: var(--c-gold);
color: rgba(17,45,78,.85);
font-size: .88rem;
}
.upatik-footer-main {
padding: 36px 0 28px;
}
.upatik-footer-grid {
display: grid;
grid-template-columns: 1.2fr 0.8fr 1.3fr;
gap: 32px;
} .upatik-footer-brand {}
.footer-logo {
height: 44px;
width: auto;
object-fit: contain;
margin-bottom: 8px;
}
.footer-brand-name {
display: flex;
flex-direction: column;
margin-bottom: 12px;
}
.footer-brand-short {
font-size: 1.05rem;
font-weight: 700;
color: var(--c-dark);
letter-spacing: .02em;
}
.footer-brand-long {
font-size: .78rem;
color: rgba(17,45,78,.6);
line-height: 1.5;
margin-top: 2px;
}
.footer-divider {
width: 40px;
height: 2px;
background: var(--c-dark);
border-radius: 2px;
margin-bottom: 12px;
opacity: .3;
}
.footer-address-block {
margin-bottom: 10px;
}
.footer-address-label {
font-size: .72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .08em;
color: var(--c-dark);
margin-bottom: 4px;
}
.footer-address-block address {
font-style: normal;
color: rgba(17,45,78,.7);
line-height: 1.7;
font-size: .83rem;
} .footer-col-title {
font-size: .78rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .09em;
color: rgba(17,45,78,.5);
margin: 0 0 12px;
}
.footer-links {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 8px;
}
.footer-links li a {
color: rgba(17,45,78,.75);
text-decoration: none;
font-size: .85rem;
transition: color var(--duration) var(--ease);
}
.footer-links li a:hover {
color: var(--c-dark);
} .footer-contact {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 10px;
}
.footer-contact li {
display: flex;
flex-direction: column;
gap: 2px;
font-size: .85rem;
color: rgba(17,45,78,.75);
}
.footer-contact-label {
font-size: .7rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .07em;
color: rgba(17,45,78,.45);
}
.footer-contact li a {
color: rgba(17,45,78,.8);
text-decoration: none;
transition: color var(--duration) var(--ease);
}
.footer-contact li a:hover { color: var(--c-dark); } .footer-map {
border-radius: 8px;
overflow: hidden;
border: 1px solid rgba(17,45,78,.15);
}
.footer-map img {
width: 100%;
height: 180px;
object-fit: cover;
display: block;
}
@media (min-width: 769px) {
.footer-map img { height: 260px; }
} .upatik-footer-bottom {
background: var(--c-dark);
border-top: none;
padding: 14px 0;
}
.upatik-footer-bottom-inner {
display: flex;
justify-content: space-between;
align-items: center;
gap: 16px;
flex-wrap: wrap;
font-size: .78rem;
color: rgba(255,255,255,.45);
}
.footer-bottom-links {
display: flex;
align-items: center;
gap: 8px;
}
.footer-bottom-links a {
color: rgba(255,255,255,.45);
text-decoration: none;
transition: color var(--duration) var(--ease);
}
.footer-bottom-links a:hover { color: rgba(255,255,255,.8); } @media (max-width: 768px) { .upatik-hero {
padding: 48px 0 40px;
min-height: auto;
text-align: center;
}
.upatik-hero .container > div {
grid-template-columns: 1fr !important;
gap: 0 !important;
}
.hero-visual  { display: none; }
.hero-label   { justify-content: center; }
.upatik-hero h1 {
font-size: clamp(1.7rem, 7vw, 2.2rem);
}
.upatik-hero p.lead {
font-size: .92rem;
max-width: 100%;
margin-left: auto;
margin-right: auto;
}
.hero-btns {
justify-content: center;
flex-direction: column;
align-items: center;
}
.hero-stats {
justify-content: center;
gap: 16px;
flex-wrap: wrap;
}
.hero-stat { min-width: 80px; text-align: center; }
.ppid-banner  { padding: 32px 24px; flex-direction: column; }
.ppid-banner h2 { font-size: 1.3rem; }
.upatik-section { padding: 52px 0; }
.upatik-brand-long { display: none; } .upatik-footer-grid {
grid-template-columns: 1fr;
gap: 24px;
}
.upatik-footer-main { padding: 28px 0 20px; }
.upatik-footer-bottom-inner { flex-direction: column; text-align: center; }
} .archive-wrap {
display: grid;
grid-template-columns: 1fr 300px;
gap: 48px;
align-items: start;
}
.archive-list {
display: flex;
flex-direction: column;
border: 1px solid var(--c-border);
border-radius: 12px;
overflow: hidden;
margin-bottom: 24px;
}
.archive-item {
display: flex;
position: relative;
border-bottom: 1px solid var(--c-border);
transition: background .15s;
}
.archive-item:last-child { border-bottom: none; }
.archive-item:hover { background: var(--c-bg); }
.archive-item-link {
position: absolute;
inset: 0;
z-index: 1;
}
.archive-item-date {
flex-shrink: 0;
width: 72px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
background: var(--c-dark);
color: #fff;
padding: 16px 8px;
text-align: center;
pointer-events: none;
}
.archive-item-day   { font-size: 1.6rem; font-weight: 700; line-height: 1; }
.archive-item-month { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; opacity: .8; margin-top: 2px; }
.archive-item-year  { font-size: .68rem; opacity: .5; margin-top: 2px; }
.archive-item-body {
padding: 16px 20px;
flex: 1;
position: relative;
z-index: 2;
pointer-events: none;
}
.archive-item-body h2 {
font-size: .97rem;
font-weight: 600;
color: var(--c-dark);
margin: 8px 0 6px;
line-height: 1.4;
}
.archive-item-body p {
font-size: .85rem;
color: var(--c-muted);
margin: 0;
line-height: 1.5;
}
.archive-pagination .nav-links {
display: flex;
gap: 8px;
align-items: center;
}
.archive-pagination .page-numbers {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 36px;
height: 36px;
padding: 0 10px;
border-radius: 8px;
font-size: .88rem;
font-weight: 500;
border: 1px solid var(--c-border);
color: var(--c-dark);
text-decoration: none;
transition: all .15s;
}
.archive-pagination .page-numbers:hover,
.archive-pagination .page-numbers.current {
background: var(--c-primary);
border-color: var(--c-primary);
color: #fff;
}
@media (max-width: 768px) {
.archive-wrap { grid-template-columns: 1fr; }
.archive-sidebar { order: 1; }
} .galeri-filter-bar {
display: flex;
gap: 8px;
flex-wrap: wrap;
margin-bottom: 32px;
}
.galeri-filter-btn {
padding: 8px 20px;
border: 1.5px solid var(--c-border, #dde3ec);
background: transparent;
color: var(--c-muted);
border-radius: 999px;
font-size: .88rem;
font-weight: 500;
cursor: pointer;
transition: all .2s;
}
.galeri-filter-btn:hover,
.galeri-filter-btn.active {
background: var(--c-primary);
border-color: var(--c-primary);
color: #fff;
}
.galeri-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
margin-bottom: 32px;
}
.galeri-card {
border-radius: 12px;
overflow: hidden;
border: 1px solid var(--c-border, #dde3ec);
background: #fff;
transition: box-shadow .2s, transform .2s;
}
.galeri-card:hover {
box-shadow: 0 8px 28px rgba(63,114,175,.12);
transform: translateY(-3px);
}
.galeri-card-img {
position: relative;
background: var(--c-bg-alt, #DBE2EF);
aspect-ratio: 16/10;
display: flex;
align-items: center;
justify-content: center;
}
.galeri-card-placeholder {
color: var(--c-primary);
opacity: .45;
}
.galeri-card-placeholder svg { width: 52px; height: 52px; }
.galeri-card-label {
position: absolute;
top: 10px;
left: 10px;
background: rgba(17,45,78,.7);
color: #fff;
font-size: .72rem;
font-weight: 600;
letter-spacing: .04em;
text-transform: uppercase;
padding: 3px 10px;
border-radius: 999px;
}
.galeri-card-body {
padding: 16px 18px 20px;
}
.galeri-card-body h3 {
font-size: 1rem;
font-weight: 600;
color: var(--c-dark);
margin: 0 0 6px;
}
.galeri-card-body p {
font-size: .85rem;
color: var(--c-muted);
margin: 0;
line-height: 1.5;
}
.galeri-empty {
text-align: center;
padding: 48px 0;
color: var(--c-muted);
font-size: .95rem;
}
.galeri-note {
display: flex;
align-items: flex-start;
gap: 10px;
background: #f0f4ff;
border-left: 3px solid var(--c-primary);
border-radius: 0 8px 8px 0;
padding: 14px 18px;
font-size: .88rem;
color: var(--c-muted);
margin-top: 8px;
}
.galeri-note p { margin: 0; }
.galeri-note span { flex-shrink: 0; color: var(--c-primary); }
.galeri-note span svg { width: 20px !important; height: 20px !important; display: block; } .agenda-wrap {
display: grid;
grid-template-columns: 1fr 300px;
gap: 40px;
align-items: start;
}
.agenda-main .sec-header { margin-bottom: 28px; }
.agenda-list {
display: flex;
flex-direction: column;
gap: 0;
border: 1px solid var(--c-border, #dde3ec);
border-radius: 12px;
overflow: hidden;
}
.agenda-item {
display: flex;
gap: 0;
border-bottom: 1px solid var(--c-border, #dde3ec);
transition: background .15s;
position: relative;
}
.agenda-item:last-child { border-bottom: none; }
.agenda-item:hover { background: var(--c-bg, #F9F7F7); }
.agenda-item-link {
position: absolute;
inset: 0;
z-index: 1;
}
.agenda-item-body { position: relative; z-index: 2; pointer-events: none; }
.agenda-item-date { position: relative; z-index: 2; pointer-events: none; }
.agenda-item-date {
flex-shrink: 0;
width: 72px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
background: var(--c-dark);
color: #fff;
padding: 16px 8px;
text-align: center;
}
.agenda-item-day {
font-size: 1.6rem;
font-weight: 700;
line-height: 1;
}
.agenda-item-month {
font-size: .72rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: .06em;
opacity: .8;
margin-top: 2px;
}
.agenda-item-year {
font-size: .68rem;
opacity: .5;
margin-top: 2px;
}
.agenda-item-body {
padding: 16px 20px;
flex: 1;
}
.agenda-item-cat {
display: inline-block;
font-size: .72rem;
font-weight: 600;
letter-spacing: .04em;
text-transform: uppercase;
padding: 2px 10px;
border-radius: 999px;
margin-bottom: 8px;
background: var(--c-bg-alt, #DBE2EF);
color: var(--c-primary);
}
.agenda-item-cat--pengumuman { background: #fff3cd; color: #856404; }
.agenda-item-cat--berita-terkini { background: #d1e7dd; color: #0f5132; }
.agenda-item-body h3 {
font-size: .97rem;
font-weight: 600;
color: var(--c-dark);
margin: 0 0 6px;
line-height: 1.4;
}
.agenda-item-body h3 a {
color: inherit;
text-decoration: none;
}
.agenda-item-body h3 a:hover { color: var(--c-primary); }
.agenda-item-body p {
font-size: .85rem;
color: var(--c-muted);
margin: 0;
line-height: 1.5;
}
.agenda-empty {
text-align: center;
padding: 64px 24px;
color: var(--c-muted);
border: 1.5px dashed var(--c-border, #dde3ec);
border-radius: 12px;
}
.agenda-empty-icon { margin-bottom: 16px; opacity: .35; }
.agenda-empty p { margin: 0; font-size: .95rem; }
.agenda-empty-sub { font-size: .85rem; margin-top: 6px !important; }
.agenda-sidebar-card {
background: #fff;
border: 1px solid var(--c-border, #dde3ec);
border-radius: 12px;
padding: 20px 20px 22px;
margin-bottom: 20px;
}
.agenda-sidebar-card h4 {
font-size: .92rem;
font-weight: 700;
color: var(--c-dark);
margin: 0 0 14px;
padding-bottom: 10px;
border-bottom: 1px solid var(--c-border, #dde3ec);
text-transform: uppercase;
letter-spacing: .05em;
}
.agenda-cat-list {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 4px;
}
.agenda-cat-list li a {
display: flex;
justify-content: space-between;
align-items: center;
padding: 7px 10px;
border-radius: 6px;
font-size: .88rem;
color: var(--c-dark);
text-decoration: none;
transition: background .15s;
}
.agenda-cat-list li a:hover {
background: var(--c-bg, #F9F7F7);
color: var(--c-primary);
}
.agenda-cat-count {
font-size: .78rem;
background: var(--c-bg-alt, #DBE2EF);
color: var(--c-muted);
padding: 1px 8px;
border-radius: 999px;
font-weight: 600;
}
@media (max-width: 768px) {
.galeri-grid { grid-template-columns: repeat(2, 1fr); }
.agenda-wrap { grid-template-columns: 1fr; }
.agenda-sidebar { order: 1; }
}
@media (max-width: 480px) {
.galeri-grid { grid-template-columns: 1fr; }
}