:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #3b82f6;--primary-50: #eff6ff;--primary-100: #dbeafe;--bg: #f8fafc;--bg-white: #ffffff;--text-dark: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--transition: all .2s ease;--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--purple: #8b5cf6;--cyan: #06b6d4;--pink: #ec4899;--orange: #f97316}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg);color:var(--text-dark);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;outline:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:64px 0}.section-label{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);margin-bottom:8px}.section-title{font-size:32px;font-weight:800;color:var(--text-dark);margin-bottom:8px;line-height:1.2}.section-subtitle{font-size:15px;color:var(--text-muted);margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px}.navbar{position:sticky;top:0;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 24px}.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}.navbar-brand{display:flex;align-items:center;gap:12px}.navbar-logo-img{height:40px;width:auto;object-fit:contain}.brand-logo{width:44px;height:44px;object-fit:contain;border-radius:var(--radius-md);flex-shrink:0}.navbar-title{font-size:16px;font-weight:700;color:var(--text-dark)}.navbar-subtitle{font-size:12px;color:var(--text-muted)}.navbar-links{display:flex;align-items:center;gap:8px}.navbar-link{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-muted);transition:var(--transition)}.navbar-link:hover,.navbar-link.active{color:var(--primary);background:var(--primary-50)}.navbar-login{background:var(--primary);color:#fff;padding:8px 24px;border-radius:var(--radius-full);font-size:14px;font-weight:600;transition:var(--transition)}.navbar-login:hover{background:var(--primary-dark);transform:scale(1.02)}.navbar-mobile-toggle{display:none;background:none;font-size:24px;color:var(--text-dark)}.hero{background:linear-gradient(135deg,#f0f4ff,#e8efff,#f8fafc);min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-50%;left:-25%;width:150%;height:150%;background:radial-gradient(ellipse at center,rgba(37,99,235,.06) 0%,transparent 70%);pointer-events:none}.hero-tag{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--primary-100);padding:6px 16px;border-radius:var(--radius-full);font-size:12px;font-weight:700;color:var(--primary);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:24px}.hero h1{font-size:48px;font-weight:800;line-height:1.15;margin-bottom:16px;color:var(--text-dark)}.hero h1 span{background:linear-gradient(135deg,var(--primary),#22c55e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:16px;color:var(--text-muted);max-width:560px;margin:0 auto 32px;line-height:1.7}.hero-search{max-width:580px;margin:0 auto 24px;display:flex;align-items:center;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border)}.hero-search input{flex:1;padding:16px 20px;border:none;font-size:15px;background:transparent;color:var(--text-dark)}.hero-search input::placeholder{color:var(--text-light)}.hero-search button{background:var(--primary);color:#fff;padding:12px 24px;margin:4px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;transition:var(--transition);white-space:nowrap}.hero-search button:hover{background:var(--primary-dark)}.hero-tags{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.hero-tags span:first-child{font-size:13px;color:var(--text-muted);font-weight:500}.hero-tags a{font-size:13px;font-weight:600;color:var(--text-dark);padding:4px 12px;border-radius:var(--radius-full);background:#fff;border:1px solid var(--border);transition:var(--transition)}.hero-tags a:hover{border-color:var(--primary);color:var(--primary)}.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:32px 0}.stat-item{display:flex;align-items:center;gap:16px;background:#fff;padding:20px 24px;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}.stat-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px}.stat-label{font-size:12px;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:24px;font-weight:800;color:var(--text-dark)}.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.category-card{background:#fff;border-radius:var(--radius-xl);padding:28px 24px;text-align:center;cursor:pointer;transition:var(--transition);border:1px solid var(--border)}.category-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:transparent}.category-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px}.category-name{font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:4px}.category-count{font-size:13px;color:var(--text-muted)}.spm-layout{display:grid;grid-template-columns:350px 1fr;gap:40px;align-items:start}.spm-info h3{font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:8px;background:var(--primary-50);display:inline-block;padding:4px 12px;border-radius:var(--radius-full)}.spm-info h2{font-size:32px;font-weight:800;color:var(--text-dark);margin-bottom:8px;line-height:1.2}.spm-info p{font-size:14px;color:var(--text-muted);line-height:1.6}.spm-cards{display:flex;flex-direction:column;gap:12px}.spm-card{display:flex;align-items:center;gap:16px;background:#fff;padding:16px 20px;border-radius:var(--radius-xl);border:1px solid var(--border);transition:var(--transition)}.spm-card:hover{box-shadow:var(--shadow-md)}.spm-card-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.spm-card-info{flex:1}.spm-card-label{font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:6px}.spm-progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.spm-progress-fill{height:100%;border-radius:4px;transition:width 1s ease}.spm-card-value{font-size:18px;font-weight:800;color:var(--text-dark);flex-shrink:0}.stats-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px}.stats-tabs-wrapper{display:flex;align-items:center;gap:8px;background:#f1f5f9;padding:4px;border-radius:var(--radius-full);max-width:450px;position:relative}.stats-tabs{display:flex;gap:4px;overflow-x:auto;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none}.stats-tabs::-webkit-scrollbar{display:none}.stats-tab{padding:8px 18px;border-radius:var(--radius-full);font-size:14px;font-weight:600;color:var(--text-muted);background:transparent;transition:var(--transition);border:1px solid transparent;white-space:nowrap;flex-shrink:0}.stats-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb33}.stats-tab:hover:not(.active){background:#fff;color:var(--primary)}.stats-nav-btn{width:32px;height:32px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--text-muted);box-shadow:0 2px 4px #0000000d;transition:var(--transition);flex-shrink:0}.stats-nav-btn:hover{background:var(--primary);color:#fff}.macro-card{background:#fff;border-radius:var(--radius-xl);padding:24px;border:1px solid var(--border);transition:var(--transition)}.macro-card:hover{box-shadow:var(--shadow-md)}.macro-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.macro-value{font-size:40px;font-weight:800;color:var(--text-dark);line-height:1}.macro-unit{font-size:16px;font-weight:500;color:var(--text-light);margin-left:8px}.macro-change{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;margin-top:8px;padding:2px 8px;border-radius:var(--radius-full)}.macro-change.positive{color:var(--green);background:#f0fdf4}.macro-change.negative{color:var(--red);background:#fef2f2}.macro-link{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--primary);margin-top:12px;cursor:pointer;transition:var(--transition)}.macro-link:hover{gap:8px}.dataset-list{display:flex;flex-direction:column;gap:12px}.dataset-item{display:flex;align-items:flex-start;gap:16px;background:#fff;padding:20px 24px;border-radius:var(--radius-xl);border:1px solid var(--border);transition:var(--transition);cursor:pointer}.dataset-item:hover{box-shadow:var(--shadow-md);border-color:var(--primary-100)}.dataset-icon{width:44px;height:44px;background:var(--primary-50);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.dataset-info{flex:1}.dataset-title{font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:6px}.dataset-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.dataset-category{font-size:12px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.dataset-date{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.dataset-date:before{content:"";width:4px;height:4px;border-radius:50%;background:var(--text-light)}.dataset-external{color:var(--text-light);transition:var(--transition)}.dataset-item:hover .dataset-external{color:var(--primary)}.ppid{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:var(--radius-2xl);padding:60px;margin:40px 0;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;overflow:hidden}.ppid:after{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(37,99,235,.15),transparent 70%);pointer-events:none}.ppid-icon{width:56px;height:56px;background:var(--primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:24px}.ppid h2{font-size:32px;font-weight:800;color:#fff;margin-bottom:12px;line-height:1.2}.ppid-desc{font-size:15px;color:#94a3b8;line-height:1.7;margin-bottom:28px}.ppid-buttons{display:flex;gap:12px}.ppid-btn{padding:12px 24px;border-radius:var(--radius-lg);font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:var(--transition)}.ppid-btn-primary{background:#fff;color:var(--text-dark)}.ppid-btn-primary:hover{background:var(--primary-50);color:var(--primary)}.ppid-btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.ppid-btn-secondary:hover{background:#fff3}.ppid-card{background:#ffffff14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-xl);padding:32px;border:1px solid rgba(255,255,255,.1);position:relative;z-index:1}.ppid-card-badge{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#94a3b8;margin-bottom:12px}.ppid-card-badge:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.ppid-card h3{font-size:22px;font-weight:800;color:#fff;margin-bottom:12px}.ppid-card p{font-size:14px;color:#94a3b8;line-height:1.7}.footer{background:#fff;border-top:1px solid var(--border);padding:48px 0 24px}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:32px}.footer-brand h3{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:800;color:var(--text-dark);margin-bottom:12px}.footer-brand p{font-size:14px;color:var(--text-muted);line-height:1.7}.footer-col h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dark);margin-bottom:16px}.footer-col a{display:block;font-size:14px;color:var(--text-muted);padding:4px 0;transition:var(--transition)}.footer-col a:hover{color:var(--primary)}.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-muted)}.footer-bottom-links{display:flex;gap:24px}.footer-bottom-links a{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500;transition:var(--transition)}.footer-bottom-links a:hover{color:var(--primary)}.data-table-container{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:14px 20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border)}.data-table td{padding:14px 20px;font-size:14px;color:var(--text-dark);border-bottom:1px solid var(--border)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--primary-50)}.link-btn{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--primary);transition:var(--transition);cursor:pointer}.link-btn:hover{gap:10px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;gap:16px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:var(--text-muted)}.error-container{text-align:center;padding:60px 20px}.error-icon{width:64px;height:64px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--red)}.error-title{font-size:18px;font-weight:700;color:var(--text-dark);margin-bottom:8px}.error-message{font-size:14px;color:var(--text-muted);margin-bottom:16px}.retry-btn{background:var(--primary);color:#fff;padding:10px 24px;border-radius:var(--radius-full);font-size:14px;font-weight:600;transition:var(--transition)}.retry-btn:hover{background:var(--primary-dark)}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.page-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:48px 0;color:#fff}.page-header-light{background:#fff;padding:60px 0;color:var(--text-dark);border-bottom:1px solid var(--border);box-shadow:0 4px 6px -1px #0000000d}.page-header h1{font-size:32px;font-weight:800;margin-bottom:8px}.page-header-light h1{color:var(--text-dark);font-size:36px;letter-spacing:-.5px}.page-header p{font-size:16px;opacity:.85}.page-header-light p{color:var(--text-muted);opacity:1}.search-bar{display:flex;gap:12px;margin-bottom:24px}.search-input{flex:1;padding:12px 20px;border:1px solid var(--border);border-radius:var(--radius-lg);font-size:14px;background:#fff;transition:var(--transition)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-btn{background:var(--primary);color:#fff;padding:12px 24px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;transition:var(--transition)}.search-btn:hover{background:var(--primary-dark)}.pagination{display:flex;justify-content:center;gap:8px;margin-top:32px}.page-btn{padding:8px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:600;color:var(--text-muted);background:#fff;border:1px solid var(--border);transition:var(--transition)}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.login-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:40px 20px}.login-card{background:#fff;border-radius:var(--radius-2xl);padding:48px;width:100%;max-width:420px;box-shadow:var(--shadow-xl);border:1px solid var(--border)}.login-card h1{font-size:28px;font-weight:800;text-align:center;margin-bottom:8px}.login-card p{text-align:center;font-size:14px;color:var(--text-muted);margin-bottom:32px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-dark);margin-bottom:6px}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-lg);font-size:14px;transition:var(--transition)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-submit{width:100%;padding:14px;background:var(--primary);color:#fff;border-radius:var(--radius-lg);font-size:15px;font-weight:700;transition:var(--transition);margin-top:8px}.form-submit:hover{background:var(--primary-dark)}.form-error{text-align:center;color:var(--red);font-size:13px;margin-top:12px}.about-hero{background:#0f172a;min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;overflow:hidden}.about-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(37,99,235,.1),transparent 70%);pointer-events:none}.about-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff1a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:6px 16px;border-radius:var(--radius-full);font-size:11px;font-weight:700;color:#94a3b8;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:24px;border:1px solid rgba(255,255,255,.1)}.about-hero h1{font-size:44px;font-weight:800;line-height:1.1;margin-bottom:24px;max-width:800px;margin-left:auto;margin-right:auto}.about-hero h1 span{color:var(--primary-light);display:block}.about-hero p{font-size:16px;color:#94a3b8;max-width:650px;margin:0 auto;line-height:1.7}.principles-section{padding:80px 0;margin-top:-60px;position:relative;z-index:10}.principles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.principle-card{background:#fff;border-radius:var(--radius-xl);padding:40px 32px;box-shadow:var(--shadow-lg);border:1px solid var(--border);transition:var(--transition)}.principle-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.principle-icon{width:48px;height:48px;background:var(--primary-50);color:var(--primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:24px}.principle-card h3{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text-dark)}.principle-card p{font-size:14px;color:var(--text-muted);line-height:1.6}.regulasi-container{background:#f8fafc;border-radius:var(--radius-2xl);padding:60px;border:1px solid #e1e7ef;margin-bottom:80px}.regulasi-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px}.regulasi-header h2{font-size:32px;font-weight:800;color:var(--text-dark)}.regulasi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.regulasi-card{background:#fff;border-radius:var(--radius-xl);padding:32px;border:1px solid var(--border);display:flex;gap:24px;transition:var(--transition)}.regulasi-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.regulasi-icon{width:56px;height:56px;background:var(--text-dark);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.regulasi-badge{display:inline-block;padding:2px 8px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;border-radius:4px;margin-bottom:8px;text-transform:uppercase}.regulasi-card h4{font-size:16px;font-weight:700;margin-bottom:12px;line-height:1.4}.regulasi-card p{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:20px}.regulasi-download{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.walidata-banner{background:var(--primary);border-radius:var(--radius-xl);padding:32px 40px;display:flex;justify-content:space-between;align-items:center;color:#fff;margin-top:40px}.walidata-info{display:flex;align-items:center;gap:24px}.walidata-icon{width:48px;height:48px;background:#fff3;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.page-header{padding:60px 0;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;margin-bottom:0;position:relative;overflow:hidden}.page-header:after{content:"";position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;transform:translate(100px,-100px)}.page-header h1{font-size:36px;font-weight:800;margin-bottom:12px;max-width:800px;line-height:1.2}.page-header p{font-size:16px;color:#ffffffe6;max-width:700px;line-height:1.6}.metadata-card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border);padding:24px;height:100%}.metadata-item{display:flex;align-items:center;gap:12px;margin-bottom:16px}.metadata-item:last-child{margin-bottom:0}.metadata-icon{width:40px;height:40px;border-radius:10px;background:var(--primary-50);color:var(--primary);display:flex;align-items:center;justify-content:center}.metadata-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.metadata-value{font-size:14px;font-weight:600;color:var(--text-dark)}.walidata-text h3{font-size:18px;font-weight:700;margin-bottom:4px}.walidata-text p{font-size:14px;opacity:.8}.walidata-btn{background:#fff;color:var(--primary);padding:12px 24px;border-radius:var(--radius-lg);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:var(--transition)}.walidata-btn:hover{background:var(--primary-50);transform:scale(1.05)}.hide-on-mobile{display:block}.show-only-mobile{display:none!important}@media(max-width:1024px){.hide-on-mobile{display:none!important}.show-only-mobile{display:block!important}}@media(max-width:1200px){.container{padding:0 20px}}@media(max-width:1024px){.categories-grid{grid-template-columns:repeat(3,1fr)}.spm-layout{grid-template-columns:1fr;gap:24px}.stats-layout{grid-template-columns:1fr}.ppid{grid-template-columns:1fr;padding:40px;gap:32px}.footer-grid,.principles-grid{grid-template-columns:repeat(2,1fr)}.regulasi-grid{grid-template-columns:1fr}.admin-sidebar{width:280px;height:100vh;position:fixed;left:-280px;top:0;bottom:0;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-xl);z-index:50}.admin-sidebar.open{transform:translate(280px)}.sidebar-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:45;opacity:0;visibility:hidden;transition:all .3s ease}.sidebar-overlay.open{opacity:1;visibility:visible}.admin-main{width:100%!important;margin-left:0!important}.admin-topbar{padding:0 16px;height:64px;justify-content:space-between}.admin-content{padding:20px}}@media(max-width:1024px){.section{padding:48px 0}.navbar-links{display:none}.navbar-links.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:#fff;padding:20px;border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);gap:12px}.navbar-mobile-toggle{display:block}.hero{padding:60px 0;min-height:auto}.hero h1{font-size:36px}.stats-bar{grid-template-columns:repeat(2,1fr);gap:12px}.stat-item{padding:16px}.categories-grid{grid-template-columns:repeat(2,1fr);gap:12px}.section-header{flex-direction:column;align-items:flex-start;gap:16px}.section-title{font-size:26px}.macro-value{font-size:32px}.dataset-item{padding:16px}.ppid{padding:32px 24px;margin:24px 0;text-align:center}.ppid-icon{margin:0 auto 20px}.ppid-buttons{flex-direction:column;width:100%}.ppid-btn{width:100%}.footer-grid{grid-template-columns:1fr;gap:40px}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.admin-page-header h1{font-size:24px}.admin-search-bar{flex-direction:column;padding:16px}}@media(max-width:480px){.hero h1{font-size:28px}.hero-search{flex-direction:column;border-radius:var(--radius-lg)}.hero-search input{width:100%}.hero-search button{width:calc(100% - 8px);justify-content:center;margin:4px}.stats-bar,.categories-grid{grid-template-columns:1fr}.stat-item{padding:12px}.dataset-meta{gap:8px}.modal-content{max-width:100%;margin:0;border-radius:var(--radius-xl)}.login-modal-inner{padding:24px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;width:100%;max-width:420px;border-radius:var(--radius-2xl);position:relative;box-shadow:var(--shadow-xl);animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text-light);cursor:pointer;z-index:10;transition:var(--transition)}.modal-close:hover{color:var(--text-dark)}.login-modal-inner{padding:32px}.login-modal-header{text-align:center;margin-bottom:24px}.login-modal-header h2{font-size:24px;font-weight:800;color:var(--text-dark);margin-bottom:4px}.login-modal-header p{font-size:13px;color:var(--text-muted)}.demo-account-badge{background:#eff6ff;border:1px solid #dbeafe;border-radius:var(--radius-lg);padding:16px;margin-bottom:24px;font-size:13px}.demo-account-badge-header{display:flex;align-items:center;gap:8px;color:var(--primary);font-weight:700;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.demo-account-info{color:var(--primary);line-height:1.5}.demo-account-info b{font-weight:700}.form-group-with-icon{margin-bottom:20px}.input-with-icon{position:relative}.input-with-icon i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-light)}.input-with-icon input{padding-left:48px}.forgot-password{display:block;text-align:right;font-size:13px;font-weight:600;color:var(--primary);margin-top:-12px;margin-bottom:24px}.separator{display:flex;align-items:center;text-align:center;margin:24px 0;font-size:12px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:1px}.separator:before,.separator:after{content:"";flex:1;border-bottom:1px solid var(--border)}.separator:not(:empty):before{margin-right:16px}.separator:not(:empty):after{margin-left:16px}.login-modal-inner .form-label{font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:8px;display:block}.social-login{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.modal-footer-link{text-align:center;font-size:12px;color:var(--text-muted);margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.modal-footer-link a{color:var(--primary);font-weight:700}.navbar-user-container{position:relative;z-index:1001}.navbar-user{display:flex;align-items:center;gap:10px;padding:5px 14px 5px 6px;border:1.5px solid #d1d5db;border-radius:9999px;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.navbar-user:hover{border-color:#9ca3af;background:#f9fafb;box-shadow:0 1px 2px #0000000d}.navbar-user.open{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.user-avatar{width:30px;height:30px;background:var(--primary);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-avatar i{display:flex;align-items:center;justify-content:center}.user-name{font-size:14px;font-weight:600;color:#1f2937;white-space:nowrap}.user-dropdown-arrow{color:#6b7280;transition:transform .2s ease;margin-left:2px}.navbar-user.open .user-dropdown-arrow{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:220px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000000d;padding:8px;display:flex;flex-direction:column;animation:dropdownSlideIn .2s cubic-bezier(.16,1,.3,1);transform-origin:top right}@keyframes dropdownSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;font-size:14.5px;font-weight:600;color:#374151;transition:all .15s ease;cursor:pointer;border:1px solid transparent}.dropdown-item:hover{background:#f3f4f6;color:#111827}.dropdown-item i{display:flex;align-items:center;justify-content:center;color:#6b7280;transition:color .15s ease}.dropdown-item:hover i{color:#111827}.dropdown-divider{height:1px;background:#f3f4f6;margin:6px 8px}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout i{color:#f87171}.dropdown-item.logout:hover{background:#fef2f2;color:#dc2626;border-color:#fee2e2}.dropdown-item.logout:hover i{color:#dc2626}.admin-layout{display:flex;min-height:100vh;background-color:#f8fafc}@media(max-width:1024px){.admin-layout{flex-direction:column}}.admin-sidebar{width:280px;height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;transition:var(--transition);z-index:50}@media(max-width:1024px){.admin-sidebar{order:2;width:100%;height:auto;max-height:0;overflow:hidden;position:relative;border-right:none;border-bottom:1px solid transparent;transition:max-height .4s ease-in-out,border-color .4s ease-in-out}.admin-sidebar.open{max-height:calc(100vh - 72px);border-bottom-color:var(--border);overflow-y:auto}}.sidebar-header{padding:24px;display:flex;align-items:center;gap:12px}@media(max-width:1024px){.sidebar-header{display:none}}.sidebar-header-text{display:flex;flex-direction:column}.sidebar-title{font-size:18px;font-weight:800;color:var(--text-dark);line-height:1.2}.sidebar-subtitle{font-size:11px;color:var(--text-muted);font-weight:500}.sidebar-section-label{padding:0 24px;margin-top:12px;margin-bottom:8px;font-size:10px;font-weight:700;color:#94a3b8;letter-spacing:1px;text-transform:uppercase}.sidebar-menu{flex:1;padding:0 12px;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#64748b;border-radius:12px;font-size:14px;font-weight:600;transition:var(--transition);margin-bottom:2px;text-decoration:none}.sidebar-item:hover{background:#f8fafc;color:var(--primary)}.sidebar-item.active,.sidebar-item.active-group{background:#0f172a;color:#fff}.sidebar-item.active-group{border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}.sidebar-submenu{background:#f8fafc;border-bottom-left-radius:12px;border-bottom-right-radius:12px;padding:8px 0;margin-bottom:8px}.sidebar-subitem{display:flex;align-items:center;padding:10px 16px 10px 48px;color:#64748b;font-size:13px;font-weight:600;transition:var(--transition);text-decoration:none}.sidebar-subitem:hover{color:var(--primary)}.sidebar-subitem.active{color:var(--primary);background:#eff6ff}.sidebar-footer{padding:24px 12px;border-top:1px solid #f1f5f9}.sidebar-item.logout{margin-top:12px;color:#ef4444;text-transform:uppercase;font-size:12px;letter-spacing:.5px}.sidebar-item.logout:hover{background:#fef2f2}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}@media(max-width:1024px){.admin-main{display:contents}}.admin-topbar{height:72px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:60}@media(max-width:1024px){.admin-topbar{order:1;padding:0 16px}}.admin-topbar-left{display:flex;align-items:center;gap:16px}.admin-mobile-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:8px;margin-left:-8px;border-radius:var(--radius-md);transition:var(--transition)}.admin-mobile-toggle:hover{background:var(--bg);color:var(--primary)}@media(max-width:1024px){.admin-mobile-toggle{display:flex;align-items:center;justify-content:center}}.admin-topbar-brand{display:flex;align-items:center;gap:12px}.brand-text{display:flex;flex-direction:column}.brand-title{font-size:16px;font-weight:800;color:var(--text-dark);line-height:1.2}.brand-subtitle{font-size:11px;color:var(--text-muted);font-weight:500}.topbar-actions{display:flex;align-items:center;gap:24px;margin-left:auto}.topbar-btn{background:none;border:none;color:var(--text-muted);position:relative;cursor:pointer;padding:8px;border-radius:var(--radius-md);transition:var(--transition);display:flex;align-items:center;justify-content:center}.topbar-btn:hover{background:var(--bg);color:var(--primary)}.notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--red);border:2px solid white;border-radius:50%}.topbar-user{display:flex;align-items:center;gap:12px}.user-details{text-align:right}.user-name{font-size:14px;font-weight:700;color:var(--text-dark)}.user-role{font-size:12px;color:var(--text-muted)}.user-avatar-small{width:38px;height:38px;background:var(--primary-50);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary);border:1px solid var(--primary-100)}.admin-content{padding:32px;flex:1}@media(max-width:1024px){.admin-content{order:3;padding:20px}}.admin-page-header{margin-bottom:32px}.admin-page-header h1{font-size:28px;font-weight:800;color:var(--text-dark);margin-bottom:8px;letter-spacing:-.5px}.breadcrumb{display:flex;gap:8px;font-size:13px;color:var(--text-muted);align-items:center;font-weight:500;margin-bottom:4px}.admin-card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.admin-search-bar{display:flex;gap:16px;padding:24px}.admin-table-container{overflow-x:auto;margin-top:16px;border-radius:var(--radius-lg);-webkit-overflow-scrolling:touch}.admin-table-container::-webkit-scrollbar{height:6px}.admin-table-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:16px 24px;white-space:nowrap}.admin-table td{padding:16px 24px;white-space:normal;overflow-wrap:break-word;word-break:break-word;max-width:400px;min-width:120px}@media(max-width:768px){.admin-table th,.admin-table td{padding:12px 16px;font-size:13px}}.admin-table th{background:#f8fafc;padding:16px 24px;text-align:left;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border)}.admin-table td{padding:20px 24px;border-bottom:1px solid #f1f5f9;font-size:14px;color:var(--text-dark)}.admin-table tr:hover td{background:#f8fafc}.admin-card-dark{background:#0f172a!important;color:#f1f5f9!important;border:1px solid #1e293b!important}.admin-card-dark .admin-table tr:hover td{background:#1e293b!important}.admin-card-dark h2{color:#f8fafc!important}.admin-card-dark .admin-table th{background:transparent!important;color:#94a3b8!important;border-bottom:1px solid #1e293b!important}.admin-card-dark .admin-table td{color:#f1f5f9!important;border-bottom:1px solid #1e293b!important}.action-btn{padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:#64748b;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center}.action-btn:hover{background:#f1f5f9;color:var(--text-dark)}.action-btn.edit:hover{color:var(--primary);background:var(--primary-50);border-color:var(--primary-100)}.action-btn.delete:hover{color:#ef4444;background:#fef2f2;border-color:#fee2e2}.form-container{max-width:800px;margin:0 auto}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:24px}.form-full{grid-column:span 2}.form-section{padding:24px;border-bottom:1px solid #f1f5f9}.form-section-title{font-size:16px;font-weight:700;color:var(--text-dark);margin-bottom:4px}.form-section-desc{font-size:13px;color:var(--text-muted);margin-bottom:20px}.variable-row{display:grid;grid-template-columns:1fr 1fr 1fr 40px;gap:12px;margin-bottom:12px;align-items:end}.modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:modalFadeIn .3s ease}.modal-container{background:#fff;width:100%;max-width:600px;max-height:90vh;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideUp .3s ease}.profile-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;align-items:start}@media(max-width:1024px){.profile-grid{grid-template-columns:1fr}}.profile-sidebar{grid-column:span 4}.profile-main{grid-column:span 8;display:flex;flex-direction:column;gap:24px}@media(max-width:1024px){.profile-sidebar,.profile-main{grid-column:span 1}}.modal-container{background:#fff;width:100%;max-width:500px;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;animation:modalSlideUp .3s ease}.modal-header{background:#1e293b;color:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between}.modal-header-title{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:700}.modal-body{padding:24px}.modal-footer{padding:12px 24px 24px;display:flex;gap:10px;justify-content:center}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group-full{grid-column:span 2}.form-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:8px}.form-input-premium{width:100%;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;font-size:14px;color:var(--text-dark);transition:all .2s}.form-input-premium:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.form-input-premium::placeholder{color:var(--text-light);font-style:italic}.btn-premium-primary{background:var(--primary);color:#fff;padding:12px 24px;border-radius:12px;font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px;transition:all .2s}.btn-premium-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb33}.btn-premium-outline{background:#fff;color:var(--text-muted);padding:12px 24px;border-radius:12px;font-weight:700;font-size:14px;transition:all .2s}.btn-premium-outline:hover{background:#f8fafc;color:var(--text-dark)}.admin-header-row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}@media(max-width:640px){.admin-header-row{flex-direction:column;align-items:stretch}.form-grid{grid-template-columns:1fr}.form-group-full{grid-column:span 1}.modal-footer{flex-direction:column;padding:12px 20px 20px}.modal-footer button{width:100%;justify-content:center}}.status-badge{padding:4px 12px;border-radius:9999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#f0fdf4;color:#16a34a}.status-badge.inactive{background:#fef2f2;color:#dc2626}.status-badge.pending{background:#fffbeb;color:#d97706}.notification-wrapper{position:relative;display:inline-block}.notification-dropdown{position:absolute;top:calc(100% + 12px);right:-80px;width:320px;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;z-index:1000;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideUp .2s ease-out}@media(max-width:640px){.notification-dropdown{position:fixed;top:60px;left:10px;right:10px;width:auto}}.notification-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#f8fafc}.notification-header h3{font-size:14px;font-weight:700;color:var(--text-dark);margin:0}.clear-btn{background:transparent;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;border:1px solid transparent}.clear-btn:hover{background:#fee2e2;color:var(--red);border-color:#fecaca}.recharts-legend-item-text{color:#475569!important;font-weight:500;margin-left:4px}.recharts-legend-wrapper{padding-top:20px}.recharts-layer text{fill:#fff!important;font-size:12px;font-weight:600}.notification-list{max-height:400px;overflow-y:auto}.notification-item{padding:16px 20px;display:flex;gap:12px;border-bottom:1px solid #f1f5f9;transition:background .2s;cursor:default}.notification-item:hover{background:#f8fafc}.activity-icon-bg{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-create{background:var(--primary-50);color:var(--primary)}.action-update{background:#fffbeb;color:#d97706}.action-delete{background:#fef2f2;color:#dc2626}.activity-content{flex:1;min-width:0}.activity-text{font-size:13px;line-height:1.5;color:var(--text-dark);margin-bottom:4px}.activity-meta{display:flex;justify-content:space-between;align-items:center}.activity-entity{font-size:10px;font-weight:700;color:var(--text-muted);background:#f1f5f9;padding:2px 6px;border-radius:4px}.activity-time{font-size:11px;color:var(--text-muted)}.notification-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}.notification-footer{padding:12px;text-align:center;background:#f8fafc;border-top:1px solid var(--border)}.notification-footer button{font-size:13px;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer}.notification-footer button:hover{text-decoration:underline}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
