:root {
--primary: #16813C; --primary-dark: #0F5C2B; --primary-darker: #0A3D1C; --primary-light: #E6F4EC; --primary-50: #F0FAF4;
--gold: #C4972A; --gold-light: #FDF6E3; --white: #FFFFFF;
--gray-50: #F9FAFB; --gray-100: #F3F4F6; --gray-200: #E5E7EB; --gray-300: #D1D5DB; --gray-400: #9CA3AF; --gray-500: #6B7280;
--gray-600: #4B5563; --gray-700: #374151; --gray-800: #1F2937; --gray-900: #111827;
--sidebar-w: 70px; --sidebar-w-exp: 260px; --header-h: 64px;
--shadow-sm: 0 1px 2px rgba(0,0,0,.05); --shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
--shadow-md: 0 4px 6px rgba(0,0,0,.07); --shadow-lg: 0 10px 15px rgba(0,0,0,.1);
--radius: 12px; --radius-sm: 8px; --radius-lg: 16px; --transition: all .3s cubic-bezier(.4,0,.2,1);
}body { font-family: 'Poppins', sans-serif; color: var(--gray-800); background: var(--gray-50); }
body.desa-custom-layout .site-header, body.desa-custom-layout .site-footer { display: none; }
.section { padding: 70px 0; }
.section-header { text-align: center; margin-bottom: 40px; }
.section-header h2 { font-size: 24px; font-weight: 700; color: var(--gray-900); margin-bottom: 8px; }
.section-header p { color: var(--gray-500); font-size: 14px; max-width: 500px; margin: 0 auto; }
.section-header .divider { width: 50px; height: 3px; background: linear-gradient(90deg, var(--primary), var(--gold)); border-radius: 2px; margin: 12px auto 0; }
.form-control, .form-select { border-radius: var(--radius-sm); border: 1.5px solid var(--gray-200); padding: 10px 14px; font-size: 14px; font-family: inherit; transition: var(--transition); }
.form-control:focus, .form-select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(22,129,60,.1); } @media (max-width: 767px) { .main-content .container { padding-left: 15px !important; padding-right: 15px !important; } .single-news-card, .single-news-content, .login-gate, .error-404-card { padding: 20px !important; }
.single-news-header { padding: 20px 20px 0 !important; } .data-table-box, .apbdes-table-box { margin-left: -10px; margin-right: -10px; } .layanan-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; } .single-news-title { font-size: 22px !important; } .modal-dialog { margin: 8px !important; }
}
@media (max-width: 480px) {
.layanan-grid { grid-template-columns: 1fr !important; }
.bpd-grid { grid-template-columns: 1fr !important; }
}.main-header { position: fixed; top: 0; left: 0; right: 0; height: var(--header-h); z-index: 1050; display: flex; align-items: center; justify-content: space-between; padding: 0 24px 0 calc(var(--sidebar-w) + 24px); transition: var(--transition); }
.main-header.scrolled { background: rgba(255,255,255,.95); backdrop-filter: blur(20px); box-shadow: 0 1px 12px rgba(0,0,0,.08); }
.main-header .header-left { display: flex; align-items: center; gap: 12px; }
.main-header .logo-icon { width: 38px; height: 38px; background: var(--primary); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; }
.main-header .site-text h1 { font-size: 13px; font-weight: 700; color: var(--primary-dark); letter-spacing: 1.5px; margin: 0; }
.main-header .site-text span { font-size: 11px; color: var(--gray-500); }
.main-header .header-nav { display: flex; align-items: center; gap: 4px; }
.main-header .header-nav a { padding: 8px 16px; font-size: 13px; font-weight: 500; color: var(--gray-600); text-decoration: none; border-radius: var(--radius-sm); transition: var(--transition); }
.main-header .header-nav a:hover, .main-header .header-nav a.active { color: var(--primary); background: var(--primary-50); }
.hamburger-btn, .home-icon-mobile, .site-text-mobile { display: none; }
.hamburger-btn { background: none; border: none; font-size: 22px; color: var(--gray-700); cursor: pointer; padding: 8px; }
.home-icon-mobile { background: none; border: none; font-size: 20px; color: var(--primary); cursor: pointer; padding: 8px; text-decoration: none; }
.site-text-mobile { font-size: 16px; font-weight: 700; color: var(--primary-dark); letter-spacing: 1px; }
@media(max-width: 991px) { .main-header { padding: 0 16px; left: 0; justify-content: space-between; } .main-header .logo-icon, .main-header .site-text, .main-header .header-nav { display: none !important; } .hamburger-btn, .home-icon-mobile, .site-text-mobile { display: flex !important; align-items: center; } .main-header .header-left { flex: 1; justify-content: flex-start; } .site-text-mobile { flex: 1; justify-content: center; } .main-header .header-right-mobile { display: flex; justify-content: flex-end; flex: 1; } }.sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 1039; }
.sidebar-overlay.show { display: block; } .sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: var(--sidebar-w); background: var(--white); border-right: 1px solid var(--gray-200); z-index: 1040; transition: width .35s cubic-bezier(.4,0,.2,1); overflow: hidden; display: flex; flex-direction: column; padding-top: var(--header-h); }
.sidebar:hover { width: var(--sidebar-w-exp); box-shadow: 6px 0 24px rgba(0,0,0,.08); }
.sidebar:hover .sidebar-label { opacity: 1; transform: translateX(0); }
.sidebar:hover .sidebar-category span { opacity: 1; }
.sidebar:hover .sidebar-item { max-height: 50px; padding: 8px 20px 8px 60px; opacity: 1; }
.sidebar-scroll { flex: 1; overflow-y: auto; padding: 12px 0; }
.sidebar-bottom { margin-top: auto; border-top: 1px solid var(--gray-200); padding: 8px 0; } .sidebar-category { display: flex; align-items: center; gap: 14px; padding: 10px 20px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--gray-400); white-space: nowrap; cursor: default; }
.sidebar-category i { font-size: 17px; width: 26px; text-align: center; flex-shrink: 0; color: var(--gray-500); transition: var(--transition); }
.sidebar:hover .sidebar-category i { color: var(--primary); }
.sidebar:hover .sidebar-category { padding: 12px 20px 4px; }
.sidebar-category span { opacity: 0; transition: opacity .3s ease; } .sidebar-item { display: flex; align-items: center; padding: 0 20px; max-height: 0; opacity: 0; color: var(--gray-600); font-size: 13px; font-weight: 400; cursor: pointer; transition: var(--transition); white-space: nowrap; text-decoration: none; position: relative; overflow: hidden; }
.sidebar-item:hover { background: var(--primary-50); color: var(--primary); }
.sidebar-item.active { color: var(--primary); font-weight: 600; }
.sidebar-item.active::before { content: ''; position: absolute; left: 0; top: 4px; bottom: 4px; width: 3px; background: var(--primary); border-radius: 0 3px 3px 0; }
.sidebar-label { opacity: 0; transform: translateX(-8px); transition: opacity .25s ease .1s, transform .25s ease .1s; } .sidebar-item-admin { color: var(--gray-500); font-weight: 500; }
.sidebar-item-admin:hover { background: var(--gray-50); color: var(--gray-700); } @media(max-width: 991px) {
.sidebar { transform: translateX(-100%); width: var(--sidebar-w-exp) !important; box-shadow: 6px 0 24px rgba(0,0,0,.12); }
.sidebar.open { transform: translateX(0); }
.sidebar-item { max-height: 50px !important; opacity: 1 !important; padding: 8px 20px 8px 60px !important; }
.sidebar-label { opacity: 1 !important; transform: translateX(0) !important; }
.sidebar-category span { opacity: 1 !important; }
.sidebar-category { padding: 12px 20px 4px !important; }
}.main-content { margin-left: var(--sidebar-w); margin-top: var(--header-h); transition: var(--transition); min-height: calc(100vh - var(--header-h)); } .hero-section { min-height: calc(100vh - var(--header-h)); display: flex; align-items: center; background: linear-gradient(135deg, var(--primary-darker) 0%, var(--primary-dark) 40%, var(--primary) 100%); position: relative; overflow: hidden; padding: 60px 40px; }
.hero-section::before { content: ''; position: absolute; top: -50%; right: -20%; width: 600px; height: 600px; background: rgba(255,255,255,.03); border-radius: 50%; }
.hero-left { position: relative; z-index: 2; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,.1); backdrop-filter: blur(10px); padding: 8px 18px; border-radius: 50px; font-size: 12px; color: rgba(255,255,255,.9); font-weight: 500; margin-bottom: 24px; border: 1px solid rgba(255,255,255,.15); }
.hero-badge i { color: var(--gold); }
.hero-title { font-size: clamp(28px,5vw,52px); font-weight: 800; color: #fff; line-height: 1.15; margin-bottom: 8px; }
.hero-title .gold { color: var(--gold); }
.hero-subtitle { font-size: clamp(14px,2vw,20px); color: rgba(255,255,255,.8); font-weight: 300; margin-bottom: 32px; } .hero-search { max-width: 480px; position: relative; }
.hero-search input[type="text"] { 
width: 100% !important; 
padding: 16px 24px 16px 52px !important; 
border: 2px solid transparent !important; 
border-radius: var(--radius) !important; 
font-size: 15px !important; 
font-family: inherit !important; 
background: rgba(255,255,255,.98) !important; 
box-shadow: 0 8px 30px rgba(0,0,0,.12) !important;
color: var(--gray-800) !important;
height: auto !important;
transition: all .3s ease !important;
}
.hero-search input[type="text"]:focus { 
outline: none !important; 
border-color: var(--gold) !important; 
box-shadow: 0 0 0 4px rgba(196, 151, 42, 0.25), 0 8px 30px rgba(0,0,0,.12) !important; 
background: #fff !important;
}
.hero-search input[type="text"]::placeholder { 
color: var(--gray-400) !important; 
}
.hero-search i { position: absolute; left: 20px; top: 50%; transform: translateY(-50%); color: var(--gray-400); font-size: 16px; z-index: 2; }
.hero-right { position: relative; z-index: 2; }
.hero-slider { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
.hero-slide { display: none; width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.hero-slide.active { display: block; animation: fadeIn .6s ease; }
.slider-dots { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 5; }
.slider-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; transition: var(--transition); border: none; }
.slider-dot.active { background: #fff; width: 28px; border-radius: 5px; }
.slider-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 5; background: rgba(255,255,255,.2); backdrop-filter: blur(6px); border: none; color: #fff; width: 40px; height: 40px; border-radius: 50%; cursor: pointer; font-size: 14px; transition: var(--transition); }
.slider-nav:hover { background: rgba(255,255,255,.35); }
.slider-nav.prev { left: 12px; }
.slider-nav.next { right: 12px; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } .quick-menu-section { padding: 60px 0; margin-top: -40px; position: relative; z-index: 10; }
.qm-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 720px; margin: 0 auto; }
.qm-card { background: var(--white); border-radius: var(--radius); padding: 24px 16px; text-align: center; cursor: pointer; transition: var(--transition); border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 130px;
text-decoration: none !important; 
color: inherit !important; }
.qm-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--primary-light); }
.qm-card:hover .qm-icon { background: var(--primary); color: #fff; transform: scale(1.1); }
.qm-icon { width: 48px; height: 48px; border-radius: var(--radius); background: var(--primary-50); color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 20px; margin-bottom: 12px; transition: var(--transition); }
.qm-card p { font-size: 12px; font-weight: 600; color: var(--gray-700); margin: 0; line-height: 1.3; } .news-card { background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid var(--gray-200); transition: var(--transition); height: 100%; display: flex; flex-direction: column; }
.news-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.news-card img { width: 100%; height: 180px; object-fit: cover; }
.news-card .card-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.news-date { font-size: 11px; color: var(--gray-400); font-weight: 500; margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.news-card h5 { font-size: 15px; font-weight: 600; color: var(--gray-800); margin-bottom: 8px; line-height: 1.4; }
.news-card .summary { font-size: 13px; color: var(--gray-500); line-height: 1.6; flex: 1; }
.btn-read { font-size: 12px; font-weight: 600; color: var(--primary); text-decoration: none; margin-top: 12px; display: inline-flex; align-items: center; gap: 6px; transition: var(--transition); }
.btn-read:hover { gap: 10px; } .stat-card { background: var(--white); border-radius: var(--radius); padding: 24px 16px; border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); transition: var(--transition); text-align: center; position: relative; overflow: hidden; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.stat-icon { width: 48px; height: 48px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: 20px; margin-bottom: 12px; }
.stat-value { font-size: 26px; font-weight: 700; color: var(--gray-900); line-height: 1; }
.stat-label { font-size: 12px; color: var(--gray-500); margin-top: 6px; font-weight: 500; }
.stat-card.green .stat-icon { background: var(--primary-50); color: var(--primary); }
.stat-card.blue .stat-icon { background: #EFF6FF; color: #2563EB; }
.stat-card.purple .stat-icon { background: #F5F3FF; color: #7C3AED; }
.stat-card.orange .stat-icon { background: #FFF7ED; color: #EA580C; }
.stat-card.gold .stat-icon { background: var(--gold-light); color: var(--gold); } .perangkat-scroll { display: flex; gap: 20px; overflow-x: auto; padding: 10px 0 20px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.perangkat-scroll::-webkit-scrollbar { height: 4px; }
.perangkat-scroll::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 4px; }
.perangkat-card { min-width: 180px; scroll-snap-align: start; text-align: center; background: var(--white); border-radius: var(--radius); padding: 24px 16px; border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); transition: var(--transition); flex-shrink: 0; }
.perangkat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--primary-light); }
.perangkat-card img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; border: 3px solid var(--primary-light); margin-bottom: 12px; transition: var(--transition); }
.perangkat-card:hover img { border-color: var(--primary); transform: scale(1.05); }
.perangkat-card h6 { font-size: 13px; font-weight: 600; color: var(--gray-800); margin-bottom: 2px; }
.perangkat-card span { font-size: 11px; color: var(--primary); font-weight: 500; } @media(max-width: 991px) { .main-content { margin-left: 0 !important; } .hero-section { padding: 40px 20px; } }
@media(max-width: 767px) { .qm-grid { gap: 12px; } .qm-card { padding: 20px 12px; min-height: 110px; } .qm-icon { width: 40px; height: 40px; font-size: 18px; } .qm-card p { font-size: 11px; } } .single-news-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-md); overflow: hidden; margin-bottom: 40px; }
.single-news-header { padding: 32px 32px 0; }
.single-news-badge { display: inline-block; background: var(--primary-50); color: var(--primary); font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 50px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.single-news-title { font-size: 28px; font-weight: 800; color: var(--gray-900); line-height: 1.3; margin-bottom: 16px; }
.single-news-meta { display: flex; gap: 20px; font-size: 13px; color: var(--gray-400); padding-bottom: 24px; border-bottom: 1px solid var(--gray-200); }
.single-news-meta i { margin-right: 6px; }
.single-news-thumbnail { width: 100%; aspect-ratio: 16/9; overflow: hidden; }
.single-news-thumbnail img { width: 100%; height: 100%; object-fit: cover; } .single-news-content { padding: 32px; font-size: 16px; line-height: 1.9; color: var(--gray-700); }
.single-news-content p { margin-bottom: 20px; }
.single-news-content h2, .single-news-content h3, .single-news-content h4 { color: var(--gray-900); font-weight: 700; margin-top: 32px; margin-bottom: 16px; }
.single-news-content img { max-width: 100%; height: auto; border-radius: var(--radius-sm); margin: 20px 0; }
.single-news-content a { color: var(--primary); text-decoration: underline; }
.single-news-content ul, .single-news-content ol { padding-left: 24px; margin-bottom: 20px; }
.single-news-content blockquote { border-left: 4px solid var(--primary); padding: 16px 24px; background: var(--primary-50); margin: 24px 0; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-style: italic; } @media(max-width: 767px) {
.single-news-header { padding: 20px 20px 0; }
.single-news-title { font-size: 22px; }
.single-news-content { padding: 20px; font-size: 15px; }
.single-news-thumbnail { aspect-ratio: 4/3; }
} .umkm-card {
background: var(--white);
border-radius: var(--radius);
overflow: hidden;
border: 1px solid var(--gray-200);
box-shadow: var(--shadow-sm);
transition: var(--transition);
height: 100%;
display: flex;
flex-direction: column;
}
.umkm-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--primary-light); }
.umkm-img { width: 100%; height: 180px; overflow: hidden; }
.umkm-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.umkm-card:hover .umkm-img img { transform: scale(1.05); }
.umkm-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.umkm-body h5 { font-size: 15px; font-weight: 600; color: var(--gray-800); margin-bottom: 6px; }
.umkm-body p { font-size: 13px; color: var(--gray-500); line-height: 1.5; margin: 0; } .galeri-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 16px;
}
.galeri-item {
position: relative;
border-radius: var(--radius);
overflow: hidden;
cursor: pointer;
aspect-ratio: 4/3;
box-shadow: var(--shadow-sm);
border: 1px solid var(--gray-200);
}
.galeri-item img {
width: 100%; height: 100%; object-fit: cover;
transition: transform .5s ease;
}
.galeri-item:hover img {
transform: scale(1.1);
}
.galeri-overlay {
position: absolute; inset: 0;
background: linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,0) 60%);
display: flex; flex-direction: column; justify-content: flex-end;
padding: 16px; opacity: 0; transition: opacity .3s ease;
}
.galeri-item:hover .galeri-overlay { opacity: 1; }
.galeri-overlay i { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 28px; color: #fff; margin-bottom: 10px; }
.galeri-overlay span { color: #fff; font-size: 13px; font-weight: 500; } .nav-links { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.nav-links .page-numbers { 
width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; 
border-radius: var(--radius-sm); border: 1px solid var(--gray-200); color: var(--gray-600); 
font-size: 14px; font-weight: 500; text-decoration: none; background: var(--white);
transition: var(--transition); box-shadow: var(--shadow-sm);
}
.nav-links .page-numbers.current { 
background: var(--primary); color: #fff; border-color: var(--primary); box-shadow: 0 4px 12px rgba(22,129,60,.3);
}
.nav-links .page-numbers:not(.current):hover { 
border-color: var(--primary); color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-md);
}
.nav-links .page-numbers.dots { border: none; box-shadow: none; background: transparent; }
.nav-links .page-numbers.prev, .nav-links .page-numbers.next { width: auto; padding: 0 16px; } .error-404-card {
text-align: center; padding: 60px 40px; background: var(--white);
border-radius: var(--radius-lg); border: 1px solid var(--gray-200);
box-shadow: var(--shadow-md);
}
.error-404-icon {
width: 80px; height: 80px; border-radius: 50%; background: var(--primary-50);
display: flex; align-items: center; justify-content: center; margin: 0 auto 24px;
}
.error-404-icon i { font-size: 36px; color: var(--primary); }
.error-404-title {
font-size: 80px; font-weight: 800; color: var(--gray-100); line-height: 1;
margin: 0; letter-spacing: -4px;
-webkit-text-stroke: 2px var(--gray-200); }
.error-404-subtitle {
font-size: 22px; font-weight: 700; color: var(--gray-800); margin-top: -10px; margin-bottom: 12px;
}
.error-404-text {
font-size: 15px; color: var(--gray-500); line-height: 1.6; max-width: 400px; margin: 0 auto 30px;
}
.error-404-search { max-width: 350px; margin: 0 auto; }
.error-404-search input:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(22,129,60,.1); }
@media(max-width: 767px) {
.error-404-card { padding: 40px 20px; }
.error-404-title { font-size: 60px; }
.error-404-subtitle { font-size: 18px; }
} @media (max-width: 767px) { .main-content .container { padding-left: 15px !important; padding-right: 15px !important; } .single-news-card, .single-news-content, .login-gate, .error-404-card { padding: 20px !important; }
.single-news-header { padding: 20px 20px 0 !important; } .data-table-box, .apbdes-table-box { margin-left: -10px; margin-right: -10px; } .layanan-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; } .single-news-title { font-size: 22px !important; } .modal-dialog { margin: 8px !important; }
}
@media (max-width: 480px) {
.layanan-grid { grid-template-columns: 1fr !important; }
.bpd-grid { grid-template-columns: 1fr !important; }
}.main-footer {
background: var(--primary-darker); color: rgba(255,255,255,.7);
padding: 60px 0 0;
margin-left: var(--sidebar-w); transition: var(--transition);
} .main-footer h5 { color: #fff; font-size: 16px; font-weight: 600; margin-bottom: 0; }
.footer-title { 
padding-bottom: 12px; 
margin-bottom: 20px; 
border-bottom: 2px solid rgba(255,255,255,.15); }
.footer-desc { margin-top: 20px; font-size: 13px; line-height: 1.8; color: rgba(255,255,255,.6); }
.footer-list {
list-style: none; padding: 0; margin: 0;
}
.footer-list li {
font-size: 13px; color: rgba(255,255,255,.7); margin-bottom: 12px;
display: flex; align-items: flex-start; gap: 10px; }
.footer-list li i { color: var(--gold); margin-top: 3px; width: 16px; text-align: center; flex-shrink: 0; }
.footer-list a { color: rgba(255,255,255,.7); text-decoration: none; transition: var(--transition); }
.footer-list a:hover { color: var(--gold); padding-left: 4px; } .footer-logo { display: flex; align-items: center; gap: 12px; }
.footer-logo .logo-icon { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; flex-shrink: 0; background: rgba(255,255,255,.15); }
.footer-logo span { font-size: 12px; color: rgba(255,255,255,.5); } .social-links { display: flex; gap: 10px; }
.social-link { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 16px; transition: var(--transition); text-decoration: none; }
.social-link:hover { background: var(--gold); color: #fff; transform: translateY(-2px); } .footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 40px; padding: 20px 0; text-align: center; font-size: 13px; color: rgba(255,255,255,.4); }
.footer-bottom a { color: var(--gold); text-decoration: none; font-weight: 600; }
.footer-bottom a:hover { color: #fff; } @media(max-width: 991px) {
.main-footer { margin-left: 0 !important; } }.login-gate {
text-align: center; 
padding: 50px 40px; 
background: var(--white); 
border-radius: var(--radius-lg); 
border: 1px solid var(--gray-200); 
box-shadow: var(--shadow-md);
}
.login-icon-wrap {
width: 70px; height: 70px; border-radius: 50%; background: var(--primary-50);
display: flex; align-items: center; justify-content: center; margin: 0 auto 20px;
}
.login-icon-wrap i { font-size: 30px; color: var(--primary); }
.login-gate h4 { color: var(--gray-800); margin-bottom: 8px; font-weight: 700; font-size: 20px; }
.login-gate p { color: var(--gray-500); font-size: 14px; margin-bottom: 28px; }
.btn-gate {
display: inline-block; padding: 12px 32px; background: var(--primary); color: #fff;
border-radius: var(--radius-sm); text-decoration: none; font-weight: 600; font-size: 15px;
box-shadow: 0 4px 14px rgba(22,129,60,.3); transition: var(--transition);
}
.btn-gate:hover { background: var(--primary-dark); color: #fff; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(22,129,60,.4); } .desa-login-form { max-width: 100%; margin: 0 auto; text-align: left; }
.desa-login-form input { 
width: 100%; margin-bottom: 16px; border: 1.5px solid var(--gray-200); 
border-radius: var(--radius-sm); padding: 14px 16px; font-size: 14px; font-family: inherit;
background: var(--gray-50); transition: var(--transition);
}
.desa-login-form input:focus { border-color: var(--primary); outline: none; background: #fff; box-shadow: 0 0 0 3px rgba(22,129,60,.1); }
.btn-login { 
width: 100%; padding: 14px; background: var(--primary); color: #fff; border: none; 
border-radius: var(--radius-sm); font-size: 15px; font-weight: 600; cursor: pointer; 
transition: var(--transition); font-family: inherit;
}
.btn-login:hover { background: var(--primary-dark); } .info-register {
margin-top: 24px; padding: 12px; background: var(--gray-50); border-radius: var(--radius-sm);
font-size: 12px; color: var(--gray-500); line-height: 1.5; border: 1px dashed var(--gray-300);
} .dashboard-welcome { 
display: flex; justify-content: space-between; align-items: center; 
background: var(--white); padding: 24px 28px; border-radius: var(--radius); 
border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); margin-bottom: 30px; 
}
.dashboard-welcome h4 { margin: 0; font-size: 18px; color: var(--primary-dark); }
.dashboard-welcome p { margin: 4px 0 0; font-size: 13px; color: var(--gray-500); }
.btn-logout { 
background: #fff; color: var(--gray-600); border: 1px solid var(--gray-300); 
padding: 10px 20px; border-radius: var(--radius-sm); text-decoration: none; 
font-size: 13px; font-weight: 500; transition: var(--transition); white-space: nowrap;
}
.btn-logout:hover { border-color: #dc3545; color: #dc3545; background: #fff5f5; } .layanan-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 20px; }
.layanan-card { 
background: var(--white); border: 1px solid var(--gray-200); border-radius: var(--radius); 
padding: 32px 16px; cursor: pointer; transition: var(--transition); text-align: center; 
box-shadow: var(--shadow-sm);
}
.layanan-card:hover { border-color: var(--primary); box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.layanan-icon { 
width: 60px; height: 60px; border-radius: 16px; background: var(--primary-50); color: var(--primary);
display: flex; align-items: center; justify-content: center; font-size: 24px; margin: 0 auto 16px;
transition: var(--transition);
}
.layanan-card:hover .layanan-icon { background: var(--primary); color: #fff; transform: scale(1.1); }
.layanan-card h6 { font-size: 14px; font-weight: 600; color: var(--gray-800); margin: 0; } .badge-status { padding: 4px 12px; border-radius: 50px; font-size: 11px; font-weight: 600; white-space: nowrap; }
.badge-menunggu { background: #FEF3C7; color: #D97706; }
.badge-diproses { background: #DBEAFE; color: #2563EB; }
.badge-selesai { background: #D1FAE5; color: #059669; }
.badge-ditolak { background: #FEE2E2; color: #DC2626; } @media (max-width: 767px) {
.table-modern table { font-size: 12px !important; }
.table-modern th, .table-modern td { padding: 10px 12px !important; }
} .shortcut-card {
display: flex; flex-direction: column; align-items: center; justify-content: center;
background: var(--white); border: 1px solid var(--gray-200); border-radius: var(--radius);
padding: 28px 16px; text-align: center; transition: var(--transition); text-decoration: none;
box-shadow: var(--shadow-sm); color: var(--gray-700); min-height: 140px;
}
.shortcut-card i { font-size: 28px; color: var(--primary); margin-bottom: 12px; transition: var(--transition); }
.shortcut-card span { font-size: 13px; font-weight: 600; }
.shortcut-card:hover { 
border-color: var(--primary); color: var(--primary); 
transform: translateY(-5px); box-shadow: var(--shadow-lg);
background: var(--primary-50);
}
.shortcut-card:hover i { transform: scale(1.15); }