@font-face{font-family:Questrial;src:url('../branding/font-dsv/Questrial-Regular.ttf') format('truetype');font-display:swap}
@font-face{font-family:MontserratExtra;src:url('../branding/font-dsv/MontserratExtraBold.otf') format('opentype');font-display:swap}
:root{--bg:#f7fbfa;--surface:#fff;--text:#102220;--muted:#5c726d;--line:#dce8e3;--teal:#006c68;--green:#35b86f;--gold:#e5b84d;--max:1160px;--shadow:0 24px 70px rgba(7,55,50,.13)}
body[data-theme=dark]{--bg:#071f1f;--surface:#0d2a28;--text:#eefbf7;--muted:#9fbbb4;--line:#23413d;--teal:#42d1c8;--green:#62d990;--shadow:0 24px 70px rgba(0,0,0,.28)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:Questrial,Arial,sans-serif;line-height:1.65;transition:background-color .2s,color .2s}a{color:inherit}.site-header{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 max(22px,calc((100% - var(--max))/2));background:color-mix(in srgb,var(--bg) 90%,transparent);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand img{width:48px;height:48px;border-radius:8px;object-fit:cover}.brand strong,.brand small{display:block}.brand strong{font-family:MontserratExtra}.brand small{color:var(--muted);font-size:12px}nav{display:flex;gap:24px;color:var(--muted);font-size:14px}nav a{text-decoration:none}nav a:hover{color:var(--teal)}.header-actions{display:flex;align-items:center;gap:10px}.theme-toggle,.menu-button{min-height:42px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);font:inherit;font-weight:800;cursor:pointer}.theme-toggle{display:inline-flex;align-items:center;gap:8px;padding:0 12px;font-size:12px}.theme-toggle span{font-size:15px}.menu-button{display:none;width:42px;padding:9px}.menu-button span{display:block;height:2px;background:var(--text);margin:5px 0}
.hero{width:min(var(--max),calc(100% - 44px));min-height:620px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:46px;align-items:center;background:linear-gradient(90deg,color-mix(in srgb,var(--bg) 98%,transparent),color-mix(in srgb,var(--bg) 72%,transparent)),url('../branding/bcg-light.png') center/cover}.hero h1{font-family:MontserratExtra;font-size:clamp(44px,6vw,82px);line-height:1;margin:0 0 22px;max-width:760px}.hero p{color:var(--muted);font-size:18px;max-width:680px;margin:0}.hero-actions{display:flex;gap:12px;margin-top:32px}.button{min-height:48px;border-radius:8px;padding:0 18px;display:inline-flex;align-items:center;text-decoration:none;font-weight:800;border:1px solid var(--line)}.button.primary{background:var(--teal);border-color:var(--teal);color:#052321}.button.secondary{background:var(--surface);color:var(--teal)}.hero-card{padding:28px;border-radius:8px;background:color-mix(in srgb,var(--surface) 88%,transparent);border:1px solid var(--line);box-shadow:var(--shadow)}.hero-card span{color:var(--green);font-weight:800;font-size:12px}.hero-card strong{display:block;font-family:MontserratExtra;font-size:28px;line-height:1.1;margin:18px 0 10px}.section,.services,.apps{width:min(var(--max),calc(100% - 44px));margin:70px auto}.section{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center}.section h2,.services h2,.apps h2{font-family:MontserratExtra;font-size:clamp(32px,4vw,54px);line-height:1.05;margin:0 0 14px}.section p{color:var(--muted);margin:0}.section img{width:100%;border-radius:8px;box-shadow:var(--shadow)}.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.service-grid article{padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:8px}.service-grid h3{font-family:MontserratExtra;margin:0 0 28px}.service-grid p{color:var(--muted);margin:0}.app-list{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.app-list a{min-height:86px;display:grid;place-items:center;text-align:center;text-decoration:none;font-family:MontserratExtra;background:var(--surface);border:1px solid var(--line);border-radius:8px}.app-list a:hover{border-color:var(--teal);color:var(--teal)}footer{padding:34px max(22px,calc((100% - var(--max))/2));display:flex;justify-content:space-between;gap:28px;background:var(--surface);border-top:1px solid var(--line);color:var(--muted)}footer strong{font-family:MontserratExtra;color:var(--text)}footer p{margin:5px 0 0}
@media(max-width:900px){.site-header{flex-wrap:wrap;padding-top:12px;padding-bottom:12px}nav{display:none;order:4;width:100%;flex-direction:column;gap:8px;padding:8px 0 4px}.site-header.nav-open nav{display:flex}.menu-button{display:block}.theme-toggle b{display:none}.hero,.section{grid-template-columns:1fr}.hero{padding:48px 0}.hero-card{max-width:520px}.service-grid,.app-list{grid-template-columns:1fr 1fr}.section img{max-width:520px}}
@media(max-width:560px){.site-header{padding-left:16px;padding-right:16px}.brand small{display:none}.hero,.section,.services,.apps{width:calc(100% - 28px);margin-top:42px}.hero h1{font-size:44px}.hero-actions{display:grid}.service-grid,.app-list{grid-template-columns:1fr}footer{display:grid;padding:28px 16px}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}

.button.small{min-height:40px;padding:0 14px;font-size:13px}.button.wide{width:100%;justify-content:center}.portal-shell{min-height:100vh;background:radial-gradient(circle at 12% 0,color-mix(in srgb,var(--green) 18%,transparent),transparent 28%),var(--bg)}.installer-page,.auth-page{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:42px 0 70px}.installer-panel,.auth-card,.dashboard-section,.metric-grid article{background:color-mix(in srgb,var(--surface) 94%,transparent);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.installer-panel{padding:34px}.installer-heading{display:flex;gap:18px;align-items:center;margin-bottom:26px}.installer-heading img,.auth-card img{width:74px;height:74px;object-fit:contain}.installer-heading h1,.auth-card h1,.dashboard-topbar h1{font-family:MontserratExtra,Georgia,serif;line-height:1.05;margin:0;color:var(--text)}.installer-heading h1{font-size:clamp(34px,4vw,58px)}.installer-heading p,.auth-card p,.dashboard-topbar p,.section-title-row p,.dashboard-section p{color:var(--muted);margin:8px 0 0}.notice{border:1px solid var(--line);border-radius:8px;padding:12px 14px;margin:18px 0;background:var(--surface)}.notice p{margin:0}.notice.danger{border-color:#e6a6a6;background:#fff3f3;color:#8a1f1f}.notice.success{border-color:#9fdab5;background:#eefbf3;color:#0d5f38}body[data-theme=dark] .notice.danger{background:#3b171a;color:#ffd4d4;border-color:#6d3037}body[data-theme=dark] .notice.success{background:#103a27;color:#c7f7d7;border-color:#286445}.setup-form{display:grid;gap:18px}.form-block{padding:20px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--surface) 88%,transparent)}.form-block h2,.form-block h3,.dashboard-section h2{font-family:MontserratExtra,Georgia,serif;margin:0 0 16px;line-height:1.1}.form-block h2{font-size:28px}.form-block h3,.dashboard-section h2{font-size:24px}.form-grid,.mini-grid{display:grid;gap:14px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mini-grid{grid-template-columns:1fr 1fr 1fr;margin-top:12px}label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:800}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);font:inherit;font-size:15px;min-height:46px;padding:10px 12px}textarea{resize:vertical}.check-row{display:flex;align-items:flex-start;gap:12px;margin-top:12px}.check-row input{width:18px;min-height:18px;margin-top:3px}.check-row span{display:grid;gap:2px}.check-row small{color:var(--muted);font-weight:600}.app-config-list{display:grid;gap:12px}.app-config-card{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.auth-page{min-height:100vh;display:grid;place-items:center}.auth-card{width:min(430px,100%);padding:30px;display:grid;gap:16px;text-align:left}.auth-card img{margin:auto}.auth-card h1,.auth-card p{text-align:center}.auth-link{text-align:center;color:var(--muted);text-decoration:none;font-weight:800}.dashboard-body{min-height:100vh;background:var(--bg);display:grid;grid-template-columns:280px minmax(0,1fr)}.village-sidebar{position:sticky;top:0;height:100vh;padding:22px;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:28px}.dashboard-brand{display:flex;align-items:center;gap:12px;text-decoration:none}.dashboard-brand img{width:54px;height:54px;object-fit:contain}.dashboard-brand strong,.dashboard-brand small{display:block}.dashboard-brand strong{font-family:MontserratExtra,Georgia,serif;line-height:1.1}.dashboard-brand small{font-size:12px;color:var(--muted)}.village-sidebar nav{display:grid;gap:8px}.village-sidebar nav a{min-height:44px;display:flex;align-items:center;padding:0 12px;border-radius:8px;text-decoration:none;color:var(--muted);font-weight:800}.village-sidebar nav a:hover{background:color-mix(in srgb,var(--teal) 12%,transparent);color:var(--text)}.dashboard-main{min-width:0;padding:28px max(22px,calc((100% - 1120px)/2))}.dashboard-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:22px}.dashboard-topbar h1{font-size:clamp(32px,4vw,54px)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.metric-grid article{padding:20px}.metric-grid span{color:var(--muted);font-size:13px;font-weight:800}.metric-grid strong{display:block;font-family:MontserratExtra,Georgia,serif;font-size:30px;line-height:1;margin:14px 0 8px}.metric-grid p{margin:0;color:var(--muted);font-size:13px}.dashboard-section{padding:22px;margin:18px 0}.section-title-row{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.app-table{display:grid;gap:10px;margin-top:18px}.app-table article{display:grid;grid-template-columns:minmax(200px,320px) minmax(0,1fr);gap:18px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.app-table strong,.app-table small{display:block}.app-table small{color:var(--muted)}.app-table a{word-break:break-all;color:var(--teal);font-weight:800}.empty-state{padding:18px;border:1px dashed var(--line);border-radius:8px}.storage-panel strong{word-break:break-all}.setup-form.compact{margin-top:14px}.dashboard-footer{margin-top:24px;padding:18px 0;color:var(--muted);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;background:transparent;border:0}

@media(max-width:980px){.dashboard-body{grid-template-columns:1fr}.village-sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--line)}.village-sidebar nav{grid-template-columns:repeat(4,1fr)}.metric-grid{grid-template-columns:repeat(2,1fr)}.app-table article{grid-template-columns:1fr}.dashboard-main{padding:22px}.form-grid,.mini-grid{grid-template-columns:1fr}.installer-heading{align-items:flex-start}}
@media(max-width:620px){.installer-panel{padding:18px}.installer-heading{display:grid}.metric-grid{grid-template-columns:1fr}.dashboard-topbar{display:grid}.village-sidebar nav{grid-template-columns:1fr 1fr}.dashboard-footer{display:grid}.auth-card{padding:22px}}

/* Portal Desa installer/dashboard v0.1.2 */
.installer-simple{width:min(960px,calc(100% - 32px))}
.install-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:22px 0}.install-steps span{min-height:46px;display:flex;align-items:center;justify-content:center;text-align:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted);font-size:13px;font-weight:900}.install-steps span.is-active{background:var(--teal);border-color:var(--teal);color:#fff}.install-steps span.is-done{background:color-mix(in srgb,var(--green) 16%,var(--surface));color:var(--text);border-color:color-mix(in srgb,var(--green) 40%,var(--line))}
.installer-token-form{margin-top:18px}.activation-card{display:grid;gap:18px;padding:26px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--green) 9%,var(--surface)));box-shadow:var(--shadow)}.activation-card h2{font-family:MontserratExtra,Georgia,serif;font-size:clamp(30px,4vw,48px);line-height:1.05;margin:0}.activation-card p,.form-hint,.advanced-box p{color:var(--muted);margin:8px 0 0}.advanced-box{padding:16px;border:1px dashed var(--line);border-radius:8px;background:color-mix(in srgb,var(--surface) 80%,transparent)}.advanced-box summary{cursor:pointer;color:var(--teal);font-weight:900}.advanced-box label{margin-top:12px}.install-help{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}.install-help article,.activation-summary,.dashboard-guide article{padding:18px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.install-help strong,.dashboard-guide strong{display:block;color:var(--text);font-family:MontserratExtra,Georgia,serif;line-height:1.1}.install-help p,.dashboard-guide p{margin:7px 0 0;color:var(--muted);font-size:13px}.activation-summary{display:flex;align-items:center;justify-content:space-between;gap:18px;margin:18px 0}.activation-summary span,.dashboard-guide span,.region-pill{color:var(--green);font-size:12px;font-weight:900;text-transform:uppercase}.activation-summary strong{display:block;font-family:MontserratExtra,Georgia,serif;font-size:28px;line-height:1.1;margin:5px 0}.activation-summary p{margin:0;color:var(--muted)}
.dashboard-guide{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:0 0 18px}.dashboard-guide article{box-shadow:var(--shadow)}.form-block-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.form-block-heading h3{margin-bottom:6px}.form-block-heading p{margin:0;color:var(--muted)}.profile-editor{background:linear-gradient(135deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--green) 7%,var(--surface)))}.region-pill{display:inline-flex;align-items:center;min-height:38px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);text-transform:none;color:var(--muted)}
@media(max-width:860px){.install-steps,.install-help,.dashboard-guide{grid-template-columns:1fr}.activation-summary,.form-block-heading{display:grid}.village-sidebar nav{grid-template-columns:repeat(3,1fr)}}

