:root { --forest:#124a35; --leaf:#2f855a; --mist:#edf5ef; --ink:#12251c; }
* { -webkit-tap-highlight-color: transparent; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
body { min-width:320px; }
.app-content { min-height:calc(100vh - 72px); padding-bottom:calc(11rem + env(safe-area-inset-bottom)) !important; }
.safe-form-actions { position:sticky; z-index:20; bottom:calc(88px + env(safe-area-inset-bottom)); display:flex; justify-content:flex-end; border:1px solid #dce9e0; border-radius:14px; background:rgba(255,255,255,.96); padding:10px; box-shadow:0 10px 30px rgba(18,74,53,.12); backdrop-filter:blur(10px); }
.save-button { display:inline-flex; align-items:center; justify-content:center; border:1px solid #58a976; border-radius:12px; background:#b9dfc8; padding:11px 20px; color:#10261c; font-size:13px; font-weight:900; box-shadow:0 6px 16px rgba(18,74,53,.10); transition:.16s; }.save-button:hover { background:#8fc9a5; color:#071c12; }
.mountain-theme { background:linear-gradient(180deg,#dcebe0 0,#f4f8f5 230px,#f8faf9 100%); position:relative; }
.mountain-theme::before { content:""; position:fixed; inset:72px 0 auto; height:190px; pointer-events:none; opacity:.42; background:linear-gradient(145deg,transparent 33%,#8db79a 34% 50%,transparent 51%) 0 0/260px 150px,linear-gradient(215deg,transparent 37%,#b7d0bd 38% 52%,transparent 53%) 80px 5px/310px 175px; mask-image:linear-gradient(#000,transparent); }
.app-header { background:linear-gradient(135deg,#0b3324,#155c3f 60%,#287a52); color:#fff; box-shadow:0 8px 28px rgba(9,38,27,.22); }
.logo-shell { display:grid; place-items:center; width:46px; height:54px; flex:none; padding:0; border:0; border-radius:0; background:transparent; box-shadow:none; }
.logo-shell-lg { width:72px; height:88px; border-radius:0; }
.hero-mountain { position:relative; overflow:hidden; min-height:155px; padding:20px; border-radius:22px; background:linear-gradient(135deg,rgba(8,42,29,.98),rgba(25,101,67,.94)); color:#fff; box-shadow:0 14px 35px rgba(18,74,53,.18); }
.hero-mountain::before,.hero-mountain::after { content:""; position:absolute; pointer-events:none; }
.hero-mountain::before { right:-18px; bottom:-52px; width:230px; height:150px; opacity:.32; background:#90c3a0; clip-path:polygon(0 100%,38% 25%,55% 55%,72% 20%,100% 100%); }
.hero-mountain::after { inset:0; background:radial-gradient(circle at 85% 10%,rgba(255,255,255,.18),transparent 30%); }
.balance-chip { flex:none; min-width:112px; padding:11px 12px; border:1px solid rgba(255,255,255,.16); border-radius:15px; background:rgba(255,255,255,.11); color:#fff; backdrop-filter:blur(10px); }
.balance-chip span { display:block; font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:#c7e5d1; }
.balance-chip strong { display:block; margin-top:4px; font-size:13px; white-space:nowrap; }
.mini-stat { min-width:0; padding:10px 5px; border:1px solid rgba(37,110,73,.12); border-radius:14px; background:rgba(255,255,255,.9); text-align:center; box-shadow:0 5px 16px rgba(18,74,53,.06); }
.mini-stat p { overflow:hidden; margin:0; color:#64756c; font-size:9px; font-weight:700; white-space:nowrap; text-overflow:ellipsis; }
.mini-stat strong { display:block; margin-top:2px; color:var(--ink); font-size:20px; line-height:1.2; font-weight:900; }
.mini-stat small { display:block; color:#8b9a92; font-size:8px; font-weight:700; }
.section-heading { display:flex; align-items:end; justify-content:space-between; gap:12px; }
.eyebrow { font-size:9px; line-height:1rem; font-weight:900; text-transform:uppercase; letter-spacing:.18em; color:#287951; }
.section-title { margin-top:0; color:#10261c; font-size:18px; line-height:1.6rem; font-weight:900; }
.section-badge { flex:none; border:1px solid #c6dfce; border-radius:999px; background:#edf7f0; padding:5px 9px; color:#256b49; font-size:9px; font-weight:800; }
.service-app { display:flex; min-width:0; flex-direction:column; align-items:center; gap:6px; border:1px solid rgba(37,110,73,.10); border-radius:16px; background:rgba(255,255,255,.94); padding:10px 3px 9px; text-align:center; box-shadow:0 5px 15px rgba(18,74,53,.055); transition:.18s ease; }
.service-app:hover { transform:translateY(-2px); border-color:#9bc8aa; box-shadow:0 10px 24px rgba(18,74,53,.12); }
.service-app strong { max-width:100%; overflow:hidden; color:#273c31; font-size:9px; line-height:1.2; white-space:nowrap; text-overflow:ellipsis; }
.service-icon { display:grid; place-items:center; width:38px; height:38px; border-radius:13px; font-size:17px; font-weight:900; }
.service-blue{background:#e8f1ff;color:#2c65a7}.service-gold{background:#fff4d8;color:#a36806}.service-purple{background:#f0eafd;color:#7550a8}.service-red{background:#fdebea;color:#b3453e}.service-green{background:#def2e5;color:#257148}.service-cyan{background:#ddf3f2;color:#237b78}.service-orange{background:#fff0df;color:#ae6826}.service-pink{background:#fae9f0;color:#a84770}
.agenda-card { display:flex; align-items:center; gap:11px; min-width:0; border:1px solid rgba(37,110,73,.11); border-radius:16px; background:rgba(255,255,255,.94); padding:10px; box-shadow:0 5px 15px rgba(18,74,53,.05); }
.agenda-card time { display:grid; width:42px; height:45px; flex:none; place-content:center; border-radius:12px; background:#e1f0e6; text-align:center; color:#1e6947; }
.agenda-card time strong { font-size:17px; line-height:1; }.agenda-card time span { margin-top:2px; font-size:8px; font-weight:900; text-transform:uppercase; }
.agenda-card h4 { overflow:hidden; color:#16291f; font-size:12px; font-weight:850; white-space:nowrap; text-overflow:ellipsis; }.agenda-card p { overflow:hidden; margin-top:3px; color:#718078; font-size:9px; white-space:nowrap; text-overflow:ellipsis; }
.news-section { padding-bottom:96px; }
.empty-state { border:1px dashed #bdd7c5; border-radius:16px; padding:25px; background:rgba(255,255,255,.65); text-align:center; color:#809087; font-size:11px; }
.scroll-section { scroll-margin-top:90px; }
.floating-dock { position:fixed; z-index:50; left:50%; bottom:max(12px,env(safe-area-inset-bottom)); display:grid; width:calc(100% - 24px); max-width:500px; grid-template-columns:repeat(5,1fr); transform:translateX(-50%); border:1px solid rgba(255,255,255,.18); border-radius:22px; background:rgba(10,47,33,.96); color:#fff; padding:7px 5px 6px; box-shadow:0 18px 45px rgba(8,35,25,.32); backdrop-filter:blur(18px); }
.dock-item { position:relative; display:flex; min-width:0; flex-direction:column; align-items:center; gap:3px; border:0; border-radius:16px; background:transparent; padding:5px 2px 4px; color:#a9c9b4; cursor:pointer; transition:.18s; }
.dock-item svg { width:20px; height:20px; fill:none; stroke:currentColor; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; }
.dock-item span { overflow:hidden; max-width:100%; font-size:8px; font-weight:750; white-space:nowrap; text-overflow:ellipsis; }
.dock-item.active,.dock-item:hover { background:rgba(255,255,255,.12); color:#fff; }
.dock-item.active::before { content:""; position:absolute; top:-8px; width:20px; height:3px; border-radius:999px; background:#8fd3a5; }
.card { border:1px solid rgba(37,110,73,.12); border-radius:17px; background:rgba(255,255,255,.95); box-shadow:0 7px 22px rgba(18,74,53,.055); }
.label { display:block; margin-bottom:.4rem; color:#354b40; font-size:.76rem; font-weight:750; }
.input { width:100%; border:1px solid #c7d8cd; border-radius:.8rem; background:#fff; padding:.68rem .8rem; color:#15291f; outline:none; transition:.15s; }
.input:focus { border-color:#39875d; box-shadow:0 0 0 3px rgba(47,133,90,.12); }
.password-field { position:relative; display:block; }.password-field button { position:absolute; top:50%; right:8px; transform:translateY(-50%); border:0; border-radius:8px; background:#e5f1e9; padding:5px 7px; color:#236944; font-size:9px; font-weight:900; cursor:pointer; }.password-field button:hover { background:#cfe5d6; color:#174f34; }
.alert { border-width:1px; border-radius:13px; padding:.75rem .9rem; font-size:.8rem; font-weight:650; }
.status-pill { display:inline-flex; border-radius:999px; background:#edf5ef; padding:.22rem .55rem; color:#355b45; font-size:.68rem; font-weight:800; text-transform:capitalize; }
.modal { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; overflow:hidden; padding:calc(84px + env(safe-area-inset-top)) 12px calc(100px + env(safe-area-inset-bottom)); }
.modal.hidden { display:none; }.modal-backdrop { position:absolute; inset:0; background:rgba(5,27,19,.68); backdrop-filter:blur(5px); }
.modal-panel { position:relative; z-index:1; max-height:100%; width:100%; max-width:46rem; overflow-y:auto; overscroll-behavior:contain; border-radius:1.35rem; background:#fff; box-shadow:0 30px 80px rgba(2,30,19,.28); }
.modal-panel form { padding-bottom:max(1rem,env(safe-area-inset-bottom)); }
body.modal-open .floating-dock,body.modal-open .app-header { pointer-events:none; }
#profileModal .modal-panel { max-width:430px; }.profile-cover { display:flex; height:115px; align-items:center; justify-content:center; background:linear-gradient(145deg,#0b3827,#26734d); }
.profile-cover { color:#fff; }
.wa-button { display:inline-flex; align-items:center; gap:6px; border-radius:999px; background:#147a45; padding:6px 10px; color:#fff; font-size:11px; font-weight:800; line-height:1; white-space:nowrap; box-shadow:0 5px 14px rgba(20,122,69,.18); transition:.16s; }
.wa-button:hover { background:#0b5e34; color:#fff; transform:translateY(-1px); }
.wa-button svg { width:16px; height:16px; flex:none; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.registration-header { display:flex; align-items:center; gap:16px; padding:20px; background:linear-gradient(135deg,#0b3827,#24734c); color:#fff; }
.registration-back { display:grid; width:36px; height:36px; flex:none; place-items:center; border:1px solid rgba(255,255,255,.2); border-radius:12px; background:rgba(255,255,255,.1); color:#fff; font-size:20px; font-weight:900; }
.area-requirement { display:flex; flex-direction:column; gap:3px; border:1px solid #b8dcc5; border-radius:14px; background:#eff8f2; padding:12px 14px; color:#185a3b; }
.area-requirement span { font-size:9px; font-weight:900; text-transform:uppercase; letter-spacing:.15em; }.area-requirement strong { font-size:12px; }
.manual-ktp-upload { border:1px solid #c7dbce; border-radius:18px; background:#f5faf7; padding:14px; }
.consent-box { display:flex; align-items:flex-start; gap:9px; border-radius:14px; background:#f1f5f3; padding:12px; color:#52645a; font-size:10px; line-height:1.5; }.consent-box input { margin-top:2px; accent-color:#1c7049; }
.registration-review-card { border:1px solid #cbded1; border-radius:17px; background:rgba(255,255,255,.96); padding:15px; box-shadow:0 7px 22px rgba(18,74,53,.06); }
.review-status { border-radius:999px; padding:5px 9px; font-size:9px; font-weight:900; text-transform:uppercase; }.review-status.pending{background:#fff2cf;color:#976300}.review-status.approved{background:#dcf4e4;color:#17643c}.review-status.rejected{background:#fee2e2;color:#a92929}
.review-grid { display:grid; gap:10px; margin-top:14px; }.review-grid dt { color:#829087; font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; }.review-grid dd { margin-top:2px; color:#263a2f; font-size:11px; font-weight:650; }
.review-button { display:inline-flex; flex:none; align-items:center; justify-content:center; border-radius:11px; padding:10px 13px; font-size:10px; font-weight:900; }.review-button.photo{border:1px solid #b9d6c3;background:#eff8f2;color:#1a6844}.review-button.approve{border:0;background:#176b44;color:#fff}.review-button.reject{border:0;background:#9f2f2f;color:#fff}
.news-slider { display:flex; gap:12px; overflow-x:auto; padding:2px 2px 12px; scroll-behavior:smooth; scroll-snap-type:x mandatory; scrollbar-width:none; }.news-slider::-webkit-scrollbar{display:none}.news-slide { min-width:84%; overflow:hidden; scroll-snap-align:start; border:1px solid rgba(37,110,73,.12); border-radius:18px; background:#fff; box-shadow:0 8px 24px rgba(18,74,53,.08); }.news-slide>img { width:100%; height:155px; object-fit:cover; background:#dce9df; }.news-slide-body { padding:13px; }.news-slide-body time,.news-list-card time { color:#75867c; font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; }.news-slide-body h4 { margin-top:4px; color:#172b20; font-size:14px; font-weight:900; }.news-slide-body p { display:-webkit-box; overflow:hidden; margin-top:5px; color:#63746a; font-size:10px; line-height:1.55; -webkit-box-orient:vertical; -webkit-line-clamp:3; }.news-nav { display:grid; width:28px; height:28px; place-items:center; border:1px solid #c7ddce; border-radius:9px; background:#fff; color:#236b47; font-size:13px; font-weight:900; }
.news-list-card { display:grid; overflow:hidden; border:1px solid #cbded1; border-radius:18px; background:#fff; box-shadow:0 7px 22px rgba(18,74,53,.06); }.news-list-card>img { width:100%; height:180px; object-fit:cover; background:#dce9df; }.news-list-card>div { padding:15px; }.news-list-card h3 { color:#172b20; font-size:16px; font-weight:900; }.news-list-card p { margin-top:8px; color:#566a5e; font-size:11px; line-height:1.65; }
@media (min-width:640px) { .review-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.registration-header{padding:25px 30px}.news-slide{min-width:360px}.news-slide>img{height:190px} }
@media (min-width:640px) { .hero-mountain{min-height:190px;padding:30px}.mini-stat{padding:15px}.mini-stat p{font-size:11px}.mini-stat strong{font-size:26px}.mini-stat small{font-size:9px}.service-app{padding:15px 6px}.service-icon{width:46px;height:46px}.service-app strong{font-size:11px}.section-title{font-size:22px}.floating-dock{bottom:20px}.balance-chip{min-width:145px;padding:15px}.balance-chip strong{font-size:17px} }
@media (max-width:640px) { .modal{align-items:stretch;padding:calc(78px + env(safe-area-inset-top)) 8px calc(92px + env(safe-area-inset-bottom))}.modal-panel{max-height:100%;border-radius:1.15rem}.hero-mountain{min-height:145px}.card{border-radius:14px} }

/* Tema Kota: biru modern. Tema Kabupaten tetap memakai hijau pegunungan di atas. */
.city-theme { --forest:#173f79; --leaf:#2563a9; --mist:#edf5ff; --ink:#14243a; background:linear-gradient(180deg,#dbeafe 0,#f3f7fd 230px,#f8fafc 100%); }
.city-theme::before { opacity:.38; background:linear-gradient(145deg,transparent 33%,#8db6e8 34% 50%,transparent 51%) 0 0/260px 150px,linear-gradient(215deg,transparent 37%,#bfd4ee 38% 52%,transparent 53%) 80px 5px/310px 175px; }
.city-theme .app-header { background:linear-gradient(135deg,#102f5e,#1c5798 60%,#347fc1); box-shadow:0 8px 28px rgba(15,47,90,.24); }
.city-theme .hero-mountain { background:linear-gradient(135deg,rgba(15,43,83,.98),rgba(30,101,164,.94)); box-shadow:0 14px 35px rgba(23,63,121,.18); }
.city-theme .hero-mountain::before { background:#8bbce6; }
.city-theme .floating-dock { background:rgba(15,45,84,.96); box-shadow:0 18px 45px rgba(10,35,69,.34); }
.city-theme .dock-item { color:#b5d0ea; }
.city-theme .dock-item.active::before { background:#80bfff; }
.city-theme .profile-cover,.city-theme .registration-header { background:linear-gradient(145deg,#123566,#2877b8); }
.city-theme .eyebrow { color:#2563a9; }
.city-theme .section-title { color:#14243a; }
.city-theme .section-badge { border-color:#bdd5ee; background:#eef6ff; color:#235f99; }
.city-theme .card,.city-theme .service-app,.city-theme .agenda-card,.city-theme .news-slide,.city-theme .news-list-card { border-color:rgba(37,99,169,.14); box-shadow:0 7px 22px rgba(23,63,121,.07); }
.city-theme .service-app:hover { border-color:#92bce4; box-shadow:0 10px 24px rgba(23,63,121,.13); }
.city-theme .agenda-card time { background:#e2effc; color:#225f9b; }
.city-theme .empty-state { border-color:#b9d0e8; color:#71869b; }
.city-theme .safe-form-actions { border-color:#d8e5f1; box-shadow:0 10px 30px rgba(23,63,121,.12); }
.city-theme .save-button { border-color:#60a5fa; background:#bfdbfe; color:#132a46; box-shadow:0 6px 16px rgba(23,63,121,.11); }
.city-theme .save-button:hover { background:#93c5fd; color:#0c2038; }
.city-theme .input { border-color:#c6d7e8; color:#14243a; }
.city-theme .input:focus { border-color:#3b82c4; box-shadow:0 0 0 3px rgba(37,99,169,.13); }
.city-theme .password-field button { background:#e5eff9; color:#245f98; }
.city-theme .area-requirement,.city-theme .manual-ktp-upload { border-color:#bdd4ea; background:#f1f7fd; color:#1e568d; }
.city-theme .registration-review-card { border-color:#c7d8e9; box-shadow:0 7px 22px rgba(23,63,121,.07); }
.city-theme .news-nav { border-color:#c3d7eb; color:#245f98; }
