﻿@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Newsreader:opsz,wght@6..72,600;6..72,700&display=swap');
:root{--navy:#073d5b;--navy-deep:#062f48;--blue:#0a5b82;--sky:#eaf4f8;--cyan:#d9edf4;--ink:#102f3f;--muted:#6e818c;--line:#e3ebef;--white:#fff;--surface:#f6f8f9;--shadow:0 18px 55px rgba(14,55,76,.12)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:"Manrope",sans-serif;color:var(--ink);background:#fff;letter-spacing:0;overflow-x:hidden}a{color:var(--blue);text-decoration:none}p{color:var(--muted);line-height:1.7}.container{max-width:1180px}.text-success{color:var(--blue)!important}.bg-success{background-color:var(--navy)!important}.site-header{position:absolute;z-index:10;top:31px;left:0;right:0}.site-header .navbar{padding:10px 20px;background:transparent}.navbar-brand{color:#fff!important}.navbar-brand-logo{width:44px;height:44px;object-fit:contain;flex:none}.navbar-brand strong,.navbar-brand small{display:block}.navbar-brand strong{font-size:.95rem;font-weight:800}.navbar-brand small{font-size:.58rem;color:rgba(255,255,255,.72);text-transform:uppercase;font-weight:600}.brand-mark{width:36px;height:36px;display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.45);border-radius:10px;flex:none}.nav-link{font-size:.72rem;font-weight:600;color:rgba(255,255,255,.82)!important;padding:9px 12px!important}.nav-link.active,.nav-link:hover{color:#fff!important}.btn{border-radius:999px;font-weight:700;font-size:.78rem;padding:.68rem 1.15rem}.btn-sm{padding:.42rem .75rem}.btn-lg{font-size:.82rem;padding:.78rem 1.25rem}.btn-success,.btn-primary-soft{background:var(--navy);border-color:var(--navy);color:#fff!important}.btn-success:hover,.btn-primary-soft:hover{background:var(--blue);border-color:var(--blue)}.btn-outline-success{border-color:var(--navy);color:var(--navy)}.btn-outline-success:hover{background:var(--navy);border-color:var(--navy)}.site-header .btn-primary-soft{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(10px)}
.home-shell,.page-head{width:100%;max-width:none;margin:0}.hero{width:100%;min-height:100vh;margin:0;border-radius:0;background:linear-gradient(90deg,rgba(4,43,66,.88) 0%,rgba(4,43,66,.44) 52%,rgba(4,43,66,.12) 100%),url('/desa.png') center/cover;color:#fff;display:flex;align-items:center;overflow:hidden}.hero-content{padding-top:85px}.hero-kicker,.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.hero-kicker{color:#fff;border:1px solid rgba(255,255,255,.35);padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px)}.eyebrow{color:var(--blue)}.hero h1{max-width:660px;font-size:clamp(3rem,6vw,5.6rem);line-height:1.03;font-weight:700;margin:20px 0;letter-spacing:0}.hero p{font-size:.92rem;max-width:530px;color:rgba(255,255,255,.78)}.hero .btn-light{color:var(--navy)}.btn-hero-outline{border:1px solid rgba(255,255,255,.55);color:#fff}.btn-hero-outline:hover{background:#fff;color:var(--navy)}.service-dock-wrap{position:relative;z-index:3;margin-top:-63px}.service-dock{max-width:920px;margin:auto;background:#fff;border:1px solid rgba(213,228,234,.8);padding:11px 11px 11px 26px;border-radius:22px;display:grid;grid-template-columns:1.35fr repeat(3,1fr);gap:7px;box-shadow:var(--shadow)}.dock-copy{display:flex;flex-direction:column;justify-content:center}.dock-copy small{font-size:.58rem;color:var(--muted);text-transform:uppercase;font-weight:700}.dock-copy strong{font-size:.85rem;color:var(--ink)}.service-dock a{border-left:1px solid var(--line);padding:9px 13px;display:flex;align-items:center;gap:9px;color:var(--ink);font-size:.7rem;font-weight:700}.service-dock a:last-child{background:var(--navy);color:#fff;border-radius:14px;border:0}.service-dock i{width:29px;height:29px;display:grid;place-items:center;border-radius:9px;background:var(--sky);color:var(--blue)}.service-dock a:last-child i{background:rgba(255,255,255,.12);color:#fff}
.section-space{padding:95px 0}.section-title{font-size:clamp(1.9rem,4vw,3rem);line-height:1.15;color:var(--ink);font-weight:700;letter-spacing:0;margin:9px 0 15px}.section-lead{font-size:1rem;color:#496573}.section-heading{text-align:center;max-width:700px;margin:0 auto 40px;position:relative}.section-heading>a{position:absolute;right:-230px;bottom:6px;font-size:.72rem;font-weight:700}.welcome-visual{position:relative;padding:0}.welcome-visual img{width:100%;height:420px;object-fit:cover;border-radius:18px;box-shadow:var(--shadow)}.visual-badge{position:absolute;right:18px;bottom:18px;background:rgba(5,52,78,.88);color:#fff;border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(12px);padding:15px 18px;border-radius:14px;display:grid;grid-template-columns:auto 1fr;gap:0 10px;align-items:center;font-size:.62rem}.visual-badge i{font-size:1.4rem;grid-row:span 2}.visual-badge strong{font-size:.9rem}.stats-section,.gallery-band{background:var(--surface)}.stat-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;min-height:150px;display:flex;flex-direction:column;box-shadow:0 8px 25px rgba(14,55,76,.04);transition:.2s}.stat-card:hover,.content-card:hover,.gallery-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.stat-card strong{font-size:1.9rem;color:var(--navy);margin-top:auto;letter-spacing:0}.stat-card>span:last-child{font-size:.68rem;color:var(--muted)}.stat-icon{width:38px;height:38px;display:grid;place-items:center;background:var(--sky);color:var(--blue);border-radius:11px}.content-card,.gallery-tile{background:#fff;border:1px solid var(--line);border-radius:16px;height:100%;overflow:hidden;box-shadow:0 8px 25px rgba(14,55,76,.04);transition:.2s}.card-image,.placeholder-img{height:220px;position:relative;overflow:hidden;background-size:cover;background-position:center}.card-image img{width:100%;height:100%;object-fit:cover}.image-village,.placeholder-img{background-image:url('https://images.unsplash.com/photo-1500534314209-a25ddb2bd429?auto=format&fit=crop&w=900&q=80')}.image-office{background-image:url('https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=900&q=80')}.image-community{background-image:url('https://images.unsplash.com/photo-1529156069898-49953e39b3ac?auto=format&fit=crop&w=900&q=80')}.placeholder-img{display:grid;place-items:center;color:#fff;font-size:2.4rem}.card-image span{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.92);border-radius:8px;padding:5px 8px;font-size:.58rem;font-weight:700;color:var(--navy)}.news-card .card-body{padding:20px}.news-card small,.gallery-tile small{display:block;color:var(--blue);font-size:.58rem;text-transform:uppercase;font-weight:800}.news-card h5{font-size:.95rem;font-weight:700;margin:8px 0;color:var(--ink)}.news-card p{font-size:.73rem;margin-bottom:12px}.news-card a{font-size:.68rem;font-weight:800}.gallery-tile .card-image{height:200px}.gallery-tile>div:last-child{padding:15px}.gallery-tile strong{font-size:.78rem}
.page-head{padding:155px 0 72px;background:linear-gradient(90deg,rgba(4,43,66,.91),rgba(4,43,66,.4)),url('https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=1900&q=86') center/cover;color:#fff;border-radius:0 0 18px 18px}.page-head h1{font-size:clamp(2.5rem,6vw,4.4rem);font-weight:700;letter-spacing:0}.page-head p{color:rgba(255,255,255,.75)}.table-responsive.content-card,.content-card.p-4,form.content-card{padding:26px!important}.content-card h3,.content-card h4,.content-card h5{font-weight:700;color:var(--ink)}iframe{border-radius:16px;box-shadow:0 8px 25px rgba(14,55,76,.05)}.table{--bs-table-bg:transparent}.table thead th{font-size:.62rem;text-transform:uppercase;color:#708591;border-bottom-color:var(--line)}.table td{border-color:#edf2f4;font-size:.78rem}.form-control,.form-select{border-color:var(--line);border-radius:10px;padding:.7rem .85rem;background:#fff;font-size:.8rem}.form-control:focus,.form-select:focus{border-color:#83b6cc;box-shadow:0 0 0 .2rem rgba(10,91,130,.1)}.form-label{font-weight:700;font-size:.72rem;color:var(--ink)}.alert{border:0;border-radius:12px}.progress{height:8px;background:var(--sky)}.progress-bar.bg-success{background:var(--blue)!important}.page-link{color:var(--blue);border-color:var(--line);font-size:.75rem}.active>.page-link,.page-link.active{background:var(--navy);border-color:var(--navy)}.footer{background:var(--navy-deep);color:#e9f4f8;margin-top:0;padding:60px 0 20px}.footer .brand-mark{background:rgba(255,255,255,.1)}.footer p,.footer a{color:#afc6d1;font-size:.75rem}.footer a{display:block;margin:8px 0}.footer h5,.footer h6{font-weight:700}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:35px;padding-top:20px;font-size:.67rem;color:#8fb0bf}
.panel-bg{background:#f4f7f9}.sidebar{width:265px;min-height:100vh;background:var(--navy-deep);flex:none;padding:20px 13px!important}.sidebar>a:first-child{background:rgba(255,255,255,.07);border:0!important;border-radius:12px;padding:15px!important}.sidebar a{display:block;color:#b6ccd6;text-decoration:none;padding:10px 12px;margin:4px 0;border-radius:9px;font-size:.78rem}.sidebar a:hover,.sidebar a.active{background:var(--blue);color:#fff}.sidebar i{display:inline-block;width:23px}.panel-topbar{margin:13px 15px 0;border-radius:12px;box-shadow:0 5px 20px rgba(14,55,76,.05)!important}.panel-topbar h5{font-weight:700;color:var(--ink)}.table-panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:0 8px 25px rgba(14,55,76,.04)}.panel-bg .stat-card{background:#fff}.badge{border-radius:999px;padding:6px 9px}.badge-Menunggu{background:#f4c95d;color:#49370a}.badge-Diproses,.badge-Diteruskan{background:#4283aa}.badge-Disetujui,.badge-Selesai{background:#27846b}.badge-Ditolak{background:#c95151}.badge-Ditindaklanjuti{background:#7863a9}
.login-page{background:#f4f7f9}.login-shell{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}.login-visual{margin:16px;border-radius:18px;background:linear-gradient(0deg,rgba(4,43,66,.87),rgba(4,43,66,.18)),url('https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=1500&q=86') center/cover;padding:38px;display:flex;flex-direction:column;justify-content:space-between;color:#fff}.login-brand{display:flex;align-items:center;gap:10px;color:#fff}.login-brand strong,.login-brand small{display:block}.login-brand strong{font-size:.95rem}.login-brand small{font-size:.55rem;text-transform:uppercase}.login-visual h1{font-size:clamp(2.7rem,5vw,5rem);max-width:700px;line-height:1.04;letter-spacing:0;margin:20px 0}.login-visual p{color:rgba(255,255,255,.75)}.login-form-wrap{display:grid;place-items:center;padding:38px}.login-form{width:min(420px,100%)}.login-form h2{font-size:2.2rem;letter-spacing:0;color:var(--ink);margin:9px 0}.input-group-text{border-color:var(--line);background:#fff;border-radius:10px 0 0 10px;color:var(--blue)}.input-group .form-control{border-left:0;border-radius:0 10px 10px 0}
@media(max-width:1199px){.site-header{top:20px}.site-header .navbar{background:rgba(4,43,66,.88);border-radius:13px;backdrop-filter:blur(12px)}.navbar-collapse{padding:8px 0}.service-dock{grid-template-columns:1fr 1fr}.dock-copy{grid-column:1/-1}.service-dock a{border:0}.section-heading>a{display:none}.page-head{border-radius:0 0 14px 14px}}
@media(max-width:800px){.hero{min-height:100svh}.hero h1{font-size:3.25rem}.hero-content{padding-top:105px}.service-dock-wrap{margin-top:-35px;padding:0 14px}.service-dock{border-radius:16px;padding:13px;gap:6px}.service-dock a{padding:8px;font-size:.65rem}.service-dock i{width:27px;height:27px}.section-space{padding:65px 0}.welcome-visual img{height:310px}.page-head{padding:135px 0 55px}.sidebar{width:69px;padding:11px 6px!important}.sidebar strong,.sidebar small,.sidebar a{font-size:0}.sidebar a i{font-size:1.1rem}.panel-topbar{margin:8px}.panel-topbar span{display:none}.panel-bg main>.p-4{padding:11px!important}.table-panel{padding:14px}.footer-main{padding:0 8px}.login-shell{grid-template-columns:1fr}.login-visual{min-height:330px}.login-form-wrap{padding:42px 20px}.container>.d-flex.gap-2.mb-4{flex-wrap:wrap}.container>form.d-flex{flex-wrap:wrap}.container>form.d-flex .form-control{min-width:100%}}

/* Motion and expressive typography */
h1,h2,.section-title,.page-head h1,.login-visual h1,.login-form h2{font-family:"Newsreader",serif;letter-spacing:0}.hero h1{font-weight:600;line-height:1}.navbar-brand strong,.news-card h5,.content-card h3,.content-card h4,.content-card h5{letter-spacing:0}.scroll-progress{position:fixed;z-index:2000;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,#70c9e8,#fff);transform:scaleX(0);transform-origin:left;transition:transform .08s linear;box-shadow:0 0 12px rgba(112,201,232,.7)}.site-header{transition:top .3s ease}.site-header.is-scrolled{position:fixed;top:10px}.site-header.is-scrolled .navbar{background:rgba(4,43,66,.9);border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 12px 40px rgba(4,43,66,.2);backdrop-filter:blur(15px)}.hero{position:relative;isolation:isolate}.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(circle 320px at var(--mouse-x,75%) var(--mouse-y,35%),rgba(123,207,235,.2),transparent 70%);pointer-events:none;transition:background .15s ease}.hero-content{animation:heroEnter .9s cubic-bezier(.2,.7,.2,1) both}.hero-kicker{animation:gentleFloat 4s ease-in-out infinite}.scroll-cue{position:absolute;left:50%;bottom:28px;display:flex;flex-direction:column;align-items:center;gap:5px;color:#fff;font-size:.8rem;opacity:.75;animation:gentleFloat 2s ease-in-out infinite}.scroll-cue span{display:block;width:1px;height:28px;background:linear-gradient(transparent,#fff)}.btn,.service-dock a,.sidebar a{transition:transform .25s ease,background-color .25s ease,border-color .25s ease,box-shadow .25s ease,color .25s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(5,52,78,.16)}.btn i,.news-card a i,.section-heading>a i{display:inline-block;transition:transform .25s ease}.btn:hover i,.news-card a:hover i,.section-heading>a:hover i{transform:translateX(4px)}.service-dock a:hover{transform:translateY(-3px);background:var(--sky)}.service-dock a:last-child:hover{background:var(--blue)}.service-dock a:hover i{animation:iconPop .45s ease}.card-image img,.welcome-visual img,.placeholder-img{transition:transform .7s cubic-bezier(.2,.7,.2,1),filter .4s ease}.content-card:hover .card-image img,.gallery-tile:hover .card-image img,.welcome-visual:hover img{transform:scale(1.045);filter:saturate(1.08)}.stat-icon{transition:transform .35s ease,background-color .35s ease}.stat-card:hover .stat-icon{transform:rotate(-8deg) scale(1.1);background:#d5edf6}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease var(--reveal-delay,0ms),transform .7s cubic-bezier(.2,.7,.2,1) var(--reveal-delay,0ms)}.reveal.is-visible{opacity:1;transform:translateY(0)}.alert{transition:opacity .4s ease,transform .4s ease}.alert-hide{opacity:0;transform:translateY(-8px);pointer-events:none}.footer a{transition:color .2s ease,transform .2s ease}.footer a:hover{color:#fff;transform:translateX(4px)}.form-control,.form-select{transition:border-color .2s ease,box-shadow .2s ease}.form-control:hover,.form-select:hover{border-color:#b5d5e2}.table tbody tr{transition:background-color .2s ease,transform .2s ease}.table tbody tr:hover{background:#f4f9fb;transform:translateX(2px)}
@keyframes heroEnter{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes gentleFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes iconPop{50%{transform:scale(1.18) rotate(-6deg)}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}@media(max-width:800px){.scroll-cue{display:none}.site-header.is-scrolled{top:6px}}

/* Navbar underline sweeps from left to right */
.site-header .nav-link{position:relative}.site-header .nav-link::after{content:"";position:absolute;left:12px;right:12px;bottom:4px;height:2px;border-radius:999px;background:#fff;transform:scaleX(0);transform-origin:left center;transition:transform .32s cubic-bezier(.2,.7,.2,1)}.site-header .nav-link:hover::after,.site-header .nav-link:focus-visible::after,.site-header .nav-link.active::after{transform:scaleX(1)}@media(max-width:1199px){.site-header .nav-link::after{left:4px;right:auto;width:46px;bottom:3px}}

/* Profile page */
.profile-page{position:relative;z-index:1;background:#f7fafb}.profile-page .content-card{height:auto;transform:none}.profile-page .content-card:hover{transform:translateY(-4px)}.profile-intro{display:grid;grid-template-columns:72px 1fr;gap:24px;align-items:start;padding:34px}.profile-intro h2{font-family:"Newsreader",serif;font-size:2.2rem;margin:8px 0 14px}.profile-intro-icon,.profile-card-icon{display:grid;place-items:center;background:var(--sky);color:var(--blue)}.profile-intro-icon{width:72px;height:72px;border-radius:18px;font-size:1.7rem}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.profile-bottom-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:24px;align-items:start}.profile-card{padding:30px!important;min-height:250px}.profile-card-icon{width:46px;height:46px;border-radius:13px;font-size:1.15rem;margin-bottom:28px}.profile-card h3{font-family:"Newsreader",serif;font-size:2rem;margin:8px 0 14px}.government-card{min-height:100%}.profile-contact{display:grid;gap:20px}.contact-card{min-height:auto}.contact-list{display:grid;gap:13px;margin-top:20px}.contact-list p{display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:start;margin:0}.contact-list i{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;background:var(--sky);color:var(--blue)}.map-frame{height:330px;border-radius:16px;overflow:hidden;background:var(--sky);box-shadow:0 8px 25px rgba(14,55,76,.08)}.map-frame iframe{display:block;width:100%;height:100%;border:0;border-radius:0;box-shadow:none}.profile-page+.footer{position:relative;z-index:0;clear:both}@media(max-width:991px){.profile-bottom-grid{grid-template-columns:1fr}.government-card{min-height:auto}}@media(max-width:767px){.profile-grid{grid-template-columns:1fr}.profile-intro{grid-template-columns:1fr;padding:24px}.profile-intro h2{font-size:1.8rem}.profile-card{padding:24px!important;min-height:auto}}
.variable-palette{display:flex;flex-wrap:wrap;gap:7px}.template-variable{border:1px solid #bdd9e5;background:var(--sky);color:var(--navy);border-radius:8px;padding:6px 8px;font:600 .68rem monospace}.template-variable:hover{background:var(--navy);color:#fff}.template-editor{font-family:Consolas,monospace;font-size:.75rem;line-height:1.7}.dynamic-field-row{display:grid;grid-template-columns:1.2fr 1fr .8fr auto auto;gap:8px;align-items:end;padding:12px 0;border-bottom:1px solid var(--line)}.dynamic-field-row label{display:block;font-size:.64rem;font-weight:700;margin-bottom:4px}.field-required{padding-bottom:8px;white-space:nowrap}.template-help{padding:15px;background:var(--sky);border-radius:10px;font-size:.75rem}@media(max-width:800px){.dynamic-field-row{grid-template-columns:1fr 1fr}.dynamic-field-row>div:first-child{grid-column:1/-1}}

/* Kepala desa signature and stamp */
.signature-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.signature-tab{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;padding:8px 11px;font-size:.7rem;font-weight:700;transition:.2s}.signature-tab:hover{border-color:#9fc7d8;background:var(--sky)}.signature-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.signature-pane{padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:10px}.signature-pane canvas{display:block;width:100%;height:180px;background:#fff;border:1px dashed #9eb9c6;border-radius:8px;cursor:crosshair;touch-action:none}.approval-preview{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}.approval-preview a{display:flex;align-items:center;gap:10px;padding:11px;border:1px solid var(--line);border-radius:10px;background:var(--surface);font-size:.7rem;font-weight:700}.approval-preview img{width:54px;height:42px;object-fit:contain;background:#fff;border-radius:6px}@media(max-width:600px){.approval-preview{grid-template-columns:1fr}}