/* Portal Desa public v0.1.1 */
.public-page{--public-bg:#f6fbfa;--public-surface:#fff;--public-panel:#f9fcfb;--public-soft:#e9f6f3;--public-text:#102220;--public-muted:#647a75;--public-line:#dce9e5;--public-teal:#007c75;--public-green:#28a96b;--public-blue:#2d75e8;--public-sky:#39bde2;--public-gold:#df9d27;--public-shadow:0 22px 55px rgba(21,75,71,.12);background:linear-gradient(180deg,#fff 0,var(--public-bg) 42%,#fff 100%);color:var(--public-text)}
body[data-theme=dark].public-page{--public-bg:#071817;--public-surface:#0b2422;--public-panel:#0f302d;--public-soft:#143936;--public-text:#effcf8;--public-muted:#a7c2bd;--public-line:#244844;--public-teal:#5adbd2;--public-green:#73dc9b;--public-blue:#74aaff;--public-sky:#67d8f1;--public-gold:#f2c26a;--public-shadow:0 24px 70px rgba(0,0,0,.36);background:linear-gradient(180deg,#061413 0,var(--public-bg) 48%,#071817 100%)}
.public-page .public-header{min-height:74px;background:color-mix(in srgb,var(--public-surface) 86%,transparent);border-color:var(--public-line);box-shadow:0 0 0 rgba(0,0,0,0);transition:box-shadow .2s,background-color .2s}
.public-page .public-header.is-scrolled{box-shadow:0 12px 34px rgba(9,45,42,.09)}
body[data-theme=dark].public-page .public-header.is-scrolled{box-shadow:0 12px 34px rgba(0,0,0,.34)}
.public-page .brand img{background:#fff;border:1px solid var(--public-line);box-shadow:0 10px 24px rgba(0,108,104,.08)}
.public-page .public-brand,.public-page .public-brand span,.public-hero-copy,.public-hero-visual,.profile-grid>*,.section-heading>*{min-width:0}
.public-page .brand strong{color:var(--public-text);max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.public-page .brand small,.public-page .public-nav{color:var(--public-muted)}
.public-page .public-nav a{font-weight:800;position:relative}
.public-page .public-nav .nav-login{display:none;color:var(--public-teal)}
.public-page .public-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--public-teal);transform:scaleX(0);transform-origin:center;transition:transform .18s}
.public-page .public-nav a:hover::after,.public-page .public-nav a.is-active::after{transform:scaleX(1)}
.public-page .public-actions{gap:12px}
.public-page .theme-toggle,.public-page .menu-button{background:var(--public-surface);border-color:var(--public-line);color:var(--public-text)}
.public-page .button{border-radius:8px;font-size:14px;letter-spacing:0;transition:transform .18s,box-shadow .18s,border-color .18s,background-color .18s}
.public-page .button:hover{transform:translateY(-1px)}
.public-page .button.primary{background:linear-gradient(135deg,var(--public-teal),#0b6f64);border-color:transparent;color:#fff;box-shadow:0 16px 32px rgba(0,124,117,.2)}
body[data-theme=dark].public-page .button.primary{color:#041b1a;background:linear-gradient(135deg,var(--public-teal),var(--public-green));box-shadow:0 16px 34px rgba(90,219,210,.14)}
.public-page .button.secondary{background:var(--public-surface);border-color:var(--public-line);color:var(--public-teal)}
.scroll-progress{position:absolute;left:0;bottom:-1px;height:2px;width:var(--progress,0%);background:linear-gradient(90deg,var(--public-teal),var(--public-green),var(--public-sky));transition:width .1s}
.public-hero,.public-section{width:min(1180px,calc(100% - 44px));margin-inline:auto}
.public-hero{min-height:690px;display:grid;grid-template-columns:minmax(0,1fr) minmax(430px,.9fr);gap:44px;align-items:center;padding:48px 0 36px}
.public-hero-copy h1{font-family:MontserratExtra,Questrial,Arial,sans-serif;font-size:clamp(42px,5.8vw,78px);line-height:.98;margin:0 0 24px;color:var(--public-text);letter-spacing:0;max-width:800px}
.public-hero-copy p{font-size:18px;line-height:1.75;color:var(--public-muted);margin:0;max-width:680px}
.public-signals{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.public-signals span{min-height:38px;display:inline-flex;align-items:center;border:1px solid var(--public-line);background:color-mix(in srgb,var(--public-surface) 82%,transparent);color:var(--public-muted);border-radius:8px;padding:0 13px;font-size:12px;font-weight:900}
.public-hero-visual{position:relative;min-height:430px;border-radius:8px;overflow:hidden;background:var(--public-soft);box-shadow:var(--public-shadow);border:1px solid var(--public-line)}
.public-hero-visual img{width:100%;height:100%;min-height:430px;display:block;object-fit:cover}
.public-hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,color-mix(in srgb,var(--public-surface) 24%,transparent),transparent 44%),linear-gradient(0deg,color-mix(in srgb,var(--public-surface) 12%,transparent),transparent 45%);pointer-events:none}
body[data-theme=dark].public-page .public-hero-visual::after{background:linear-gradient(90deg,rgba(5,22,20,.34),transparent 48%),linear-gradient(0deg,rgba(5,22,20,.36),transparent 55%)}
.hero-stat{position:absolute;z-index:2;display:grid;gap:4px;min-width:168px;padding:18px;background:color-mix(in srgb,var(--public-surface) 91%,transparent);border:1px solid var(--public-line);border-radius:8px;box-shadow:0 18px 38px rgba(0,0,0,.12);backdrop-filter:blur(14px)}
.hero-stat span{font-size:12px;color:var(--public-muted);font-weight:900}.hero-stat strong{font-family:MontserratExtra,Questrial,sans-serif;font-size:30px;line-height:1;color:var(--public-text)}.hero-stat small{color:var(--public-green);font-weight:800}.hero-stat-main{top:24px;left:24px}.hero-stat-side{right:24px;bottom:24px}
.public-section{padding:70px 0;border-top:1px solid color-mix(in srgb,var(--public-line) 72%,transparent)}
.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:28px;margin-bottom:24px}
.section-heading h2{font-family:MontserratExtra,Questrial,Arial,sans-serif;font-size:clamp(30px,4vw,50px);line-height:1.04;letter-spacing:0;margin:0 0 8px;color:var(--public-text)}
.section-heading p{margin:0;color:var(--public-muted);max-width:680px}
.text-link{color:var(--public-teal);text-decoration:none;font-weight:900;white-space:nowrap}
.profile-grid{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:18px}
.profile-story,.profile-mode,.public-card,.public-stats-grid article,.news-feature,.news-list article,.transparency-copy,.budget-list article,.contact-grid article{background:var(--public-surface);border:1px solid var(--public-line);border-radius:8px;box-shadow:0 16px 36px rgba(12,68,64,.06)}
body[data-theme=dark].public-page .profile-story,body[data-theme=dark].public-page .profile-mode,body[data-theme=dark].public-page .public-card,body[data-theme=dark].public-page .public-stats-grid article,body[data-theme=dark].public-page .news-feature,body[data-theme=dark].public-page .news-list article,body[data-theme=dark].public-page .transparency-copy,body[data-theme=dark].public-page .budget-list article,body[data-theme=dark].public-page .contact-grid article{box-shadow:0 18px 42px rgba(0,0,0,.22)}
.profile-story{padding:28px}.profile-story h3{font-family:MontserratExtra,Questrial,sans-serif;font-size:30px;line-height:1.1;margin:0 0 16px}.profile-story p{color:var(--public-muted);margin:10px 0 0}
.profile-mode{padding:26px;background:linear-gradient(145deg,var(--public-teal),#095c57);color:#fff}.profile-mode span{font-weight:900;font-size:12px;text-transform:uppercase}.profile-mode strong{display:block;font-family:MontserratExtra,Questrial,sans-serif;font-size:40px;line-height:1;margin:18px 0 10px}.profile-mode p{margin:0;color:rgba(255,255,255,.82)}
body[data-theme=dark].public-page .profile-mode{background:linear-gradient(145deg,#0e4a45,#123633);color:var(--public-text)}
body[data-theme=dark].public-page .profile-mode p{color:var(--public-muted)}
.public-service-grid,.public-app-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.public-card{padding:22px;text-decoration:none;color:inherit;min-width:0;transition:transform .18s,border-color .18s,box-shadow .18s}
.public-card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--public-teal) 55%,var(--public-line));box-shadow:var(--public-shadow)}
.card-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:8px;background:var(--public-soft);color:var(--public-teal);font-weight:900;margin-bottom:22px}.tone-blue .card-icon{color:var(--public-blue)}.tone-green .card-icon{color:var(--public-green)}.tone-gold .card-icon{color:var(--public-gold)}.tone-sky .card-icon{color:var(--public-sky)}
.public-card h3{font-family:MontserratExtra,Questrial,sans-serif;font-size:18px;line-height:1.18;margin:0 0 10px;color:var(--public-text)}.public-card p{font-size:13px;line-height:1.55;color:var(--public-muted);margin:0}.service-card a{display:inline-flex;margin-top:22px;color:var(--public-teal);font-weight:900;text-decoration:none}
.app-card{display:grid;align-content:start;gap:10px;min-height:214px}.app-code{width:max-content;max-width:100%;border:1px solid var(--public-line);background:var(--public-panel);color:var(--public-teal);border-radius:8px;padding:5px 9px;font-size:11px;font-weight:900;overflow:hidden;text-overflow:ellipsis}.app-card small{align-self:end;margin-top:auto;color:var(--public-teal);font-weight:900}
.public-stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.public-stats-grid article{padding:22px}.public-stats-grid span,.contact-grid span{display:block;color:var(--public-muted);font-size:12px;font-weight:900}.public-stats-grid strong{display:block;font-family:MontserratExtra,Questrial,sans-serif;font-size:30px;line-height:1;margin:14px 0 6px;color:var(--public-text)}.public-stats-grid small{color:var(--public-green);font-weight:800}
.public-tabs{display:grid;gap:18px}.tab-buttons{display:flex;gap:10px;flex-wrap:wrap}.tab-buttons button{min-height:42px;border:1px solid var(--public-line);background:var(--public-surface);color:var(--public-muted);font:inherit;font-size:13px;font-weight:900;border-radius:8px;padding:0 15px;cursor:pointer}.tab-buttons button[aria-selected=true]{background:var(--public-teal);border-color:var(--public-teal);color:#fff}body[data-theme=dark].public-page .tab-buttons button[aria-selected=true]{color:#041b1a}.tab-panel{display:none}.tab-panel.is-active{display:block}
.news-layout{display:grid;grid-template-columns:1fr 1.08fr;gap:18px}.news-feature{overflow:hidden}.news-feature img{width:100%;height:250px;display:block;object-fit:cover}.news-feature span{display:inline-flex;margin:18px 20px 0;padding:5px 9px;border-radius:8px;background:var(--public-soft);color:var(--public-teal);font-size:12px;font-weight:900}.news-feature h3{font-family:MontserratExtra,Questrial,sans-serif;font-size:26px;line-height:1.13;margin:12px 20px 10px}.news-feature p,.news-feature small{display:block;margin:0 20px 18px;color:var(--public-muted)}.news-list{display:grid;gap:12px}.news-list article{padding:18px}.news-list span{color:var(--public-teal);font-size:12px;font-weight:900}.news-list h3{font-family:MontserratExtra,Questrial,sans-serif;font-size:18px;margin:5px 0 6px}.news-list p{margin:0;color:var(--public-muted);font-size:13px}
.transparency-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px}.transparency-copy{padding:24px}.transparency-copy h3{font-family:MontserratExtra,Questrial,sans-serif;font-size:28px;line-height:1.12;margin:0 0 10px}.transparency-copy p{color:var(--public-muted);margin:0 0 20px}.budget-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.budget-list article{padding:20px}.budget-list span{color:var(--public-muted);font-size:12px;font-weight:900}.budget-list strong{display:block;color:var(--public-text);font-size:18px;margin:8px 0 14px}.budget-list i{display:block;height:8px;background:linear-gradient(90deg,var(--public-teal) var(--value),color-mix(in srgb,var(--public-line) 70%,transparent) var(--value));border-radius:999px}.budget-list small{display:block;margin-top:8px;color:var(--public-muted)}
.potential-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.potential-card{padding:0;overflow:hidden}.potential-card h3,.potential-card p,.potential-card small{margin-left:18px;margin-right:18px}.potential-card h3{margin-top:16px}.potential-card small{display:block;margin-top:14px;margin-bottom:18px;color:var(--public-gold);font-weight:900}.potential-media{height:128px;background:linear-gradient(0deg,rgba(0,0,0,.08),rgba(0,0,0,0)),url('../branding/sampulpgn-sensus-light.png') center/cover}
.contact-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.contact-grid article{padding:20px;min-height:116px}.contact-grid strong{display:block;margin-top:8px;color:var(--public-text);line-height:1.45;word-break:break-word}
.public-footer{padding:34px max(22px,calc((100% - 1180px)/2));display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:32px;background:linear-gradient(135deg,#004c47,#062b29);border:0;color:rgba(255,255,255,.78)}.public-footer img{width:92px;height:auto;display:block;margin-bottom:12px}.public-footer p{margin:0}.public-footer nav{display:grid;gap:8px;color:rgba(255,255,255,.78);font-size:14px}.public-footer a{text-decoration:none;color:inherit}.public-footer a:hover{color:#fff}
@media(max-width:1040px){.public-page .brand strong{max-width:190px}.public-hero{grid-template-columns:1fr;min-height:auto;padding-top:42px}.public-hero-visual{min-height:360px}.public-service-grid,.public-app-grid,.public-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-grid,.news-layout,.transparency-layout{grid-template-columns:1fr}.budget-list,.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.potential-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.public-page .public-header{align-items:center}.public-page .public-header.nav-open .public-nav{display:grid}.public-page .public-nav{gap:10px}.public-page .public-nav a{min-height:38px;display:flex;align-items:center}.public-page .public-nav .nav-login{display:flex}.public-page .public-nav a::after{display:none}.public-page .public-actions{margin-left:auto}.public-page .public-theme-toggle b{display:none}}
@media(max-width:620px){.public-page{overflow-x:hidden}.public-page .site-header{padding-left:16px;padding-right:16px;gap:8px}.public-page .brand img{width:42px;height:42px}.public-page .public-brand span{display:none}.public-page .theme-toggle{width:42px;padding:0}.public-page .menu-button{width:42px}.public-page .public-actions{gap:8px}.public-page .public-actions .button.small{display:none}.public-page .button.small{min-height:40px;padding:0 11px;font-size:12px}.public-hero,.public-section{width:100%;max-width:100%;padding-left:16px;padding-right:16px}.public-hero{gap:28px;padding-top:30px;padding-bottom:36px}.public-hero-copy h1{font-size:30px;line-height:1.08;max-width:100%;overflow-wrap:break-word}.public-hero-copy p{font-size:15px;max-width:100%;overflow-wrap:break-word}.public-hero .hero-actions{display:grid}.public-signals{display:grid;grid-template-columns:1fr}.public-signals span{justify-content:center;text-align:center;font-size:11px;min-width:0}.public-hero-visual{width:100%;max-width:100%;min-height:270px}.public-hero-visual img{min-height:270px}.hero-stat{position:relative;inset:auto;min-width:0;margin:10px;background:var(--public-surface)}.public-hero-visual{display:grid}.public-hero-visual img{grid-area:1/1}.public-hero-visual .hero-stat{grid-area:1/1;align-self:end;justify-self:start;max-width:155px}.public-hero-visual .hero-stat-side{display:none}.section-heading{display:grid}.section-heading h2{font-size:29px;overflow-wrap:anywhere}.text-link{white-space:normal}.profile-grid,.public-service-grid,.public-app-grid,.public-stats-grid,.budget-list,.potential-grid,.contact-grid{grid-template-columns:1fr}.profile-story h3{font-size:24px}.public-section{padding-top:48px;padding-bottom:48px}.tab-buttons{display:grid;grid-template-columns:1fr 1fr}.tab-buttons button:last-child{grid-column:1/-1}.news-feature img{height:190px}.public-footer{grid-template-columns:1fr;padding:28px 16px}}

/* Portal Desa v0.2.1 asset controls */
.asset-upload-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.asset-preview{min-height:96px;display:grid;place-items:center;border:1px dashed var(--line);border-radius:8px;background:color-mix(in srgb,var(--bg) 52%,var(--surface));overflow:hidden}.asset-preview.small{min-height:72px}.asset-preview.wide{min-height:130px}.asset-preview img{max-width:100%;max-height:170px;object-fit:contain;display:block}.asset-preview.wide img{width:100%;height:130px;object-fit:cover}.form-hint{color:var(--muted);font-size:13px;margin:12px 0 0}.public-hero{background:linear-gradient(90deg,var(--public-bg) 0,color-mix(in srgb,var(--public-bg) 82%,transparent) 50%,transparent 100%),var(--public-background-image,none) center/cover no-repeat;border-radius:8px}.public-hero-copy{padding-left:clamp(0px,2vw,24px)}@media(max-width:760px){.asset-upload-grid{grid-template-columns:1fr}.public-hero{border-radius:0}.public-hero-copy{padding-left:0}}

/* Theme toggle day/night icon */
.theme-toggle [data-theme-icon]{width:18px;height:18px;border-radius:50%;display:inline-block;position:relative;background:#f8c64d;box-shadow:0 0 0 3px color-mix(in srgb,#f8c64d 18%,transparent),0 0 18px color-mix(in srgb,#f8c64d 54%,transparent);font-size:0;line-height:0;flex:0 0 auto}.theme-toggle [data-theme-icon]::before{content:"";position:absolute;inset:-5px;border-radius:inherit;border:1px solid color-mix(in srgb,#f8c64d 48%,transparent)}body[data-theme=dark] .theme-toggle [data-theme-icon]{background:transparent;box-shadow:inset -5px -3px 0 1px var(--teal),0 0 18px color-mix(in srgb,var(--teal) 50%,transparent)}body[data-theme=dark] .theme-toggle [data-theme-icon]::before{display:none}

/* Portal Desa v0.2.8 dual public logo */
.public-brand{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-width:0}.public-brand img.brand-logo-main,.public-brand img.brand-logo-secondary{width:58px;height:58px;object-fit:contain;border-radius:0;background:transparent;border:0;padding:0;box-shadow:none}.public-brand .brand-logo-secondary{justify-self:end}.footer-brand-lockup{min-width:0}.footer-logo-pair{display:flex;align-items:center;gap:16px;margin-bottom:16px}.public-footer .footer-logo-pair img{width:96px;max-height:110px;object-fit:contain;margin:0;background:transparent;border:0;border-radius:0;padding:0;box-shadow:none}@media(max-width:620px){.public-brand{grid-template-columns:auto minmax(0,1fr);gap:8px}.public-brand img.brand-logo-main,.public-brand img.brand-logo-secondary{width:42px;height:42px}.footer-logo-pair{gap:10px}.public-footer .footer-logo-pair img{width:74px}}

