:root{
  --primary:#0f766e;--primary-dark:#115e59;--primary-soft:#ccfbf1;
  --accent:#f59e0b;--bg:#f4f7fb;--surface:#ffffff;--text:#172033;
  --muted:#667085;--border:#e4e7ec;--danger:#b42318;--success:#027a48;
  --shadow:0 12px 35px rgba(16,24,40,.08);--radius:16px
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;display:flex}.sidebar{position:fixed;inset:0 auto 0 0;width:268px;background:linear-gradient(180deg,#0f766e 0%,#134e4a 100%);color:#fff;padding:24px 18px;display:flex;flex-direction:column;z-index:40;box-shadow:10px 0 30px rgba(15,118,110,.12)}.brand{display:flex;align-items:center;gap:12px;padding:4px 8px 24px;border-bottom:1px solid rgba(255,255,255,.16)}.brand-mark{width:44px;height:44px;border-radius:14px;background:#fff;color:var(--primary);display:grid;place-items:center;font-weight:800;box-shadow:0 8px 18px rgba(0,0,0,.12)}.brand strong,.brand span{display:block}.brand strong{font-size:18px}.brand span{font-size:12px;opacity:.78}.nav-menu{display:grid;gap:8px;margin-top:24px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:rgba(255,255,255,.83);font-weight:600;transition:.2s}.nav-link:hover,.nav-link.active{background:rgba(255,255,255,.15);color:#fff;transform:translateX(2px)}.nav-icon{width:24px;text-align:center;font-size:20px}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.16);padding-top:18px}.user-mini{display:flex;gap:10px;align-items:center}.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.2);font-weight:800}.user-mini strong,.user-mini span{display:block}.user-mini span{font-size:12px;opacity:.72}.logout-link{display:block;margin-top:14px;text-align:center;padding:9px;border:1px solid rgba(255,255,255,.25);border-radius:10px;font-size:14px}.main-area{margin-left:268px;min-width:0;flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:88px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 30px;gap:16px;position:sticky;top:0;z-index:20}.topbar h1{font-size:22px;margin:0}.topbar p{margin:3px 0 0;color:var(--muted);font-size:13px}.topbar-badge{margin-left:auto;background:var(--primary-soft);color:var(--primary-dark);padding:8px 13px;border-radius:999px;font-size:13px;font-weight:700}.menu-toggle{display:none;border:0;background:#eef4f4;width:42px;height:42px;border-radius:12px;cursor:pointer;font-size:20px}.content{padding:28px;flex:1}.footer{padding:18px 28px;border-top:1px solid var(--border);display:flex;justify-content:space-between;color:var(--muted);font-size:13px;background:#fff}.grid{display:grid;gap:20px}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:22px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;width:85px;height:85px;border-radius:50%;background:var(--primary-soft);right:-28px;top:-28px}.stat-label{color:var(--muted);font-size:13px;font-weight:600}.stat-value{font-size:30px;font-weight:800;margin-top:8px}.stat-note{font-size:12px;color:var(--primary);margin-top:6px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:14px}.card-header h2,.card-header h3{margin:0;font-size:18px}.card-body{padding:22px}.two-column{grid-template-columns:minmax(0,1.4fr) minmax(290px,.6fr)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:11px;padding:10px 15px;font-weight:700;cursor:pointer;transition:.2s}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:#eef2f6;color:#344054}.btn-outline{background:#fff;color:var(--primary);border:1px solid var(--primary)}.btn-danger{background:#fee4e2;color:var(--danger)}.btn-sm{padding:7px 10px;border-radius:9px;font-size:13px}.actions{display:flex;gap:8px;flex-wrap:wrap}.alert{padding:13px 16px;border-radius:12px;margin-bottom:18px;font-weight:600;transition:.3s}.alert-success{background:#ecfdf3;color:var(--success);border:1px solid #abefc6}.alert-danger{background:#fef3f2;color:var(--danger);border:1px solid #fecdca}.fade-out{opacity:0;transform:translateY(-6px)}.table-responsive{overflow:auto}.table{width:100%;border-collapse:collapse;min-width:760px}.table th,.table td{padding:13px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#fafbfc}.table tbody tr:hover{background:#fbfdfd}.badge{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:700}.badge-primary{background:var(--primary-soft);color:var(--primary-dark)}.badge-neutral{background:#f2f4f7;color:#475467}.search-bar{display:flex;gap:10px;flex-wrap:wrap}.search-bar input{min-width:230px;flex:1}.form-control,.form-select,.form-textarea{width:100%;border:1px solid #d0d5dd;border-radius:11px;padding:10px 12px;background:#fff;color:var(--text);outline:none;transition:.2s}.form-control:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(15,118,110,.1)}.form-textarea{min-height:90px;resize:vertical}.form-group label{display:block;font-weight:700;font-size:13px;margin-bottom:7px}.required{color:var(--danger)}.form-hint{font-size:12px;color:var(--muted);margin-top:5px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid .full{grid-column:1/-1}.section-title{display:flex;align-items:center;gap:10px;margin:2px 0 16px}.section-title span{width:34px;height:34px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-weight:800}.section-title h3{margin:0;font-size:17px}.person-block{border:1px solid var(--border);border-radius:15px;padding:18px;margin-bottom:18px;background:#fcfdfd}.person-block:last-child{margin-bottom:0}.tabs{display:flex;gap:8px;background:#f2f4f7;padding:6px;border-radius:13px;margin-bottom:20px}.tab-btn{flex:1;border:0;background:transparent;padding:11px;border-radius:9px;font-weight:700;cursor:pointer;color:#475467}.tab-btn.active{background:#fff;color:var(--primary);box-shadow:0 3px 12px rgba(16,24,40,.08)}.tab-pane{display:none}.tab-pane.active{display:block}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:18px;border-top:1px solid var(--border);margin-top:22px}.empty-state{text-align:center;padding:45px 20px;color:var(--muted)}.empty-state strong{display:block;color:var(--text);font-size:18px;margin-bottom:5px}.quick-list{display:grid;gap:12px}.quick-item{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--border)}.quick-item:last-child{border-bottom:0}.quick-item strong,.quick-item span{display:block}.quick-item span{font-size:12px;color:var(--muted)}.progress{height:10px;background:#eef2f6;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),#14b8a6);border-radius:999px}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.detail-item{padding:12px 14px;background:#f8fafc;border-radius:11px}.detail-item dt{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase}.detail-item dd{margin:5px 0 0;font-weight:600}.detail-item.full{grid-column:1/-1}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,#ccfbf1 0,transparent 35%),linear-gradient(135deg,#f7fafc,#ecfdf5)}.login-card{width:min(440px,100%);background:#fff;border:1px solid var(--border);border-radius:22px;padding:30px;box-shadow:0 24px 60px rgba(15,118,110,.15)}.login-brand{text-align:center;margin-bottom:24px}.login-brand .brand-mark{margin:0 auto 12px}.login-brand .brand-mark--logo{width:78px;height:78px;padding:8px;border-radius:22px;background:linear-gradient(145deg,#ffffff 0%,#effdfa 100%);box-shadow:0 14px 34px rgba(0,35,44,.18), inset 0 1px 0 rgba(255,255,255,.85);display:grid;place-items:center;overflow:hidden}.login-brand .brand-mark--logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}.login-brand h1{font-size:24px;margin:0}.login-brand p{color:var(--muted);margin:6px 0 0}.login-card .form-group{margin-bottom:16px}.login-help{margin-top:18px;padding:12px;background:#f8fafc;border-radius:10px;font-size:12px;color:var(--muted)}.w-100{width:100%}.text-muted{color:var(--muted)}.mb-0{margin-bottom:0}.mt-2{margin-top:8px}.sidebar-overlay{display:none}
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.two-column{grid-template-columns:1fr}}
@media(max-width:800px){.sidebar{transform:translateX(-100%);transition:.25s}.sidebar.open{transform:translateX(0)}.main-area{margin-left:0}.menu-toggle{display:grid;place-items:center}.sidebar-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:30}.sidebar-overlay.show{display:block}.topbar{padding:0 18px}.content{padding:18px}.footer{padding:16px 18px}.form-grid,.detail-grid{grid-template-columns:1fr}.form-grid .full,.detail-item.full{grid-column:auto}}
@media(max-width:560px){.stats-grid{grid-template-columns:1fr}.card-header{align-items:flex-start;flex-direction:column}.tabs{flex-direction:column}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.topbar-badge{display:none}.topbar h1{font-size:18px}.table{min-width:680px}}
@media print{.sidebar,.topbar,.footer,.no-print,.sidebar-overlay{display:none!important}.main-area{margin:0}.content{padding:0}.card{box-shadow:none;border:0}.card-header{padding-left:0;padding-right:0}.card-body{padding-left:0;padding-right:0}body{background:#fff}}

/* Modul wali nikah */
.guardian-notice{margin:16px 0;padding:13px 15px;border-radius:12px;border:1px solid var(--border);font-size:13px;line-height:1.55}
.guardian-notice.info{background:#eff8ff;border-color:#b2ddff;color:#175cd3}
.guardian-notice.open{background:#ecfdf3;border-color:#abefc6;color:#027a48}
.guardian-notice.locked{background:#fffaeb;border-color:#fedf89;color:#93370d}
.guardian-fields{transition:.2s}
.guardian-fields.is-locked .form-control,
.guardian-fields.is-locked .form-textarea{background:#f2f4f7;color:#667085;border-color:#e4e7ec;cursor:not-allowed}
.form-select:disabled,.form-control:disabled,.form-textarea:disabled{background:#f2f4f7;color:#667085;cursor:not-allowed}
.parent-status-notice{margin-top:14px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);font-size:13px;line-height:1.55}
.parent-status-notice.available{background:#ecfdf3;border-color:#abefc6;color:#027a48}
.parent-status-notice.locked{background:#fffaeb;border-color:#fedf89;color:#93370d}
.parent-fields-locked [data-parent-dependent]{background:#f2f4f7!important;color:#667085!important;border-color:#e4e7ec!important;cursor:not-allowed}


/* Pilihan jenis layanan */
.badge-warning{background:#fffaeb;color:#b54708}
.service-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:14px;margin-bottom:18px;border:1px solid var(--border)}
.service-banner strong,.service-banner span{display:block}
.service-banner strong{font-size:15px;margin-bottom:3px}
.service-banner span{font-size:13px}
.service-banner-primary{background:#ecfdf3;border-color:#abefc6;color:#027a48}
.service-banner-warning{background:#fffaeb;border-color:#fedf89;color:#93370d}
.modal-open{overflow:hidden}
.service-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.62);backdrop-filter:blur(5px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.service-modal-backdrop.is-open{display:flex;animation:modalFade .2s ease-out}
.service-modal-card{width:min(720px,100%);background:#fff;border-radius:24px;padding:30px;box-shadow:0 30px 90px rgba(15,23,42,.28);position:relative;animation:modalRise .25s ease-out}
.service-modal-close{position:absolute;right:18px;top:16px;width:38px;height:38px;border:0;border-radius:50%;background:#f2f4f7;color:#475467;font-size:25px;line-height:1;cursor:pointer}
.service-modal-icon{width:54px;height:54px;border-radius:17px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-size:26px;margin:0 auto 12px}
.service-modal-card>h2{text-align:center;margin:0;font-size:24px}
.service-modal-card>p{text-align:center;color:var(--muted);margin:7px 0 22px}
.service-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:18px}
.service-choice{display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:22px;border:2px solid var(--border);border-radius:18px;transition:.2s;background:#fff;min-height:170px}
.service-choice:hover{transform:translateY(-3px);box-shadow:0 15px 35px rgba(16,24,40,.1)}
.service-choice-primary:hover{border-color:#5fe9d5;background:#f0fdfa}
.service-choice-warning:hover{border-color:#fdb022;background:#fffcf5}
.service-choice-icon{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-size:22px;font-weight:800}
.service-choice-primary .service-choice-icon{background:var(--primary-soft);color:var(--primary)}
.service-choice-warning .service-choice-icon{background:#fef0c7;color:#b54708}
.service-choice strong{font-size:17px;color:var(--text)}
.service-choice small{font-size:13px;color:var(--muted);line-height:1.55}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
@keyframes modalRise{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media(max-width:640px){.service-choice-grid{grid-template-columns:1fr}.service-modal-card{padding:26px 18px 20px}.service-choice{min-height:auto}.service-banner{align-items:flex-start;flex-direction:column}.service-banner .btn{width:100%}}

.village-letterhead-preview{text-align:center;border-bottom:3px double var(--text);padding:8px 5px 14px;line-height:1.45;font-family:"Times New Roman",serif;font-size:14px}.village-letterhead-preview strong{display:block;font-size:21px;margin-top:3px}.village-summary{margin-top:18px}.dashboard-village-summary{margin-top:18px;padding-top:16px;border-top:1px solid var(--border);display:grid;gap:4px}.dashboard-village-summary span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.dashboard-village-summary strong{font-size:16px}.dashboard-village-summary small{color:var(--muted);line-height:1.5}.dashboard-village-summary a{color:var(--primary);font-size:13px;font-weight:700;margin-top:5px}.village-preview-card{align-self:start}

/* Pemisahan data berdasarkan jenis layanan */
.stat-card-link{display:block;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s}
.stat-card-link:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(16,24,40,.12);border-color:#99d8d2}
.service-data-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:18px}
.service-data-tab{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border:1px solid var(--border);border-radius:13px;background:#f8fafc;color:#475467;font-weight:700;transition:.2s}
.service-data-tab:hover{transform:translateY(-1px);border-color:#98a2b3;background:#fff}
.service-data-tab strong{min-width:32px;height:32px;padding:0 9px;border-radius:999px;display:grid;place-items:center;background:#e4e7ec;color:#344054;font-size:13px}
.service-data-tab.active{border-color:#98a2b3;background:#fff;box-shadow:0 8px 22px rgba(16,24,40,.08);color:var(--text)}
.service-data-tab-primary.active{border-color:#5fe9d5;background:#f0fdfa;color:#115e59}
.service-data-tab-primary.active strong{background:var(--primary);color:#fff}
.service-data-tab-warning.active{border-color:#fdb022;background:#fffcf5;color:#93370d}
.service-data-tab-warning.active strong{background:#f79009;color:#fff}
@media(max-width:720px){.service-data-tabs{grid-template-columns:1fr}.service-data-tab{padding:12px 14px}}

/* Statistik Daftar Nikah */
.statistics-filter-card{margin-bottom:22px}.statistics-filter-row{display:flex;align-items:center;justify-content:space-between;gap:18px}.statistics-filter-row strong{display:block;margin-bottom:3px}.statistics-year-filter{display:flex;align-items:center;gap:10px;min-width:220px}.statistics-year-filter label{font-size:13px;font-weight:700}.statistics-year-filter .form-select{min-width:110px}.statistics-summary-grid{margin-top:0}.statistics-age-value{font-size:27px}.statistics-chart-card{margin-bottom:22px}.statistics-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.statistics-canvas-wrap{position:relative;width:100%;min-height:340px;overflow:hidden}.statistics-canvas{display:block;width:100%;height:340px}.statistics-note-card{margin-bottom:4px}.statistics-note-card p{margin-top:6px;line-height:1.65}@media(max-width:1050px){.statistics-chart-grid{grid-template-columns:1fr}}@media(max-width:640px){.statistics-filter-row{align-items:flex-start;flex-direction:column}.statistics-year-filter{width:100%}.statistics-year-filter .form-select{flex:1}.statistics-canvas-wrap{min-height:320px}.statistics-canvas{height:320px}}@media print{.statistics-chart-grid{grid-template-columns:1fr}.statistics-chart-card{break-inside:avoid}.statistics-canvas-wrap{min-height:300px}.statistics-note-card{break-inside:avoid}}

/* Dashboard profesional */
.dashboard-body{background:#f2f5f9}.dashboard-body .content{background:radial-gradient(circle at 88% 3%,rgba(20,184,166,.08),transparent 23%),radial-gradient(circle at 15% 18%,rgba(245,158,11,.055),transparent 18%),#f2f5f9}.dashboard-page{max-width:1580px;margin:0 auto}.dashboard-hero{position:relative;min-height:242px;padding:38px 40px;border-radius:26px;overflow:hidden;color:#fff;background:linear-gradient(124deg,#073f3b 0%,#0f766e 48%,#0d9488 100%);box-shadow:0 24px 55px rgba(15,118,110,.22);display:flex;align-items:center;justify-content:space-between;gap:30px;margin-bottom:22px}.dashboard-hero:before{content:"";position:absolute;inset:auto -70px -150px auto;width:360px;height:360px;border-radius:50%;border:68px solid rgba(255,255,255,.055)}.dashboard-hero:after{content:"";position:absolute;inset:-95px auto auto 40%;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.045)}.dashboard-hero-pattern{position:absolute;inset:0;opacity:.12;background-image:linear-gradient(30deg,rgba(255,255,255,.18) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.18) 87.5%,rgba(255,255,255,.18)),linear-gradient(150deg,rgba(255,255,255,.18) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.18) 87.5%,rgba(255,255,255,.18)),linear-gradient(30deg,rgba(255,255,255,.18) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.18) 87.5%,rgba(255,255,255,.18)),linear-gradient(150deg,rgba(255,255,255,.18) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.18) 87.5%,rgba(255,255,255,.18));background-size:70px 122px;background-position:0 0,0 0,35px 61px,35px 61px}.dashboard-hero-content,.dashboard-hero-clock{position:relative;z-index:2}.dashboard-hero-content{max-width:760px}.dashboard-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.02em}.status-dot{width:8px;height:8px;border-radius:50%;background:#86efac;box-shadow:0 0 0 5px rgba(134,239,172,.13);animation:dashboardPulse 2s infinite}.dashboard-hero h2{font-size:34px;line-height:1.17;margin:18px 0 8px;letter-spacing:-.025em}.dashboard-hero p{max-width:680px;margin:0;color:rgba(255,255,255,.77);font-size:15px;line-height:1.65}.dashboard-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.hero-btn{display:inline-flex;align-items:center;gap:9px;padding:11px 17px;border-radius:12px;font-size:13px;font-weight:800;transition:.2s}.hero-btn:hover{transform:translateY(-2px)}.hero-btn-primary{background:#fff;color:#0b635d;box-shadow:0 10px 25px rgba(4,47,46,.18)}.hero-btn-light{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);color:#fff}.dashboard-hero-clock{min-width:230px;padding:22px;border:1px solid rgba(255,255,255,.17);border-radius:20px;background:rgba(4,47,46,.28);backdrop-filter:blur(10px);text-align:right;box-shadow:inset 0 1px rgba(255,255,255,.09)}.clock-label{display:block;color:rgba(255,255,255,.65);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700}.dashboard-hero-clock strong{display:block;font-size:34px;line-height:1.15;margin:8px 0 3px;font-variant-numeric:tabular-nums;letter-spacing:.035em}.dashboard-hero-clock small{color:rgba(255,255,255,.7);font-size:12px}.clock-today{margin-top:16px;padding-top:13px;border-top:1px solid rgba(255,255,255,.14);font-size:12px;color:rgba(255,255,255,.73)}.clock-today span{font-weight:900;color:#fde68a;font-size:15px}.dashboard-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}.dashboard-stat-card{position:relative;display:flex;align-items:center;gap:14px;min-height:132px;padding:20px;border:1px solid #e3e8ef;border-radius:18px;background:rgba(255,255,255,.93);box-shadow:0 10px 30px rgba(30,41,59,.055);overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}.dashboard-stat-card:before{content:"";position:absolute;width:100px;height:100px;border-radius:50%;right:-48px;top:-50px;background:var(--stat-soft,#e9f8f5);opacity:.85}.dashboard-stat-card:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(30,41,59,.1);border-color:var(--stat-border,#cbd5e1)}.dashboard-stat-icon{position:relative;z-index:1;flex:0 0 48px;width:48px;height:48px;display:grid;place-items:center;border-radius:15px;color:var(--stat-color,#0f766e);background:var(--stat-soft,#e9f8f5)}.dashboard-stat-icon svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.dashboard-stat-copy{position:relative;z-index:1;min-width:0}.dashboard-stat-copy>span{display:block;color:#64748b;font-size:12px;font-weight:700}.dashboard-stat-copy strong{display:block;color:#132238;font-size:29px;line-height:1.15;margin:5px 0 4px;letter-spacing:-.03em}.dashboard-stat-copy small{display:block;color:#8490a2;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-stat-arrow{position:absolute;right:14px;bottom:12px;color:var(--stat-color,#0f766e);font-size:17px;opacity:.55;transition:.2s}.dashboard-stat-card:hover .dashboard-stat-arrow{transform:translateX(3px);opacity:1}.stat-total{--stat-color:#2563eb;--stat-soft:#eaf2ff;--stat-border:#a8c7fa}.stat-daftar{--stat-color:#0f766e;--stat-soft:#e6f8f4;--stat-border:#9adace}.stat-rekomendasi{--stat-color:#d97706;--stat-soft:#fff6df;--stat-border:#f8ce7d}.stat-month{--stat-color:#7c3aed;--stat-soft:#f2ebff;--stat-border:#cdb6f5}.trend-up{color:#059669!important}.trend-down{color:#dc2626!important}.dashboard-main-grid{display:grid;grid-template-columns:minmax(0,1.75fr) minmax(300px,.65fr);gap:18px;margin-bottom:18px}.dashboard-panel{background:#fff;border:1px solid #e3e8ef;border-radius:20px;box-shadow:0 10px 32px rgba(30,41,59,.055);overflow:hidden}.dashboard-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:22px 24px 12px}.dashboard-panel-header.compact{align-items:center;padding-bottom:18px;border-bottom:1px solid #edf0f4}.panel-kicker{display:block;color:#0f766e;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}.dashboard-panel-header h3{margin:0;color:#1b2a40;font-size:18px;letter-spacing:-.01em}.dashboard-panel-header p{margin:4px 0 0;color:#7a8597;font-size:12px}.panel-link{color:#0f766e;font-size:12px;font-weight:800;white-space:nowrap}.dashboard-chart-legend{display:flex;align-items:center;gap:13px;padding-top:4px;color:#64748b;font-size:11px;font-weight:600}.dashboard-chart-legend span{display:flex;align-items:center;gap:6px}.dashboard-chart-legend i{display:block;width:9px;height:9px;border-radius:3px}.legend-daftar{background:#0f766e}.legend-rekomendasi{background:#f59e0b}.dashboard-chart-wrap{height:350px;padding:0 17px 8px}.dashboard-chart-wrap canvas{display:block;width:100%;height:330px}.dashboard-composition-panel{display:flex;flex-direction:column}.service-donut-wrap{display:grid;place-items:center;padding:25px 20px 17px}.service-donut{--daftar-angle:0deg;width:168px;height:168px;padding:15px;border-radius:50%;background:conic-gradient(#0f766e 0 var(--daftar-angle),#f59e0b var(--daftar-angle) 360deg);box-shadow:0 13px 30px rgba(15,118,110,.13);position:relative}.service-donut:before{content:"";position:absolute;inset:8px;border-radius:50%;border:1px solid rgba(255,255,255,.7)}.service-donut.is-empty{background:#e9eef4}.service-donut-center{position:relative;z-index:1;width:100%;height:100%;border-radius:50%;background:#fff;display:grid;place-content:center;text-align:center;box-shadow:inset 0 0 0 1px #eef1f4}.service-donut-center strong{font-size:29px;line-height:1;color:#16243a}.service-donut-center span{font-size:11px;color:#8490a2;margin-top:5px}.service-composition-list{display:grid;gap:8px;padding:0 22px 22px}.service-composition-list a{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:10px 11px;border-radius:11px;background:#f8fafc;transition:.2s}.service-composition-list a:hover{background:#f1f5f9;transform:translateX(2px)}.composition-name{display:flex;align-items:center;gap:8px;font-size:12px;color:#475569;font-weight:700}.composition-dot{width:9px;height:9px;border-radius:3px}.composition-dot.daftar{background:#0f766e}.composition-dot.rekomendasi{background:#f59e0b}.service-composition-list strong{font-size:13px}.service-composition-list small{min-width:42px;color:#8490a2;text-align:right;font-size:11px}.dashboard-lower-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(360px,.55fr);gap:18px}.dashboard-activity-list{padding:4px 14px 12px}.dashboard-activity-item{display:grid;grid-template-columns:42px minmax(0,1fr) auto 18px;align-items:center;gap:12px;padding:13px 10px;border-bottom:1px solid #edf0f4;border-radius:10px;transition:.2s}.dashboard-activity-item:last-child{border-bottom:0}.dashboard-activity-item:hover{background:#f8fafc}.activity-icon{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;font-size:13px;font-weight:900}.activity-icon.registration{background:#e6f8f4;color:#0f766e}.activity-icon.recommendation{background:#fff4d9;color:#c26a00}.activity-content{min-width:0}.activity-content strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#243248;font-size:13px}.activity-content strong em{font-style:normal;color:#94a3b8;font-weight:500}.activity-content small{display:block;color:#8490a2;font-size:11px;margin-top:3px}.activity-service{padding:5px 8px;border-radius:999px;font-size:10px;font-weight:800;white-space:nowrap}.activity-service.registration{color:#0d6b63;background:#e6f8f4}.activity-service.recommendation{color:#a95800;background:#fff3d6}.activity-chevron{color:#a7b0bf;font-size:21px}.dashboard-side-stack{display:grid;align-content:start;gap:14px}.dashboard-action-panel{overflow:visible}.quick-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:16px}.quick-action-card{min-height:122px;padding:14px;border-radius:14px;border:1px solid #e3e8ef;background:#f8fafc;display:flex;flex-direction:column;align-items:flex-start;transition:.2s}.quick-action-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(30,41,59,.09)}.quick-action-card>span{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;margin-bottom:10px;font-size:18px;font-weight:800}.quick-action-card strong{font-size:12px;color:#26354b}.quick-action-card small{font-size:10px;color:#8490a2;margin-top:3px;line-height:1.4}.quick-action-card.primary{background:#eefaf7;border-color:#c8ebe4}.quick-action-card.primary>span{background:#0f766e;color:#fff}.quick-action-card.warning{background:#fff9ea;border-color:#f8e0a7}.quick-action-card.warning>span{background:#f59e0b;color:#fff}.quick-action-card.neutral>span{background:#e8eef5;color:#506176}.dashboard-village-card{display:grid;grid-template-columns:48px minmax(0,1fr) 28px;align-items:center;gap:13px;padding:17px 18px;border-radius:18px;color:#fff;background:linear-gradient(135deg,#172a3a,#253d4f);box-shadow:0 15px 32px rgba(23,42,58,.18);overflow:hidden;position:relative}.dashboard-village-card:after{content:"";position:absolute;width:110px;height:110px;border:20px solid rgba(255,255,255,.035);border-radius:50%;right:-50px;top:-45px}.village-card-seal{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.09);font-family:Georgia,serif;font-size:22px;font-weight:700}.dashboard-village-card div:nth-child(2){min-width:0}.dashboard-village-card span,.dashboard-village-card strong,.dashboard-village-card small{display:block}.dashboard-village-card span{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;font-weight:800}.dashboard-village-card strong{font-size:14px;margin:2px 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-village-card small{font-size:10px;color:#c3ccd6;line-height:1.45}.dashboard-village-card>a{position:relative;z-index:1;display:grid;place-items:center;width:28px;height:28px;border-radius:9px;background:rgba(255,255,255,.1);font-size:19px}.dashboard-empty-state{text-align:center;padding:44px 20px 48px;color:#8490a2}.dashboard-empty-state>span{display:grid;place-items:center;width:48px;height:48px;margin:0 auto 12px;border-radius:15px;background:#eef7f5;color:#0f766e;font-size:24px}.dashboard-empty-state strong{display:block;color:#26354b}.dashboard-empty-state p{font-size:12px}.dashboard-empty-state a{display:inline-flex;margin-top:5px;padding:8px 12px;border-radius:9px;background:#0f766e;color:#fff;font-size:11px;font-weight:800}.dashboard-body .topbar{background:rgba(255,255,255,.88);box-shadow:0 1px 0 rgba(226,232,240,.8)}.dashboard-body .topbar h1{letter-spacing:-.02em}.dashboard-body .topbar-badge{box-shadow:inset 0 0 0 1px rgba(15,118,110,.09)}
@keyframes dashboardPulse{0%,100%{box-shadow:0 0 0 4px rgba(134,239,172,.14)}50%{box-shadow:0 0 0 8px rgba(134,239,172,0)}}
@media(max-width:1260px){.dashboard-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-main-grid{grid-template-columns:minmax(0,1.45fr) minmax(290px,.55fr)}.dashboard-lower-grid{grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr)}}
@media(max-width:1030px){.dashboard-main-grid,.dashboard-lower-grid{grid-template-columns:1fr}.dashboard-side-stack{grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr)}.dashboard-village-card{align-self:stretch}.dashboard-hero{padding:32px}.dashboard-hero h2{font-size:30px}}
@media(max-width:760px){.dashboard-hero{min-height:auto;align-items:flex-start;flex-direction:column;padding:28px 24px}.dashboard-hero-clock{width:100%;min-width:0;text-align:left}.dashboard-hero-clock strong{font-size:29px}.dashboard-stat-grid{grid-template-columns:1fr 1fr}.dashboard-main-grid,.dashboard-lower-grid{gap:14px}.dashboard-side-stack{grid-template-columns:1fr}.dashboard-panel-header{padding:19px 18px 11px}.dashboard-panel-header.compact{padding:18px}.dashboard-chart-legend{display:none}.dashboard-chart-wrap{padding:0 8px;height:320px}.dashboard-activity-item{grid-template-columns:40px minmax(0,1fr) 15px}.activity-service{display:none}}
@media(max-width:520px){.dashboard-page{margin:-2px}.dashboard-hero{border-radius:20px;padding:24px 20px}.dashboard-hero h2{font-size:26px}.dashboard-hero p{font-size:13px}.dashboard-hero-actions{width:100%}.hero-btn{flex:1;justify-content:center;padding:10px 12px}.dashboard-stat-grid{grid-template-columns:1fr;gap:11px}.dashboard-stat-card{min-height:112px;padding:16px}.dashboard-stat-copy strong{font-size:26px}.quick-action-grid{grid-template-columns:1fr 1fr}.quick-action-card{min-height:115px}.service-donut{width:150px;height:150px}.dashboard-panel-header h3{font-size:16px}}
@media(prefers-reduced-motion:reduce){.status-dot{animation:none}.dashboard-stat-card,.hero-btn,.quick-action-card,.dashboard-activity-item{transition:none}}
@media print{.dashboard-hero,.dashboard-stat-grid,.dashboard-main-grid,.dashboard-lower-grid{break-inside:avoid}.dashboard-hero{background:#0f766e!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.dashboard-chart-wrap{height:300px}}

/* Akad Nikah */
.akad-tab{display:inline-flex;align-items:center;gap:7px}.akad-tab span{font-size:15px}.akad-section{position:relative;overflow:hidden;border-color:#b9ded6;background:linear-gradient(180deg,#fff 0%,#fbfffe 100%)}.akad-section:after{content:"";position:absolute;width:190px;height:190px;border-radius:50%;right:-90px;top:-100px;background:radial-gradient(circle,rgba(15,118,110,.12),rgba(15,118,110,0) 70%);pointer-events:none}.akad-intro{position:relative;z-index:1;display:flex;align-items:center;gap:13px;padding:15px 17px;margin-bottom:20px;border:1px solid #cce9e3;border-radius:15px;background:linear-gradient(135deg,#ebfaf6,#f8fffd)}.akad-intro-icon{width:43px;height:43px;display:grid;place-items:center;flex:0 0 43px;border-radius:13px;background:linear-gradient(135deg,#0f766e,#16a085);box-shadow:0 9px 20px rgba(15,118,110,.2);font-size:20px}.akad-intro strong,.akad-intro span{display:block}.akad-intro strong{color:#164e49;font-size:14px}.akad-intro span{color:#66817d;font-size:12px;margin-top:3px}.akad-grid .form-control[readonly]{background:#eef6f4;color:#0f5e58;border-color:#b7dcd5;font-weight:800;cursor:not-allowed}.akad-summary-cell strong{display:block;color:#164e49;font-size:12px}.akad-summary-cell span{display:block;color:#64748b;font-size:11px;margin-top:2px}.akad-summary-empty{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;background:#fff7df;color:#a16207;font-size:10px;font-weight:800}.btn-akad{border-color:#9bd6ca!important;background:#edfaf7!important;color:#0f6f67!important}.btn-akad:hover{background:#dff6f1!important;transform:translateY(-1px)}.akad-detail-card{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:18px;border:1px solid #cde8e2;border-radius:17px;background:linear-gradient(135deg,#f3fcfa,#fff);box-shadow:0 8px 24px rgba(15,118,110,.06)}.akad-detail-item{padding:13px;border-radius:13px;background:#fff;border:1px solid #e2eeeb}.akad-detail-item.full{grid-column:1/-1}.akad-detail-item dt{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:#77908b;font-weight:800}.akad-detail-item dd{margin:5px 0 0;color:#183b38;font-weight:800;line-height:1.45}.akad-detail-empty{padding:18px;border:1px dashed #dfb65d;border-radius:14px;background:#fffbeb;color:#8a5a00}.akad-detail-empty a{font-weight:800;text-decoration:underline}@media(max-width:760px){.akad-detail-card{grid-template-columns:1fr 1fr}}@media(max-width:480px){.akad-detail-card{grid-template-columns:1fr}.akad-detail-item.full{grid-column:auto}.akad-intro{align-items:flex-start}}

/* REGIS SIMKAH dan penyempurnaan visual */
.registration-meta-grid{align-items:end}.simkah-number{display:inline-flex;align-items:center;padding:6px 10px;border-radius:10px;background:linear-gradient(135deg,#e8faf5,#f7fffc);border:1px solid #bfe8dd;color:#0b6b63;font-size:12px;letter-spacing:.02em;white-space:nowrap}.simkah-detail-badge{display:inline-flex;gap:6px;align-items:center;margin-top:9px;padding:7px 10px;border-radius:10px;background:#eaf9f5;border:1px solid #c5e9e0;color:#17645e;font-size:12px}.dashboard-v2{background:linear-gradient(180deg,#f8fbfc 0,#f4f8fa 100%);border-radius:24px;padding:2px}.dashboard-v2 .v2-panel,.dashboard-v2 .v2-stat-card{box-shadow:0 12px 35px rgba(22,50,65,.08);border:1px solid rgba(218,228,234,.9)}.dashboard-v2 .v2-stat-card:hover{transform:translateY(-4px);box-shadow:0 18px 42px rgba(15,118,110,.14)}.dashboard-topbar{min-height:145px}.topbar-scene{opacity:.98}.sidebar{background:linear-gradient(180deg,#0a7d71 0%,#075f67 52%,#064d5a 100%)}.sidebar:after{content:"";position:absolute;inset:auto 0 0 0;height:46%;pointer-events:none;background:radial-gradient(circle at 28% 80%,rgba(45,212,191,.15),transparent 40%),linear-gradient(180deg,transparent,rgba(0,30,40,.18))}.nav-link{border:1px solid transparent}.nav-link.active{background:linear-gradient(135deg,#20c997,#0fb79f);border-color:rgba(255,255,255,.2);box-shadow:0 10px 26px rgba(0,0,0,.16),inset 0 1px rgba(255,255,255,.2)}.sidebar-footer{position:relative;z-index:2}.user-card,.logout-link{backdrop-filter:blur(8px)}

/* =========================================================
   Dashboard & Navigation Premium v2.2
   ========================================================= */
:root{
  --ui-navy:#14213a;
  --ui-teal:#087f73;
  --ui-teal-dark:#045b62;
  --ui-green:#18b892;
  --ui-cyan:#139bb5;
  --ui-purple:#7b4ce1;
  --ui-orange:#f4a51c;
  --ui-page:#f5f8fb;
  --ui-line:#e5edf2;
  --ui-card-shadow:0 14px 40px rgba(25,54,74,.08);
  --ui-card-shadow-hover:0 22px 48px rgba(8,127,115,.14)
}
body{background:radial-gradient(circle at 88% 2%,rgba(80,210,184,.08),transparent 24%),var(--ui-page);color:var(--ui-navy)}
.sidebar{width:286px;padding:22px 16px 20px;background:linear-gradient(155deg,#0a927f 0%,#06726e 35%,#055b67 72%,#064553 100%);box-shadow:16px 0 44px rgba(4,72,82,.16);overflow:hidden;isolation:isolate}
.sidebar-glow{position:absolute;z-index:-1;width:340px;height:340px;border-radius:50%;left:-180px;top:-110px;background:radial-gradient(circle,rgba(60,255,211,.30),rgba(60,255,211,0) 68%)}
.sidebar-pattern{position:absolute;z-index:-1;inset:auto -40px 0 -40px;height:48%;opacity:.28;background:radial-gradient(circle at 30% 55%,rgba(73,224,194,.35),transparent 35%),repeating-radial-gradient(circle at 40% 100%,transparent 0 18px,rgba(255,255,255,.035) 19px 20px)}
.sidebar:before{content:"";position:absolute;z-index:-1;width:235px;height:235px;border:1px solid rgba(255,255,255,.06);border-radius:46% 54% 55% 45%;right:-115px;top:210px;transform:rotate(20deg);box-shadow:0 0 0 24px rgba(255,255,255,.018),0 0 0 48px rgba(255,255,255,.012)}
.sidebar:after{height:42%;background:linear-gradient(180deg,transparent,rgba(0,29,38,.28)),radial-gradient(circle at 25% 70%,rgba(45,212,191,.18),transparent 42%)}
.brand{min-height:76px;padding:2px 6px 22px;gap:13px;border-bottom:1px solid rgba(255,255,255,.14);position:relative;z-index:2}
.brand-mark{width:50px;height:50px;border-radius:16px;color:#08796f;background:linear-gradient(145deg,#fff,#eefdfa);box-shadow:0 12px 26px rgba(0,33,40,.22),inset 0 0 0 1px rgba(255,255,255,.7);font-size:16px;letter-spacing:.03em}
.brand-copy strong{font-size:19px;letter-spacing:-.02em}.brand-copy span{font-size:12px;color:#c8f6ed;opacity:.95;margin-top:2px}
.nav-caption{display:block;margin:22px 13px 9px;color:rgba(220,255,248,.56);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.16em}
.nav-menu{margin-top:0;gap:7px;position:relative;z-index:2}
.nav-link{min-height:54px;padding:10px 12px;border-radius:15px;gap:12px;color:rgba(235,255,252,.83);font-size:13px;font-weight:700;border:1px solid transparent;position:relative;overflow:hidden;transform:none!important}
.nav-link:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.10),transparent);opacity:0;transition:.25s}
.nav-link:hover{background:rgba(255,255,255,.075);color:#fff;border-color:rgba(255,255,255,.08)}
.nav-link:hover:before{opacity:1}
.nav-link.active{background:linear-gradient(135deg,#19c59c,#0fa79c);color:#fff;border-color:rgba(255,255,255,.23);box-shadow:0 12px 28px rgba(0,34,43,.24),inset 0 1px rgba(255,255,255,.25)}
.nav-link.active:after{content:"";position:absolute;width:80px;height:80px;border-radius:50%;right:-36px;top:-38px;background:rgba(255,255,255,.10)}
.nav-icon{width:34px;height:34px;flex:0 0 34px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.08);transition:.25s}
.nav-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.nav-link:hover .nav-icon{background:rgba(255,255,255,.13);transform:scale(1.04)}
.nav-link.active .nav-icon{background:rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.13)}
.nav-text{flex:1}.nav-indicator{width:5px;height:5px;border-radius:50%;background:#bff9ed;opacity:0;box-shadow:0 0 0 4px rgba(191,249,237,.12)}.nav-link.active .nav-indicator{opacity:1}
.sidebar-footer{padding-top:15px;border-top:1px solid rgba(255,255,255,.14);position:relative;z-index:3}
.user-card{display:grid;grid-template-columns:42px minmax(0,1fr) 22px;align-items:center;gap:11px;padding:12px;border:1px solid rgba(255,255,255,.14);border-radius:16px;background:rgba(2,50,58,.22);box-shadow:inset 0 1px rgba(255,255,255,.05);transition:.2s}
.user-card:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.2)}
.user-card .avatar{width:42px;height:42px;background:linear-gradient(135deg,#73d7c6,#3ba99c);box-shadow:0 8px 18px rgba(0,34,42,.22)}
.user-card-copy{min-width:0}.user-card-copy strong,.user-card-copy span{display:block}.user-card-copy strong{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-copy span{font-size:10px;color:#bde9e3;margin-top:2px}.user-card-chevron{width:18px;height:18px;fill:none;stroke:#d7fff7;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.logout-link{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;height:45px;border-radius:13px;border:1px solid rgba(129,240,220,.28);background:linear-gradient(135deg,rgba(35,190,164,.16),rgba(5,61,69,.25));font-size:12px;font-weight:800;transition:.22s}
.logout-link svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.logout-link:hover{background:rgba(255,255,255,.11);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.main-area{margin-left:286px;background:transparent}
.topbar{height:96px;padding:0 34px;background:rgba(255,255,255,.89);border-bottom:1px solid rgba(218,228,234,.88);box-shadow:0 4px 22px rgba(37,63,82,.035);backdrop-filter:blur(16px)}
.dashboard-topbar{min-height:142px;height:142px;overflow:hidden}
.topbar-heading{position:relative;z-index:2}.topbar-heading h1{font-size:28px;letter-spacing:-.035em;color:#15213a}.topbar-heading p{display:flex;align-items:center;gap:7px;font-size:12px;color:#718096;margin-top:7px}.topbar-heading p svg{width:15px;height:15px;fill:none;stroke:#6f8595;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.topbar-scene{position:absolute;right:20px;bottom:-4px;width:min(43%,470px);height:132px;display:flex;align-items:flex-end;justify-content:flex-end;pointer-events:none}.topbar-scene svg{width:100%;height:100%;filter:drop-shadow(0 8px 16px rgba(27,145,124,.08))}
.topbar-badge{margin-left:auto;background:linear-gradient(135deg,#e8faf5,#f6fffc);border:1px solid #c8ebe2;color:#0b6d64;box-shadow:0 7px 18px rgba(15,118,110,.08)}
.content{padding:25px 28px 34px;max-width:1680px;width:100%;margin:0 auto}
.dashboard-v2{padding:0;background:transparent;border-radius:0}
.v2-welcome{position:relative;display:flex;justify-content:space-between;align-items:center;gap:22px;min-height:126px;padding:26px 28px;margin-bottom:18px;border-radius:22px;color:#fff;overflow:hidden;background:linear-gradient(125deg,#087b72 0%,#0b9582 45%,#11a98b 100%);box-shadow:0 20px 42px rgba(8,127,115,.19)}
.v2-welcome:before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;right:-110px;top:-155px;border:40px solid rgba(255,255,255,.055)}.v2-welcome:after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 52%,rgba(255,255,255,.06));pointer-events:none}
.v2-welcome>div{position:relative;z-index:1}.v2-live{display:inline-flex;align-items:center;gap:7px;margin-bottom:9px;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.13);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.09em}.v2-live i{width:7px;height:7px;border-radius:50%;background:#8fffdc;box-shadow:0 0 0 5px rgba(143,255,220,.12);animation:v2Pulse 1.8s infinite}
.v2-welcome>div>strong{display:block;font-size:25px;letter-spacing:-.025em}.v2-welcome p{max-width:650px;margin:6px 0 0;color:#d8fff7;font-size:12px}.v2-today{min-width:135px;padding:15px 18px;border:1px solid rgba(255,255,255,.2);border-radius:17px;text-align:center;background:rgba(255,255,255,.11);backdrop-filter:blur(6px)}.v2-today span,.v2-today small{display:block}.v2-today span{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:#cafff3}.v2-today strong{display:block;font-size:30px;line-height:1.1;margin:4px 0}.v2-today small{font-size:10px;color:#d9fff7}
.v2-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:15px;margin-bottom:18px}
.v2-stat-card{min-height:151px;padding:18px;border-radius:19px;background:#fff;display:grid;grid-template-columns:47px minmax(0,1fr);grid-template-rows:1fr auto;gap:10px 13px;position:relative;overflow:hidden;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease;border:1px solid #e4edf2!important;box-shadow:var(--ui-card-shadow)!important}
.v2-stat-card:before{content:"";position:absolute;width:98px;height:98px;border-radius:50%;right:-46px;top:-45px;background:var(--stat-soft,#ebfaf7)}
.v2-stat-card:hover{transform:translateY(-5px)!important;box-shadow:var(--ui-card-shadow-hover)!important;border-color:#cdebe4!important}
.v2-stat-icon{width:47px;height:47px;border-radius:15px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--stat-a,#16a88f),var(--stat-b,#0a8177));box-shadow:0 10px 21px color-mix(in srgb,var(--stat-a,#16a88f) 24%,transparent)}.v2-stat-icon svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.v2-stat-total{--stat-a:#2fc9a4;--stat-b:#0ea487;--stat-soft:#e9fbf6}.v2-stat-daftar{--stat-a:#19a9c7;--stat-b:#087f9e;--stat-soft:#e9f8fc}.v2-stat-rekomendasi{--stat-a:#42c763;--stat-b:#14933e;--stat-soft:#edfbed}.v2-stat-month{--stat-a:#9865eb;--stat-b:#7141cb;--stat-soft:#f2ecfd}
.v2-stat-content{min-width:0}.v2-stat-content small,.v2-stat-content strong,.v2-stat-content em{display:block}.v2-stat-content small{font-size:11px;font-weight:750;color:#5b687b}.v2-stat-content strong{font-size:29px;line-height:1.05;margin:7px 0 8px;color:#17243c;letter-spacing:-.035em}.v2-stat-content em{font-style:normal;font-size:9px;color:#7b8796}.v2-stat-content em b,.v2-stat-content em.is-up{color:#17935b}.v2-stat-content em.is-down{color:#c54545}
.v2-stat-link{grid-column:1/-1;padding-top:10px;border-top:1px solid #edf2f5;display:flex;align-items:center;justify-content:space-between;font-size:9px;font-weight:800;color:#728091}.v2-stat-link b{width:23px;height:23px;border-radius:8px;display:grid;place-items:center;background:#edf8f5;color:#0e7d71}
.v2-main-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(285px,.62fr);gap:17px;margin-bottom:17px}.v2-lower-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr);gap:17px}
.v2-panel{background:#fff;border:1px solid #e3ebf0!important;border-radius:20px;box-shadow:var(--ui-card-shadow)!important;overflow:hidden;transition:box-shadow .25s,border-color .25s}.v2-panel:hover{box-shadow:0 18px 44px rgba(31,63,82,.105)!important;border-color:#d8e6eb!important}
.v2-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:20px 21px 12px}.v2-panel-head.compact{align-items:center;padding-bottom:16px;border-bottom:1px solid #edf2f5}.v2-panel-head span{display:block;font-size:8px;font-weight:850;letter-spacing:.14em;color:#15907f}.v2-panel-head h2{margin:4px 0 0;font-size:16px;letter-spacing:-.015em;color:#1a2940}.v2-panel-head p{font-size:10px;color:#8490a1;margin:4px 0 0}.v2-panel-head>a{padding:7px 10px;border:1px solid #d9e8e5;border-radius:9px;color:#0c7a6f;font-size:9px;font-weight:800;background:#f7fcfa}.v2-panel-head>a:hover{background:#ebf9f5}
.v2-legend{display:flex;gap:12px;padding:7px 9px;border-radius:10px;background:#f7fafb}.v2-legend span{display:flex;align-items:center;gap:5px;color:#6b7789;font-size:8px;letter-spacing:0;text-transform:none}.v2-legend i,.v2-composition-list i{width:8px;height:8px;border-radius:50%}.v2-legend i.daftar,.v2-composition-list i.daftar{background:#16aa91}.v2-legend i.rekomendasi,.v2-composition-list i.rekomendasi{background:#f3a51d}
.v2-chart-area{height:285px;padding:2px 17px 4px}.v2-chart-area canvas{width:100%!important;height:100%!important}.v2-chart-insight{display:grid;grid-template-columns:38px minmax(0,1fr) auto;gap:11px;align-items:center;margin:4px 18px 18px;padding:12px 14px;border:1px solid #d4eee8;border-radius:13px;background:linear-gradient(135deg,#effbf8,#f9fffd)}.v2-insight-icon{width:35px;height:35px;border-radius:11px;display:grid;place-items:center;background:#dff7f1;color:#0c8a78}.v2-insight-icon svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.v2-chart-insight strong{font-size:10px}.v2-chart-insight p{font-size:9px;color:#748393;margin:2px 0 0}.v2-chart-insight>a{font-size:9px;font-weight:800;color:#0e7e72}
.v2-donut-wrap{display:grid;place-items:center;padding:14px 0}.v2-donut{width:168px;height:168px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(#18ad92 0 var(--daftar-angle),#f4a51c var(--daftar-angle) 100%);box-shadow:0 12px 28px rgba(20,117,104,.11);position:relative}.v2-donut:after{content:"";position:absolute;inset:32px;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 1px #edf1f4}.v2-donut>div{position:relative;z-index:1;text-align:center}.v2-donut strong,.v2-donut span{display:block}.v2-donut strong{font-size:26px}.v2-donut span{font-size:9px;color:#7e8a98}.v2-donut.empty{background:#edf2f4}
.v2-composition-list{display:grid;padding:0 20px 15px}.v2-composition-list>a{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #edf2f5}.v2-composition-list>a:last-child{border-bottom:0}.v2-composition-list span{display:flex;align-items:center;gap:8px;font-size:10px;color:#465569}.v2-composition-list strong{font-size:11px}.v2-composition-list small{min-width:38px;text-align:right;font-size:8px;color:#8994a3}.v2-primary-action{display:flex;align-items:center;justify-content:center;gap:7px;margin:0 18px 18px;height:41px;border-radius:12px;color:#fff;background:linear-gradient(135deg,#13aa8e,#087b72);box-shadow:0 10px 22px rgba(8,127,115,.18);font-size:10px;font-weight:800}.v2-primary-action:hover{filter:brightness(1.04);transform:translateY(-1px)}
.v2-latest-list{display:grid}.v2-latest-item{display:grid;grid-template-columns:42px minmax(0,1fr) auto 16px;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid #edf2f5;transition:.18s}.v2-latest-item:last-child{border-bottom:0}.v2-latest-item:hover{background:#f8fcfb;padding-left:21px}.v2-couple-avatar{width:40px;height:40px;position:relative}.v2-couple-avatar b,.v2-couple-avatar i{position:absolute;width:28px;height:28px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:10px;font-style:normal;border:2px solid #fff}.v2-couple-avatar b{left:0;top:0;background:linear-gradient(135deg,#178fb0,#0c7191)}.v2-couple-avatar i{right:0;bottom:0;background:linear-gradient(135deg,#ef9b7d,#db6d74)}.v2-latest-copy{min-width:0}.v2-latest-copy strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:10px;color:#25364c}.v2-latest-copy strong em{font-style:normal;color:#9aa5b1;font-weight:500}.v2-latest-copy small{display:flex;align-items:center;gap:5px;margin-top:4px;font-size:8px;color:#8793a2}.v2-latest-copy small svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.v2-service-badge{padding:5px 8px;border-radius:999px;font-size:8px;font-weight:800;white-space:nowrap}.v2-service-badge.daftar{color:#087566;background:#e6f8f3}.v2-service-badge.rekomendasi{color:#a66300;background:#fff4d9}.v2-item-more{color:#9ba7b5;font-size:16px}.v2-empty{text-align:center;padding:45px 20px;color:#8290a0}.v2-empty span{font-size:24px}.v2-empty strong{display:block;color:#293a50;margin-top:7px}.v2-empty p{font-size:10px}.v2-empty a{display:inline-block;padding:7px 11px;border-radius:9px;background:#0d8276;color:#fff;font-size:9px;font-weight:800}
.v2-info-list{padding:4px 18px}.v2-info-item{display:grid;grid-template-columns:39px minmax(0,1fr);gap:11px;padding:13px 0;border-bottom:1px solid #edf2f5}.v2-info-item:last-child{border-bottom:0}.v2-info-item>span{width:38px;height:38px;border-radius:12px;display:grid;place-items:center}.v2-info-item>span.green{color:#0d967d;background:#e8f9f5}.v2-info-item>span.blue{color:#2086bd;background:#eaf6fd}.v2-info-item>span.purple{color:#7b4ce1;background:#f2edfd}.v2-info-item svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.v2-info-item strong{display:block;font-size:10px}.v2-info-item p{font-size:9px;color:#788596;margin:3px 0;line-height:1.5}.v2-info-item small{font-size:8px;color:#a0a9b4}.v2-quick-row{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:14px 18px 18px}.v2-quick-row>a{display:grid;grid-template-columns:29px minmax(0,1fr);column-gap:8px;padding:11px;border:1px solid #e2ebef;border-radius:12px;background:#f9fbfc}.v2-quick-row>a:hover{border-color:#bfe4dc;background:#f3fbf9}.v2-quick-row span{grid-row:1/3;width:28px;height:28px;border-radius:9px;background:#e2f7f1;color:#0b8576;display:grid;place-items:center;font-weight:800}.v2-quick-row strong{font-size:9px}.v2-quick-row small{font-size:7px;color:#8c97a4}
@keyframes v2Pulse{0%,100%{box-shadow:0 0 0 4px rgba(143,255,220,.13)}50%{box-shadow:0 0 0 9px rgba(143,255,220,0)}}
@media(max-width:1250px){.v2-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.v2-main-grid,.v2-lower-grid{grid-template-columns:1fr}.topbar-scene{width:45%}}
@media(max-width:900px){.sidebar{width:286px}.main-area{margin-left:0}.topbar{height:82px;min-height:82px}.dashboard-topbar{height:100px;min-height:100px}.topbar-scene{opacity:.55;width:52%}.content{padding:18px}.v2-welcome{min-height:115px}.v2-main-grid,.v2-lower-grid{gap:14px}}
@media(max-width:650px){.topbar-scene{display:none}.dashboard-topbar{height:88px;min-height:88px}.topbar-heading h1{font-size:21px}.v2-welcome{padding:21px;align-items:flex-start}.v2-welcome>div>strong{font-size:20px}.v2-today{min-width:105px}.v2-stat-grid{grid-template-columns:1fr}.v2-main-grid,.v2-lower-grid{display:block}.v2-panel{margin-bottom:14px}.v2-chart-area{height:245px}.v2-chart-insight{grid-template-columns:35px minmax(0,1fr)}.v2-chart-insight>a{grid-column:2}.v2-latest-item{grid-template-columns:40px minmax(0,1fr) 16px}.v2-service-badge{display:none}.v2-quick-row{grid-template-columns:1fr}}
@media(max-width:430px){.content{padding:13px}.v2-welcome{display:block}.v2-today{margin-top:15px;width:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;text-align:left}.v2-today small{text-align:right}.v2-stat-card{min-height:140px}.v2-panel-head{padding:17px 16px 11px}.v2-legend{display:none}.v2-chart-area{padding-inline:8px}.v2-donut{width:150px;height:150px}.v2-latest-item{padding-inline:14px}}
@media(prefers-reduced-motion:reduce){.v2-live i{animation:none}.v2-stat-card,.v2-panel,.nav-link,.quick-action-card{transition:none}}


/* =========================================================
   Hotfix Dashboard Premium v2.3
   ========================================================= */
.brand-mark{font-size:17px;font-weight:900;letter-spacing:.04em}
.brand-mark span{display:inline-block;transform:translateY(1px)}
.topbar{background:rgba(255,255,255,.94);backdrop-filter:blur(18px)}
.topbar-heading h1{font-weight:800}
.v2-welcome{border:1px solid #d6ece7;box-shadow:0 18px 38px rgba(20,67,86,.06)}
.v2-welcome strong{font-weight:800}
.v2-stat-card,.v2-panel,.user-card,.logout-link,.nav-link{transition:all .25s ease}
.v2-stat-card:hover,.v2-panel:hover{transform:translateY(-4px)}
.v2-panel-head h2{font-weight:800}
.v2-latest-item:nth-child(even){background:linear-gradient(180deg,#fbfdfd,#f8fbfc)}
.v2-latest-item:hover{background:#eefbf8}
.v2-info-panel .v2-panel-head{background:linear-gradient(180deg,#fbfffe,#f4fbfa)}
.v2-info-item strong{font-size:11px}
.v2-quick-row a{box-shadow:0 10px 22px rgba(16,96,88,.05)}
.v2-primary-action span{font-size:16px;line-height:1}
.footer{background:transparent;color:#7b8794}
.footer span:last-child{font-weight:700;color:#0c7a6f}
@media (max-width:900px){.sidebar{box-shadow:22px 0 40px rgba(1,39,49,.32)}}


/* =========================================================
   Dashboard Refinement Premium v2.5
   ========================================================= */
.dashboard-v2{position:relative}
.dashboard-v2:before{content:"";position:absolute;inset:0 auto auto 0;width:42%;height:240px;background:radial-gradient(circle at left top,rgba(44,208,175,.08),transparent 72%);pointer-events:none}
.dashboard-v2:after{content:"";position:absolute;right:0;top:0;width:320px;height:260px;background:radial-gradient(circle at 70% 10%,rgba(39,191,163,.10),transparent 70%);pointer-events:none}
.v2-welcome,.v2-stat-card,.v2-panel{position:relative;z-index:1}
.v2-welcome{background:linear-gradient(135deg,#ffffff 0%,#f8fefd 65%,#eefaf7 100%);border-radius:24px;overflow:hidden}
.v2-welcome:before{content:"";position:absolute;right:-40px;top:-56px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(38,200,165,.18),rgba(38,200,165,0) 72%)}
.v2-welcome:after{content:"";position:absolute;left:40%;bottom:-72px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(19,155,181,.10),rgba(19,155,181,0) 72%)}
.v2-live{box-shadow:0 8px 18px rgba(20,151,126,.12)}
.v2-today{background:linear-gradient(135deg,#ffffff,#f4fffb);border:1px solid #d4eee7;box-shadow:0 12px 24px rgba(13,128,116,.08)}
.v2-today strong{font-size:38px;background:linear-gradient(135deg,#0b8d7f,#14b997);-webkit-background-clip:text;background-clip:text;color:transparent}
.v2-stat-card{background:linear-gradient(180deg,#fff 0%,#fcfefe 100%)}
.v2-stat-card:after{content:"";position:absolute;left:18px;right:18px;bottom:0;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--stat-a,#2fc9a4),transparent 78%);opacity:.75}
.v2-stat-card:hover .v2-stat-icon{transform:translateY(-2px) scale(1.04)}
.v2-stat-link{margin-top:2px}
.v2-panel{background:linear-gradient(180deg,#ffffff 0%,#fcfefe 100%)}
.v2-panel-head{background:linear-gradient(180deg,#ffffff 0%,#fbfdfd 100%)}
.v2-chart-panel .v2-panel-head,.v2-latest-panel .v2-panel-head{border-bottom:1px solid #edf2f5}
.v2-chart-area{padding-top:10px}
.v2-chart-insight{box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.v2-composition-panel .v2-donut-wrap{padding-top:20px}
.v2-donut{box-shadow:0 14px 34px rgba(17,120,108,.14), inset 0 2px 10px rgba(255,255,255,.35)}
.v2-composition-list a:hover{padding-left:6px}
.v2-primary-action{position:relative;overflow:hidden}
.v2-primary-action:before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.22) 50%,transparent 80%);transform:translateX(-120%);transition:transform .7s ease}
.v2-primary-action:hover:before{transform:translateX(120%)}
.v2-latest-panel .v2-panel-head,.v2-info-panel .v2-panel-head{padding-bottom:14px}
.v2-latest-list{padding:8px 0}
.v2-latest-item{border-bottom:1px solid #edf3f6}
.v2-latest-item:hover{box-shadow:inset 4px 0 0 #1ab89b}
.v2-couple-avatar b,.v2-couple-avatar i{box-shadow:0 6px 14px rgba(28,67,78,.18)}
.v2-item-more{display:grid;place-items:center;width:20px;height:20px;border-radius:7px;background:#f4f7fa}
.v2-info-panel{background:linear-gradient(180deg,#ffffff 0%,#fbfefd 100%)}
.v2-info-list{padding-top:6px}
.v2-info-item{align-items:flex-start}
.v2-info-item>span{box-shadow:0 8px 20px rgba(31,78,92,.08)}
.v2-quick-row{padding-top:10px}
.v2-quick-row a{background:linear-gradient(180deg,#ffffff 0%,#f8fcfc 100%)}
.v2-quick-row a:hover{transform:translateY(-2px);box-shadow:0 16px 26px rgba(21,99,97,.08)}
.v2-quick-row span{box-shadow:0 8px 18px rgba(11,133,118,.14)}
.topbar-scene svg{filter:drop-shadow(0 12px 20px rgba(50,154,137,.08))}
.topbar-badge{background:linear-gradient(135deg,#e9fbf7,#d8f6ee);border:1px solid #c3ece1}
.brand-mark{position:relative;overflow:hidden}
.brand-mark:before{content:"";position:absolute;inset:-20% auto auto -40%;width:80%;height:180%;background:linear-gradient(115deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%);transform:rotate(22deg)}
.nav-link.active .nav-indicator{box-shadow:0 0 0 6px rgba(191,249,237,.10),0 0 18px rgba(191,249,237,.55)}
.user-card{background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.06))}
.logout-link{box-shadow:0 12px 24px rgba(3,44,51,.18)}
.footer{border-top:1px solid rgba(223,232,238,.9)}
@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.v2-stat-card:nth-child(1){animation:floatSoft 5.2s ease-in-out infinite}
.v2-stat-card:nth-child(2){animation:floatSoft 5.8s ease-in-out infinite}
.v2-stat-card:nth-child(3){animation:floatSoft 6.1s ease-in-out infinite}
.v2-stat-card:nth-child(4){animation:floatSoft 6.5s ease-in-out infinite}
@media (max-width:900px){.v2-stat-card:nth-child(n){animation:none}.v2-welcome:before,.v2-welcome:after,.dashboard-v2:before,.dashboard-v2:after{display:none}}
@media (prefers-reduced-motion:reduce){.v2-stat-card:nth-child(n),.v2-primary-action:before{animation:none;transition:none}}


/* =========================================================
   Dashboard Modern Luxury v2.6
   ========================================================= */
body.dashboard-body,
body.dashboard-v2-body{background:
  radial-gradient(circle at 10% 8%, rgba(41, 207, 169, .10), transparent 22%),
  radial-gradient(circle at 90% 6%, rgba(19, 155, 181, .09), transparent 20%),
  linear-gradient(180deg, #f5fbfc 0%, #f2f7fa 45%, #eef4f8 100%)}
.app-shell{background:transparent}
.sidebar{border-right:1px solid rgba(255,255,255,.10);background:
  linear-gradient(180deg,#0aa08a 0%,#087d79 34%,#075c6c 68%,#083f52 100%)}
.sidebar:before{opacity:.9}
.sidebar-pattern{opacity:.38}
.brand{margin-bottom:8px}
.brand-mark{width:54px;height:54px;border-radius:18px;background:linear-gradient(145deg,#ffffff 0%,#effdfa 100%);box-shadow:0 14px 34px rgba(0,35,44,.22), inset 0 1px 0 rgba(255,255,255,.85)}
.brand-copy strong{font-size:20px;font-weight:800}
.brand-copy span{font-size:12px;letter-spacing:.02em}
.nav-caption{margin-top:18px;margin-bottom:10px;color:rgba(223,255,249,.64)}
.nav-link{min-height:56px;padding:11px 13px;border-radius:17px;background:rgba(255,255,255,.02)}
.nav-link:hover{background:rgba(255,255,255,.10);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.nav-link.active{background:linear-gradient(135deg,#26d3aa 0%,#11b8a1 48%,#0aa3a2 100%);box-shadow:0 18px 34px rgba(0,39,47,.26), inset 0 1px 0 rgba(255,255,255,.28)}
.nav-link.active .nav-icon{background:rgba(255,255,255,.20)}
.nav-indicator{width:7px;height:7px}
.user-card{border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.05));border-color:rgba(255,255,255,.16);box-shadow:0 10px 26px rgba(2,42,50,.14)}
.user-card .avatar{width:46px;height:46px;font-size:15px}
.logout-link{height:48px;border-radius:15px;background:linear-gradient(135deg,rgba(35,190,164,.18),rgba(255,255,255,.04));border-color:rgba(156,248,232,.24)}
.main-area{padding-bottom:14px}
.topbar{margin:18px 18px 0 18px;border:1px solid rgba(220,231,236,.95);border-radius:28px;height:100px;min-height:100px;padding:0 34px;box-shadow:0 16px 40px rgba(27,56,78,.08)}
.dashboard-topbar{height:158px;min-height:158px}
.topbar-heading h1{font-size:31px;font-weight:850;letter-spacing:-.04em}
.topbar-heading p{font-size:13px;color:#6e7e90;font-weight:600}
.topbar-heading p svg{width:17px;height:17px}
.topbar-scene{right:16px;width:40%;max-width:470px;opacity:1}
.topbar-scene svg{filter:drop-shadow(0 20px 30px rgba(46,154,138,.10))}
.content{padding:20px 18px 18px}
.dashboard-v2{display:block}
.v2-welcome{padding:26px 28px;border-radius:26px;min-height:138px;background:
  linear-gradient(135deg,#ffffff 0%,#f9ffff 55%,#eefbf8 100%);box-shadow:0 18px 42px rgba(19,69,88,.08);border:1px solid #d8ece8}
.v2-welcome>div>strong{font-size:28px;letter-spacing:-.03em;margin-top:10px}
.v2-welcome p{font-size:14px;max-width:720px;color:#607287}
.v2-live{padding:8px 12px;border-radius:999px;background:#ecfbf7;color:#0d8a78;font-size:11px;letter-spacing:.05em}
.v2-live i{width:9px;height:9px;background:#1ac89e;box-shadow:0 0 0 5px rgba(26,200,158,.13)}
.v2-today{min-width:155px;padding:18px 20px;border-radius:22px}
.v2-today span{font-size:11px;letter-spacing:.08em;font-weight:800;color:#7a889a}
.v2-today strong{font-size:42px;line-height:1}
.v2-today small{font-size:12px;color:#6a788a}
.v2-stat-grid{gap:18px;margin:18px 0}
.v2-stat-card{min-height:176px;padding:20px;border-radius:22px;box-shadow:0 16px 36px rgba(20,58,78,.08)!important;border:1px solid #dfebf0!important}
.v2-stat-card:before{width:116px;height:116px;right:-52px;top:-52px;opacity:.95}
.v2-stat-card:after{left:20px;right:20px;height:5px;opacity:.82}
.v2-stat-icon{width:54px;height:54px;border-radius:17px;box-shadow:0 12px 24px color-mix(in srgb,var(--stat-a,#16a88f) 24%,transparent)}
.v2-stat-icon svg{width:25px;height:25px}
.v2-stat-content small{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#738295}
.v2-stat-content strong{font-size:34px;margin:10px 0 8px}
.v2-stat-content em{font-size:11px}
.v2-stat-link{font-size:11px;padding-top:12px}
.v2-stat-link b{width:26px;height:26px;border-radius:9px}
.v2-main-grid,.v2-lower-grid{gap:18px;margin-bottom:18px}
.v2-panel{border-radius:24px;box-shadow:0 18px 40px rgba(22,57,77,.08)!important;border:1px solid #dfebf0!important}
.v2-panel-head{padding:22px 23px 14px}
.v2-panel-head.compact{padding:22px 23px 16px}
.v2-panel-head span{font-size:9px}
.v2-panel-head h2{font-size:20px;font-weight:850}
.v2-panel-head p{font-size:12px}
.v2-panel-head>a{padding:8px 12px;border-radius:11px;font-size:10px}
.v2-legend{padding:9px 11px;border-radius:12px}
.v2-legend span{font-size:10px;font-weight:700}
.v2-chart-area{height:320px;padding:10px 18px 8px}
.v2-chart-insight{grid-template-columns:42px minmax(0,1fr) auto;gap:12px;padding:14px 16px;border-radius:16px}
.v2-insight-icon{width:40px;height:40px;border-radius:13px}
.v2-insight-icon svg{width:20px;height:20px}
.v2-chart-insight strong{font-size:12px}
.v2-chart-insight p,.v2-chart-insight a{font-size:11px}
.v2-donut{width:186px;height:186px}
.v2-donut:after{inset:35px}
.v2-donut strong{font-size:31px}
.v2-donut span{font-size:11px}
.v2-composition-list{padding:4px 21px 16px}
.v2-composition-list a{padding:12px 0}
.v2-composition-list span{font-size:12px;font-weight:700}
.v2-composition-list strong{font-size:13px}
.v2-composition-list small{font-size:10px}
.v2-primary-action{height:46px;border-radius:14px;font-size:12px}
.v2-latest-list{padding:6px 0}
.v2-latest-item{grid-template-columns:46px minmax(0,1fr) auto 20px;gap:12px;padding:14px 20px}
.v2-couple-avatar{width:44px;height:44px}
.v2-couple-avatar b,.v2-couple-avatar i{width:30px;height:30px;font-size:11px}
.v2-latest-copy strong{font-size:13px}
.v2-latest-copy small{font-size:10px}
.v2-service-badge{padding:6px 10px;font-size:9px;letter-spacing:.02em}
.v2-item-more{font-size:18px}
.v2-empty{padding:50px 20px}
.v2-empty strong{font-size:18px}
.v2-empty p,.v2-empty a{font-size:11px}
.v2-info-list{padding:6px 20px 2px}
.v2-info-item{grid-template-columns:44px minmax(0,1fr);gap:13px;padding:15px 0}
.v2-info-item>span{width:42px;height:42px;border-radius:14px}
.v2-info-item svg{width:20px;height:20px}
.v2-info-item strong{font-size:13px}
.v2-info-item p{font-size:11px}
.v2-info-item small{font-size:10px}
.v2-quick-row{gap:12px;padding:14px 20px 20px}
.v2-quick-row a{padding:13px 12px;border-radius:15px}
.v2-quick-row span{width:30px;height:30px;border-radius:10px}
.v2-quick-row strong{font-size:11px}
.v2-quick-row small{font-size:9px}
.footer{margin:0 18px 0 18px;padding:18px 8px 10px;background:transparent;border-top:0;font-size:12px}
@media(max-width:1250px){.topbar-scene{width:34%}.v2-welcome>div>strong{font-size:24px}.v2-stat-content strong{font-size:30px}}
@media(max-width:900px){.topbar{margin:10px 10px 0 10px;height:88px;min-height:88px;border-radius:22px;padding:0 18px}.dashboard-topbar{height:110px;min-height:110px}.content{padding:14px 10px 12px}.footer{margin:0 10px}.v2-welcome{padding:22px}.v2-main-grid,.v2-lower-grid{display:block}.v2-panel{margin-bottom:16px}}
@media(max-width:650px){.v2-welcome>div>strong{font-size:22px}.v2-welcome p{font-size:12px}.v2-today strong{font-size:34px}.v2-stat-card{min-height:156px}.v2-stat-content strong{font-size:28px}.v2-panel-head h2{font-size:18px}.v2-chart-area{height:260px}.v2-donut{width:164px;height:164px}}


/* =========================================================
   Dashboard Greeting & Live Clock v2.7
   ========================================================= */
.dashboard-topbar .topbar-heading h1{font-size:38px!important;line-height:1.05;font-weight:900!important;letter-spacing:-.05em!important}
.v2-greeting-copy{min-width:0;max-width:62%}
.v2-greeting-copy>strong{display:block;font-size:31px!important;line-height:1.2;color:#16314a!important}
.v2-greeting-copy>strong #dashboardGreeting{background:linear-gradient(135deg,#087f73,#18b892);-webkit-background-clip:text;background-clip:text;color:transparent}
.dashboard-live-clock{position:relative;z-index:2;display:grid;grid-template-columns:54px minmax(155px,1fr) auto;align-items:center;gap:14px;min-width:380px;padding:16px 18px;border:1px solid rgba(191,229,220,.95);border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(238,251,247,.96));box-shadow:0 16px 34px rgba(23,95,93,.10);backdrop-filter:blur(14px)}
.clock-icon{width:54px;height:54px;border-radius:17px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#18b892,#087f73);box-shadow:0 12px 24px rgba(8,127,115,.22)}
.clock-icon svg{width:27px;height:27px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.clock-copy span,.clock-copy strong,.clock-copy small,.clock-today span,.clock-today strong,.clock-today small{display:block}
.clock-copy span{font-size:10px;font-weight:850;letter-spacing:.10em;text-transform:uppercase;color:#718193}
.clock-copy strong{font-size:28px;line-height:1.05;margin:4px 0 5px;color:#172b42;font-variant-numeric:tabular-nums;letter-spacing:.035em}
.clock-copy small{font-size:10px;color:#728093}
.clock-today{min-width:74px;padding-left:15px;border-left:1px solid #dbeae6;text-align:center}
.clock-today span{font-size:9px;font-weight:850;text-transform:uppercase;letter-spacing:.09em;color:#7d8a99}
.clock-today strong{font-size:25px;line-height:1.05;margin:4px 0;color:#0c8578}
.clock-today small{font-size:9px;color:#80909f}
@media(max-width:1250px){.dashboard-topbar .topbar-heading h1{font-size:34px!important}.v2-greeting-copy{max-width:56%}.v2-greeting-copy>strong{font-size:27px!important}.dashboard-live-clock{min-width:345px;grid-template-columns:48px minmax(140px,1fr) auto}.clock-icon{width:48px;height:48px}.clock-copy strong{font-size:25px}}
@media(max-width:900px){.dashboard-topbar .topbar-heading h1{font-size:29px!important}.v2-welcome{display:block}.v2-greeting-copy{max-width:none}.dashboard-live-clock{margin-top:18px;width:100%;min-width:0}.v2-greeting-copy>strong{font-size:24px!important}}
@media(max-width:560px){.dashboard-topbar .topbar-heading h1{font-size:26px!important}.dashboard-live-clock{grid-template-columns:46px minmax(0,1fr);padding:14px}.clock-today{grid-column:1/-1;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:12px 0 0;border-left:0;border-top:1px solid #dbeae6;text-align:left}.clock-today small{text-align:right}.clock-copy strong{font-size:23px}.v2-greeting-copy>strong{font-size:21px!important}}

/* Pilihan lokasi akad nikah */
.akad-grid [data-akad-location-type]{font-weight:800;color:#154e49;background:#fbfffe}.akad-grid [data-akad-location-address]{background:linear-gradient(135deg,#eef9f6,#f8fffd)!important;border-color:#b9ded6!important;color:#164e49;font-weight:700;cursor:not-allowed}.akad-grid #akadLocationHint{display:inline-flex;align-items:center;gap:6px;margin-top:7px;padding:6px 9px;border-radius:9px;background:#eaf8f4;color:#39746c;font-weight:600}

/* Statistik tempat akad dan filter periode v2.9 */
.statistics-filter-modern{align-items:flex-start}.statistics-filter-copy{max-width:420px}.statistics-advanced-filter{display:grid;grid-template-columns:110px 145px 155px 155px auto;gap:12px;align-items:end}.statistics-advanced-filter .form-group label{font-size:11px;margin-bottom:5px}.statistics-advanced-filter .form-control,.statistics-advanced-filter .form-select{min-height:42px}.statistics-filter-actions{display:flex;gap:8px}.statistics-filter-actions .btn{white-space:nowrap;min-height:42px}.statistics-period-badge{display:flex;align-items:center;gap:10px;margin:-8px 0 18px;padding:10px 14px;border:1px solid #cfe9e3;border-radius:13px;background:linear-gradient(135deg,#f0fbf8,#fff);color:#56706d;font-size:12px}.statistics-period-badge span{font-weight:700}.statistics-period-badge strong{color:#0c746a}.statistics-place-card{margin-bottom:22px}.statistics-place-wrap{min-height:380px}.statistics-place-card .card-header{background:linear-gradient(135deg,#ffffff,#f1fbf8)}
@media(max-width:1280px){.statistics-filter-row.statistics-filter-modern{display:block}.statistics-filter-copy{max-width:none;margin-bottom:16px}.statistics-advanced-filter{grid-template-columns:repeat(4,minmax(120px,1fr))}.statistics-filter-actions{grid-column:1/-1;justify-content:flex-end}}
@media(max-width:760px){.statistics-advanced-filter{grid-template-columns:1fr 1fr}.statistics-filter-actions{grid-column:1/-1}.statistics-filter-actions .btn{flex:1}.statistics-period-badge{align-items:flex-start;flex-direction:column;gap:2px}}
@media(max-width:480px){.statistics-advanced-filter{grid-template-columns:1fr}.statistics-filter-actions{grid-column:auto;flex-direction:column}.statistics-place-wrap{min-height:320px}}


/* Dashboard Publik v3.0 */
.public-dashboard-body{margin:0;background:#f3f8fa;color:#17243b;font-family:Inter,Segoe UI,Arial,sans-serif}.public-nav{height:78px;display:flex;align-items:center;justify-content:space-between;padding:0 max(24px,5vw);background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid #e1ebef;position:sticky;top:0;z-index:10}.public-brand{display:flex;align-items:center;gap:12px}.public-brand>span{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;color:#fff;font-weight:900;background:linear-gradient(135deg,#16b596,#087d79);box-shadow:0 10px 24px rgba(8,125,121,.22)}.public-brand strong,.public-brand small{display:block}.public-brand strong{font-size:15px}.public-brand small{font-size:11px;color:#718094}.public-nav-actions{display:flex;align-items:center;gap:14px}.public-nav-actions>span{padding:9px 13px;border-radius:11px;background:#eef9f6;color:#08796f;font-weight:800;font-size:12px}.public-nav-actions>a{padding:10px 16px;border-radius:12px;color:#fff;background:linear-gradient(135deg,#15ad91,#08776f);font-size:12px;font-weight:800;box-shadow:0 10px 22px rgba(8,119,111,.18)}.public-dashboard{width:min(1460px,calc(100% - 40px));margin:24px auto}.public-hero{min-height:330px;padding:48px;display:grid;grid-template-columns:1.4fr .6fr;align-items:center;gap:30px;border:1px solid #d9ebe7;border-radius:32px;background:radial-gradient(circle at 82% 18%,rgba(74,218,187,.2),transparent 28%),linear-gradient(135deg,#fff,#f2fdf9);box-shadow:0 22px 55px rgba(24,66,84,.09);overflow:hidden}.public-kicker,.public-section-title>span{font-size:10px;font-weight:900;letter-spacing:.16em;color:#118b79}.public-hero h1{font-size:43px;line-height:1.12;margin:12px 0;color:#17243b;letter-spacing:-.04em}.public-hero h1 b{color:#0b8b7b}.public-hero p{font-size:15px;color:#66768a;max-width:700px}.public-hero-actions{display:flex;gap:11px;margin-top:24px}.public-hero-actions a{padding:12px 18px;border-radius:13px;background:#0c897b;color:#fff;font-size:12px;font-weight:800}.public-hero-actions a.outline{background:#fff;color:#0c7c72;border:1px solid #bfe7df}.public-hero-summary{display:grid;grid-template-columns:1fr 1fr;gap:14px}.public-hero-summary article{padding:24px;border-radius:22px;background:rgba(255,255,255,.86);border:1px solid #d9ece7;box-shadow:0 15px 30px rgba(27,79,85,.08)}.public-hero-summary span,.public-hero-summary strong,.public-hero-summary small{display:block}.public-hero-summary span{font-size:11px;color:#718094;font-weight:800}.public-hero-summary strong{font-size:38px;margin:8px 0;color:#0b897a}.public-hero-summary small{color:#8a96a5}.public-section{margin-top:26px;padding:30px;border-radius:28px;background:#fff;border:1px solid #e0eaef;box-shadow:0 16px 40px rgba(27,60,78,.07)}.public-section-title h2{font-size:28px;margin:7px 0 3px}.public-section-title p{color:#748296;margin:0}.public-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:22px}.public-chart-card{border:1px solid #e1ebef;border-radius:22px;background:linear-gradient(180deg,#fff,#fbfdfd);box-shadow:0 12px 30px rgba(24,61,80,.06);overflow:hidden}.public-chart-card.wide{grid-column:1/-1}.public-chart-card header{padding:19px 20px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #eef3f5}.public-chart-card header small{color:#13917f;font-size:9px;font-weight:900;letter-spacing:.13em}.public-chart-card h3{font-size:17px;margin:4px 0}.public-chart-card header>b{padding:7px 10px;border-radius:10px;background:#ecfaf6;color:#0a8174;font-size:11px}.public-canvas{padding:12px 12px 8px;min-height:260px}.public-canvas.tall{min-height:300px}.recommendation{background:linear-gradient(180deg,#fff,#f9fcff)}.public-rec-summary{display:flex;justify-content:space-between;align-items:center;margin:20px 0 15px;padding:16px 18px;border:1px solid #dcebea;border-radius:18px;background:#f6fcfa}.public-rec-summary article small,.public-rec-summary article strong,.public-rec-summary article span{display:block}.public-rec-summary article small{font-size:9px;font-weight:900;color:#168e7e}.public-rec-summary article strong{font-size:30px;color:#17243b}.public-rec-summary article span{font-size:11px;color:#7a8797}.public-filter{display:flex;padding:5px;background:#eaf3f4;border-radius:13px}.public-filter button{border:0;padding:9px 14px;border-radius:9px;background:transparent;color:#617184;font-weight:800;font-size:11px;cursor:pointer}.public-filter button.active{background:#fff;color:#0a8477;box-shadow:0 6px 15px rgba(24,67,84,.10)}.public-footer{display:flex;justify-content:space-between;padding:25px max(24px,5vw);font-size:11px;color:#758397}.login-card:before{content:"";display:block}.login-page .login-card:after{content:"Kembali ke Dashboard Publik";display:block;text-align:center;margin-top:14px;color:#0b7f73;font-size:12px;font-weight:700}
@media(max-width:900px){.public-hero{grid-template-columns:1fr;padding:34px}.public-hero h1{font-size:34px}.public-chart-grid{grid-template-columns:1fr}.public-chart-card.wide{grid-column:auto}}@media(max-width:600px){.public-nav{height:auto;padding:12px 15px}.public-brand strong{font-size:12px}.public-nav-actions>span{display:none}.public-nav-actions>a{padding:9px 11px;font-size:10px}.public-dashboard{width:calc(100% - 20px);margin:10px auto}.public-hero{padding:25px 20px;border-radius:24px}.public-hero h1{font-size:28px}.public-hero-summary{grid-template-columns:1fr}.public-section{padding:20px 14px;border-radius:22px}.public-section-title h2{font-size:23px}.public-rec-summary{align-items:flex-start;gap:12px;flex-direction:column}.public-footer{display:block;text-align:center}.public-footer span{display:block;margin:4px}}


/* =========================================================
   Dashboard Publik Modern Color v3.1
   ========================================================= */
.public-dashboard-body{background:radial-gradient(circle at 12% 8%,rgba(20,184,166,.10),transparent 24%),radial-gradient(circle at 88% 3%,rgba(59,130,246,.08),transparent 20%),linear-gradient(180deg,#f4fbfc 0%,#eff6fa 100%)}
.public-nav{border-radius:0 0 22px 22px;box-shadow:0 10px 30px rgba(25,64,83,.06)}
.public-nav-actions>span{background:linear-gradient(135deg,#e9fbf7,#ddf7f2);border:1px solid #caeee5;box-shadow:0 10px 18px rgba(16,124,116,.08)}
.public-nav-actions>a{background:linear-gradient(135deg,#18b899,#098178);border:1px solid rgba(255,255,255,.22)}
.public-dashboard{width:min(1480px,calc(100% - 34px));margin:20px auto 26px}
.public-hero{position:relative;background:radial-gradient(circle at 85% 15%,rgba(66,214,183,.22),transparent 25%),radial-gradient(circle at 18% 95%,rgba(59,130,246,.14),transparent 24%),linear-gradient(135deg,#ffffff,#f4fdfa);border:1px solid #d7ebe7;box-shadow:0 24px 60px rgba(27,66,84,.09)}
.public-hero:before{content:"";position:absolute;right:-60px;top:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(16,185,129,.16),rgba(16,185,129,0) 72%)}
.public-hero:after{content:"";position:absolute;left:52%;bottom:-80px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.12),rgba(59,130,246,0) 72%)}
.public-kicker,.public-section-title>span{font-size:11px;color:#0d8f7d}
.public-hero h1{font-size:46px}.public-hero p{font-size:16px;line-height:1.7}
.public-hero-actions a{box-shadow:0 12px 22px rgba(14,125,116,.12)}
.public-hero-actions a.outline{box-shadow:none}
.public-hero-summary article{position:relative;overflow:hidden;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,253,252,.94));box-shadow:0 18px 32px rgba(28,75,90,.08)}
.public-hero-summary article:before{content:"";position:absolute;width:110px;height:110px;border-radius:50%;right:-36px;top:-36px;background:rgba(16,185,129,.09)}
.public-hero-summary article:nth-child(2):before{background:rgba(59,130,246,.10)}
.public-hero-summary strong{font-size:42px}
.public-section{position:relative;overflow:hidden}
.public-section:before{content:"";position:absolute;right:-90px;top:-90px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(16,185,129,.07),rgba(16,185,129,0) 72%);pointer-events:none}
.public-section-title h2{font-size:30px;font-weight:850;letter-spacing:-.03em}
.public-chart-grid{gap:20px;margin-top:24px}
.public-chart-card{position:relative;border-radius:24px;box-shadow:0 18px 40px rgba(23,60,79,.07);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.public-chart-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px rgba(21,61,79,.11);border-color:#cfe5e5}
.public-chart-card:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#18b899,#1ea5d2,#7c5cf3,#f4a51d);opacity:.95}
.public-chart-card header{padding:20px 20px 13px;background:linear-gradient(180deg,#ffffff,#fbfdfd)}
.public-chart-card header small{font-size:10px;color:#11917f}
.public-chart-card h3{font-size:18px;font-weight:800}
.public-chart-card header>b{background:linear-gradient(135deg,#eefbf8,#e4f7fb);border:1px solid #d4eceb;color:#0b8275;font-size:11px}
.public-canvas{padding:14px 14px 10px;min-height:280px;background:linear-gradient(180deg,#fff,#fcfefe)}
.public-canvas.tall{min-height:330px}
.public-rec-summary{background:linear-gradient(135deg,#f6fcfa,#f5fbff);box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.public-rec-summary article strong{font-size:34px}
.public-filter{padding:6px;background:#ebf3f5;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.public-filter button{padding:10px 16px;font-size:11px}
.public-filter button.active{background:linear-gradient(135deg,#ffffff,#f8fdfd);color:#098377;border:1px solid #dce9ea}
.public-footer{padding-top:6px;font-size:12px}
@media(max-width:900px){.public-hero h1{font-size:36px}.public-hero p{font-size:14px}.public-section-title h2{font-size:25px}}
@media(max-width:600px){.public-dashboard{width:calc(100% - 16px)}.public-hero{padding:24px 18px}.public-hero h1{font-size:30px}.public-chart-card,.public-section,.public-hero{border-radius:22px}.public-canvas,.public-canvas.tall{min-height:260px}}


/* =========================================================
   Public Dashboard Powerful Background v3.1.1
   ========================================================= */
.public-dashboard-body{
  background:
    radial-gradient(circle at 8% 10%, rgba(16,185,129,.22), transparent 22%),
    radial-gradient(circle at 92% 8%, rgba(59,130,246,.20), transparent 20%),
    radial-gradient(circle at 20% 92%, rgba(245,158,11,.18), transparent 24%),
    radial-gradient(circle at 88% 84%, rgba(139,92,246,.16), transparent 22%),
    linear-gradient(135deg,#e8fffa 0%,#eef9ff 24%,#f5f0ff 48%,#fff8ea 72%,#eefcf7 100%);
  background-attachment: fixed;
  position:relative;
}
.public-dashboard-body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.35;
  background-image:
    linear-gradient(rgba(255,255,255,.26) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.22) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.7), rgba(0,0,0,.15));
}
.public-nav{
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(245,255,252,.88));
  border-bottom:1px solid rgba(208,229,229,.9);
  box-shadow:0 12px 34px rgba(23,60,79,.08);
}
.public-brand>span{
  background:linear-gradient(135deg,#10c3a0,#087a79 58%,#2563eb 100%);
  box-shadow:0 14px 32px rgba(8,125,121,.22);
}
.public-nav-actions>a{
  background:linear-gradient(135deg,#18c2a2,#0d8e85 45%,#1277c8 100%);
  box-shadow:0 14px 26px rgba(8,119,111,.20);
}
.public-nav-actions>span{
  background:linear-gradient(135deg,#e9fffa,#e5f6ff 55%,#f4efff 100%);
  color:#086f74;
}
.public-dashboard{position:relative;z-index:1}
.public-hero{
  background:
    radial-gradient(circle at 85% 18%, rgba(34,197,94,.20), transparent 24%),
    radial-gradient(circle at 70% 82%, rgba(59,130,246,.16), transparent 24%),
    radial-gradient(circle at 18% 20%, rgba(245,158,11,.14), transparent 16%),
    linear-gradient(135deg,#ffffff 0%,#f2fffb 35%,#eef7ff 65%,#f7f2ff 100%);
  border:1px solid #d7ebe7;
  box-shadow:0 26px 60px rgba(27,66,84,.11);
}
.public-hero:before{background:radial-gradient(circle,rgba(16,185,129,.22),rgba(16,185,129,0) 72%)}
.public-hero:after{background:radial-gradient(circle,rgba(59,130,246,.18),rgba(59,130,246,0) 72%)}
.public-hero h1 b{background:linear-gradient(135deg,#0a8f7c,#0f7fa4 60%,#6b4ce6 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.public-hero-actions a{background:linear-gradient(135deg,#12b897,#0d8f82 48%,#1077c7 100%)}
.public-hero-actions a.outline{background:rgba(255,255,255,.86);border:1px solid #cbe7e3;color:#0b7c72}
.public-hero-summary article:nth-child(1){background:linear-gradient(180deg,#ffffff,#f2fffb)}
.public-hero-summary article:nth-child(2){background:linear-gradient(180deg,#ffffff,#f2f8ff)}
.public-hero-summary article:nth-child(1) strong{color:#0c897a}
.public-hero-summary article:nth-child(2) strong{color:#2563eb}
.public-section{
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(252,255,255,.94));
  box-shadow:0 18px 44px rgba(27,60,78,.08);
}
.public-section:after{
  content:"";
  position:absolute;
  left:-70px;
  bottom:-70px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.10),rgba(245,158,11,0) 72%);
  pointer-events:none;
}
.public-chart-card{
  background:linear-gradient(180deg,#ffffff 0%,#fbffff 52%,#f9fcff 100%);
  border:1px solid #ddeaf0;
}
.public-chart-card:before{background:linear-gradient(90deg,#10b981 0%,#06b6d4 33%,#8b5cf6 66%,#f59e0b 100%)}
.public-chart-card header>b{
  background:linear-gradient(135deg,#effff9,#ecf7ff 50%,#f4efff 100%);
  color:#0b7f78;
}
.public-rec-summary{
  background:linear-gradient(135deg,#f5fffb 0%,#f4fbff 55%,#faf5ff 100%);
  border:1px solid #dcebea;
}
.public-filter{
  background:linear-gradient(135deg,#edf6f8,#eef8fb 55%,#f3effd 100%);
}
.public-filter button.active{
  background:linear-gradient(135deg,#ffffff,#faffff);
  box-shadow:0 10px 18px rgba(24,67,84,.10);
}
.public-footer{
  color:#617387;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.24));
}
@media(max-width:600px){
  .public-dashboard-body:before{opacity:.22;background-size:26px 26px}
}


/* Export Excel Data Daftar Nikah v3.2 */
.btn-excel{color:#fff;background:linear-gradient(135deg,#16864b,#0e6f3e);border:1px solid rgba(255,255,255,.16);box-shadow:0 10px 22px rgba(14,111,62,.18)}
.btn-excel:hover{background:linear-gradient(135deg,#197e49,#095f34);box-shadow:0 14px 26px rgba(14,111,62,.24)}
.excel-icon{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;background:rgba(255,255,255,.18);font-size:11px;font-weight:900}


/* Export Excel wajib filter tanggal */
.export-date-modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px}.export-date-modal.is-open{display:flex}.export-date-backdrop{position:absolute;inset:0;background:rgba(8,28,42,.58);backdrop-filter:blur(7px)}.export-date-dialog{position:relative;z-index:1;width:min(560px,100%);padding:28px;border:1px solid #d9e8e8;border-radius:24px;background:linear-gradient(180deg,#fff,#f8fdfc);box-shadow:0 30px 80px rgba(8,35,49,.25);animation:exportModalIn .25s ease}.export-date-close{position:absolute;right:16px;top:14px;width:36px;height:36px;border:0;border-radius:11px;background:#edf4f5;color:#526477;font-size:22px;cursor:pointer}.export-date-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;color:#fff;font-weight:900;font-size:20px;background:linear-gradient(135deg,#22b573,#087f5b);box-shadow:0 12px 26px rgba(8,127,91,.22)}.export-date-dialog h2{margin:16px 0 6px;font-size:22px;color:#17283d}.export-date-dialog>p{margin:0 0 20px;color:#6d7c8f;font-size:13px;line-height:1.65}.export-date-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.export-date-hint{margin-top:14px;padding:11px 13px;border-radius:12px;background:#edf9f6;color:#477168;font-size:12px}.export-date-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid #e6eef1}.btn-excel{background:linear-gradient(135deg,#18a96f,#087b57);color:#fff;border:0}.btn-excel:hover{filter:brightness(1.04);box-shadow:0 10px 22px rgba(8,123,87,.18)}.excel-icon{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:6px;background:rgba(255,255,255,.18);font-weight:900}@keyframes exportModalIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}@media(max-width:560px){.export-date-grid{grid-template-columns:1fr}.export-date-actions{flex-direction:column-reverse}.export-date-actions .btn{width:100%}}


/* =========================================================
   Menu Cetak & Popup v3.3
   ========================================================= */
.nav-link-button{width:100%;border:1px solid transparent;font:inherit;text-align:left;cursor:pointer}
.print-choice-modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px}
.print-choice-modal.is-open{display:flex}
.print-choice-backdrop{position:absolute;inset:0;background:rgba(8,24,37,.62);backdrop-filter:blur(8px);animation:printFade .2s ease}
.print-choice-dialog{position:relative;z-index:1;width:min(660px,100%);padding:26px;border:1px solid rgba(255,255,255,.75);border-radius:26px;background:linear-gradient(145deg,#ffffff,#f4fbfa);box-shadow:0 30px 80px rgba(4,33,48,.28);animation:printPop .28s ease}
.print-choice-close{position:absolute;right:16px;top:14px;width:36px;height:36px;border:0;border-radius:12px;background:#eef3f5;color:#526275;font-size:23px;cursor:pointer}
.print-choice-heading{display:grid;grid-template-columns:58px minmax(0,1fr);gap:15px;align-items:center;padding-right:34px;margin-bottom:20px}.print-choice-heading small{font-size:9px;font-weight:900;letter-spacing:.16em;color:#0f8d7d}.print-choice-heading h2{margin:3px 0;font-size:23px;color:#18283d}.print-choice-heading p{margin:0;color:#718094;font-size:12px}.print-choice-symbol{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#17b899,#087d79 65%,#2563eb);box-shadow:0 15px 28px rgba(8,125,121,.22)}.print-choice-symbol svg,.print-choice-card-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.print-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}.print-choice-card{position:relative;overflow:hidden;min-height:188px;padding:20px;border:1px solid #dce9ed;border-radius:20px;background:#fff;box-shadow:0 13px 28px rgba(26,61,79,.07);transition:.24s}.print-choice-card:before{content:"";position:absolute;width:115px;height:115px;border-radius:50%;right:-42px;top:-50px;background:var(--print-soft)}.print-choice-card:hover{transform:translateY(-4px);box-shadow:0 22px 38px rgba(18,75,79,.13);border-color:var(--print-border)}.print-choice-daftar{--print-soft:#e5faf5;--print-border:#9fddd0;--print-main:#0f8d7d}.print-choice-rekomendasi{--print-soft:#e9f3ff;--print-border:#a9c9f4;--print-main:#2563b5}.print-choice-card-icon{position:relative;width:48px;height:48px;border-radius:15px;display:grid;place-items:center;color:#fff;background:var(--print-main);box-shadow:0 10px 21px color-mix(in srgb,var(--print-main) 22%,transparent)}.print-choice-card strong,.print-choice-card small,.print-choice-card b{position:relative;display:block}.print-choice-card strong{font-size:15px;margin-top:14px;color:#1e3045}.print-choice-card small{font-size:11px;line-height:1.55;color:#738195;margin-top:5px}.print-choice-card b{font-size:10px;margin-top:15px;color:var(--print-main)}body.modal-open{overflow:hidden}@keyframes printFade{from{opacity:0}to{opacity:1}}@keyframes printPop{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}@media(max-width:600px){.print-choice-dialog{padding:21px 16px;border-radius:22px}.print-choice-grid{grid-template-columns:1fr}.print-choice-card{min-height:155px}.print-choice-heading{grid-template-columns:48px 1fr}.print-choice-symbol{width:46px;height:46px;border-radius:14px}.print-choice-heading h2{font-size:19px}}


/* =========================================================
   Dokumen Cetak Daftar Nikah v3.4
   ========================================================= */
.print-choice-card.is-rich{display:block;text-decoration:none}
.print-choice-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.print-choice-actions.single-row{justify-content:space-between;align-items:center}
.print-doc-dialog{max-width:860px;padding:28px 28px 26px;border-radius:30px;background:linear-gradient(155deg,rgba(255,255,255,.97),rgba(241,250,249,.98));box-shadow:0 36px 90px rgba(7,35,57,.26), inset 0 1px 0 rgba(255,255,255,.9);overflow:hidden}
.print-doc-dialog::before,.print-doc-dialog::after{content:"";position:absolute;z-index:0;border-radius:50%;pointer-events:none;filter:blur(4px)}
.print-doc-dialog::before{width:220px;height:220px;right:-80px;top:-70px;background:radial-gradient(circle at center,rgba(32,190,159,.16),rgba(32,190,159,0) 70%)}
.print-doc-dialog::after{width:180px;height:180px;left:-70px;bottom:-70px;background:radial-gradient(circle at center,rgba(37,99,235,.12),rgba(37,99,235,0) 72%)}
.print-doc-dialog > *{position:relative;z-index:1}
.print-doc-selector{display:flex;flex-direction:column;gap:9px;margin:14px 0 20px;padding:18px;border:1px solid rgba(195,220,228,.95);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(244,250,251,.96));box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 14px 30px rgba(26,61,79,.06)}
.print-doc-selector label{font-weight:900;color:#203041;font-size:13px;letter-spacing:.01em}
.print-doc-selector select,.print-doc-selector input{width:100%;min-height:52px;padding:14px 16px;border:1px solid #cfe0e6;border-radius:16px;background:linear-gradient(180deg,#ffffff,#f9fcfd);font:inherit;color:#203041;box-shadow:0 8px 18px rgba(15,49,72,.05);transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease}
.print-doc-selector select:hover,.print-doc-selector input:hover{border-color:#b7d8d1}
.print-doc-selector select:focus,.print-doc-selector input:focus{outline:none;border-color:#20be9f;box-shadow:0 0 0 4px rgba(32,190,159,.12),0 10px 24px rgba(15,49,72,.08);transform:translateY(-1px)}
.print-doc-selector small{font-size:12px;color:#6f8092;line-height:1.55;padding:2px 2px 0}
.print-doc-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}
.print-doc-btn{position:relative;overflow:hidden;border:1px solid #d6e4ea;background:linear-gradient(180deg,#ffffff,#f7fbfc);color:#14324a;padding:16px 12px;border-radius:18px;font-weight:900;cursor:pointer;box-shadow:0 10px 22px rgba(15,49,72,.07);transition:all .24s ease}
.print-doc-btn::before{content:"";position:absolute;inset:auto -10% 100% auto;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(32,190,159,.14),rgba(32,190,159,0) 70%);transition:transform .26s ease}
.print-doc-btn:hover{transform:translateY(-3px);border-color:#a7dcd1;box-shadow:0 18px 34px rgba(15,49,72,.12);background:linear-gradient(180deg,#ffffff,#effcf9)}
.print-doc-btn:hover::before{transform:translate(-8px,80px)}
.print-doc-btn:active{transform:translateY(-1px) scale(.99)}
@media(max-width:900px){.print-doc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.print-choice-actions.single-row{flex-direction:column;align-items:stretch}.print-doc-dialog{padding:24px 18px 22px}}
@media(max-width:560px){.print-doc-grid{grid-template-columns:1fr}.print-doc-selector{padding:15px;border-radius:18px}.print-doc-dialog{border-radius:24px}}


/* =========================================================
   Logo Kop & Nomor Manual v3.5
   ========================================================= */
.village-logo-preview-row{display:flex;justify-content:center;gap:18px;margin-bottom:14px}.village-logo-preview-row img{width:72px;height:82px;object-fit:contain;border:1px solid #e0e8ed;border-radius:12px;padding:5px;background:#fff}.print-number-preview{padding:13px 15px;border-radius:15px;background:linear-gradient(135deg,#eefbf8,#f3f8ff);border:1px solid #d6ebe8;color:#0d726b;font-size:12px;font-weight:900;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}.print-doc-btn:focus{outline:3px solid rgba(15,118,110,.15);outline-offset:2px}


/* =========================================================
   Template Editor v3.6
   ========================================================= */
.template-editor-layout{display:grid;grid-template-columns:240px minmax(0,1fr) 280px;gap:18px;align-items:start}.template-doc-list,.template-editor-card,.template-placeholder-card{padding:20px}.template-doc-list h3,.template-placeholder-card h3{margin:0 0 14px}.template-doc-link{display:block;padding:12px 13px;border-radius:12px;color:#26394d;border:1px solid transparent;margin-bottom:7px;font-weight:750}.template-doc-link small{display:block;margin-top:3px;color:#8895a4;font-size:10px}.template-doc-link:hover{background:#f3faf8;border-color:#d8ece7}.template-doc-link.active{background:linear-gradient(135deg,#e7faf5,#edf8ff);border-color:#bee6dc;color:#08776e}.template-editor-head{display:flex;justify-content:space-between;gap:15px;border-bottom:1px solid #e8eef2;padding-bottom:15px;margin-bottom:15px}.template-editor-head small{font-size:9px;font-weight:900;letter-spacing:.12em;color:#0d8a78}.template-editor-head h3{margin:5px 0}.template-editor-head p{margin:0;color:#748294;font-size:12px}.badge-neutral{background:#eef2f5;color:#617083}.template-code-editor{width:100%;min-height:560px;margin-top:8px;padding:16px;border:1px solid #d7e2e8;border-radius:14px;background:#172331;color:#dff7ef;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.55;resize:vertical}.template-code-editor:focus{outline:2px solid rgba(20,184,166,.25);border-color:#38bda5}.template-actions{display:flex;gap:10px;margin-top:14px}.placeholder-list{display:flex;flex-wrap:wrap;gap:7px}.placeholder-chip{border:1px solid #d8e6eb;background:#f7fbfc;color:#17675f;border-radius:9px;padding:6px 8px;font-size:10px;font-family:Consolas,monospace;cursor:pointer}.placeholder-chip:hover{background:#eaf9f5;border-color:#b8e1d8}.template-help{margin-top:18px;padding:13px;border-radius:12px;background:#f5f8fa;color:#657486;font-size:11px}.template-help code{background:#e7edf1;padding:1px 4px;border-radius:4px}.template-document{font-family:"Bookman Old Style",Bookman,Georgia,"Times New Roman",serif;font-size:12pt}.template-heading{text-align:center;margin-bottom:20px}.template-heading h1{font-size:12pt;text-transform:uppercase}.template-table{width:100%;border-collapse:collapse}.template-table td{padding:2px 4px;vertical-align:top}.template-table td:first-child{width:235px}.template-signature{width:40%;margin:28px 0 0 auto;text-align:center}.template-signature .signature-space{height:80px}.template-signature .signature-name{display:block;white-space:nowrap;font-size:10pt;border-bottom:1px solid #000}@media(max-width:1200px){.template-editor-layout{grid-template-columns:210px minmax(0,1fr)}.template-placeholder-card{grid-column:1/-1}}@media(max-width:760px){.template-editor-layout{grid-template-columns:1fr}.template-code-editor{min-height:440px}.template-actions{flex-direction:column}}

/* Public Statistik Catin v4.4.2 */
.public-filter-section{background:linear-gradient(135deg,#ffffff,#f5fffc 56%,#f5f9ff)}
.public-stat-filter{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:14px;align-items:end;margin-top:22px;padding:20px;border:1px solid #dce9ed;border-radius:20px;background:rgba(248,252,253,.92);box-shadow:inset 0 1px 0 #fff}
.public-stat-filter label{display:block;margin-bottom:7px;color:#405469;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.public-stat-filter select,.public-stat-filter input{width:100%;min-height:45px;border:1px solid #ccdce2;border-radius:12px;padding:10px 12px;background:#fff;color:#1f3348;outline:none}
.public-stat-filter select:focus,.public-stat-filter input:focus{border-color:#18a994;box-shadow:0 0 0 4px rgba(24,169,148,.1)}
.public-filter-actions{display:flex;gap:8px;align-items:center}.public-filter-actions button,.public-filter-actions a{min-height:45px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:12px;padding:10px 15px;font-size:12px;font-weight:800;cursor:pointer}.public-filter-actions button{background:linear-gradient(135deg,#11a88e,#0d7fb4);color:#fff;box-shadow:0 10px 22px rgba(13,127,180,.17)}.public-filter-actions a{background:#eaf0f4;color:#4b6075}
.public-filter-note{margin-top:13px;padding:11px 14px;border-radius:12px;background:#eaf9f5;color:#14675e;font-size:12px;font-weight:700}
.public-data-card{margin-top:22px;border:1px solid #e0eaee;border-radius:20px;background:#fff;box-shadow:0 14px 34px rgba(24,61,80,.06);overflow:hidden}
.public-table-wrap{overflow:auto;max-height:520px}.public-data-table{width:100%;min-width:920px;border-collapse:separate;border-spacing:0}.public-data-table th{position:sticky;top:0;z-index:2;padding:13px 14px;background:linear-gradient(180deg,#ecfaf7,#e8f4f7);color:#385267;font-size:10px;text-transform:uppercase;letter-spacing:.055em;text-align:left;border-bottom:1px solid #d5e5e9}.public-data-table td{padding:13px 14px;border-bottom:1px solid #edf2f4;color:#465b6e;font-size:12px;vertical-align:top}.public-data-table tbody tr:nth-child(even){background:#fbfdfd}.public-data-table tbody tr:hover{background:#f2fbf8}.public-data-table strong{color:#1b3448}.public-empty{text-align:center!important;padding:38px!important;color:#8290a0!important}.public-regis-badge,.public-destination-badge{display:inline-flex;padding:6px 9px;border-radius:9px;font-size:11px;font-weight:800;white-space:nowrap}.public-regis-badge{background:#e9f2ff;color:#2563a8;border:1px solid #cfe0fa}.public-destination-badge{background:#fff6dd;color:#a45a00;border:1px solid #f4dc9f}
.public-chart-legend{display:flex;align-items:center;gap:7px;color:#63758a;font-size:10px;font-weight:800}.public-chart-legend i{width:9px;height:9px;border-radius:3px;display:inline-block}.public-chart-legend i.male{background:#2563eb}.public-chart-legend i.female{background:#ec4899}.public-rekom-chart{margin-top:20px}
@media(max-width:1100px){.public-stat-filter{grid-template-columns:repeat(2,minmax(0,1fr))}.public-filter-actions{grid-column:1/-1}}
@media(max-width:600px){.public-stat-filter{grid-template-columns:1fr;padding:14px}.public-filter-actions{grid-column:auto}.public-filter-actions button,.public-filter-actions a{flex:1}.public-table-wrap{max-height:430px}.public-chart-legend{flex-wrap:wrap;justify-content:flex-end}}

/* Loader animasi akses aplikasi */
html.is-loading, body.is-loading { overflow: hidden; }
.app-loader-overlay{position:fixed;inset:0;z-index:999999;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top left,rgba(117,224,204,.28),transparent 30%),radial-gradient(circle at bottom right,rgba(20,184,166,.18),transparent 32%),rgba(246,251,250,.98);backdrop-filter:blur(10px);transition:opacity .28s ease,visibility .28s ease;animation:loaderAutoHide .28s ease .72s forwards}
.app-loader-overlay.is-hiding{opacity:0;visibility:hidden;pointer-events:none;animation:none}
.app-loader-overlay.is-hidden{display:none}
.app-loader-card{position:relative;width:min(430px,100%);padding:34px 30px 28px;border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(239,252,248,.97));border:1px solid rgba(157,226,213,.85);box-shadow:0 28px 80px rgba(18,72,74,.18);text-align:center;overflow:hidden}
.app-loader-card:before,.app-loader-card:after{content:"";position:absolute;border-radius:999px;filter:blur(8px);opacity:.55;pointer-events:none}.app-loader-card:before{width:140px;height:140px;right:-35px;top:-45px;background:radial-gradient(circle,#99ead7 0,rgba(153,234,215,0) 72%)}.app-loader-card:after{width:120px;height:120px;left:-28px;bottom:-35px;background:radial-gradient(circle,#b8f0e3 0,rgba(184,240,227,0) 72%)}
.app-loader-rings{position:relative;width:118px;height:118px;margin:0 auto 16px}.app-loader-rings span{position:absolute;inset:0;border-radius:50%;border:3px solid transparent;animation:loaderSpin 4.5s linear infinite}.app-loader-rings span:first-child{border-top-color:#0f766e;border-right-color:#2dd4bf}.app-loader-rings span:last-child{inset:12px;border-bottom-color:#14b8a6;border-left-color:#99f6e4;animation-direction:reverse;animation-duration:3.4s}
.app-loader-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;font-size:29px;animation:loaderFloat 2.1s ease-in-out infinite}.app-loader-heart{display:inline-block;color:#ef476f;font-size:24px;animation:loaderPulse 1.25s ease-in-out infinite}
.app-loader-text strong,.app-loader-text small{display:block;position:relative;z-index:1}.app-loader-text strong{font-size:24px;line-height:1.15;color:#13313f;margin-bottom:7px;letter-spacing:-.02em}.app-loader-text small{font-size:13px;line-height:1.65;color:#68808f;max-width:290px;margin:0 auto}
.app-loader-progress{position:relative;z-index:1;height:10px;margin:22px auto 0;width:min(240px,100%);background:#e2f3ef;border-radius:999px;overflow:hidden;border:1px solid #d1ebe4}.app-loader-progress span{display:block;height:100%;width:42%;background:linear-gradient(90deg,#0f766e,#14b8a6,#6ee7d0);border-radius:999px;animation:loaderTrack 1.5s ease-in-out infinite}
@keyframes loaderSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes loaderFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes loaderPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}
@keyframes loaderTrack{0%{transform:translateX(-115%)}100%{transform:translateX(350%)}}
@keyframes loaderAutoHide{to{opacity:0;visibility:hidden;pointer-events:none}}
@media (max-width:640px){.app-loader-card{padding:28px 20px 22px;border-radius:24px}.app-loader-rings{width:102px;height:102px}.app-loader-icon{font-size:25px}.app-loader-heart{font-size:20px}.app-loader-text strong{font-size:21px}}


/* Halaman Berkas Persyaratan Nikah v4.5.8 */
.public-requirements-link{background:linear-gradient(135deg,#7c3aed,#2563eb)!important;box-shadow:0 10px 24px rgba(79,70,229,.20)!important}
.public-requirements-promo{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);align-items:center;gap:30px;background:radial-gradient(circle at 86% 12%,rgba(99,102,241,.13),transparent 28%),linear-gradient(135deg,#fff,#f5fffc 56%,#f3f6ff)}
.public-requirements-promo-copy h2{font-size:30px;margin:8px 0 6px;letter-spacing:-.03em}.public-requirements-promo-copy p{max-width:720px;color:#6f8093;line-height:1.7}.public-requirements-button{display:inline-flex;margin-top:18px;padding:12px 18px;border-radius:14px;background:linear-gradient(135deg,#0d9c87,#2563eb);color:#fff;font-size:12px;font-weight:900;box-shadow:0 12px 25px rgba(37,99,235,.18)}
.public-requirements-promo-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.public-requirements-promo-cards article{padding:20px 14px;border:1px solid #dce8ed;border-radius:20px;text-align:center;background:rgba(255,255,255,.92);box-shadow:0 14px 30px rgba(21,59,80,.07);transition:.25s}.public-requirements-promo-cards article:hover{transform:translateY(-4px);box-shadow:0 20px 38px rgba(21,59,80,.11)}.public-requirements-promo-cards .promo-icon{display:block;font-size:34px;margin-bottom:9px}.public-requirements-promo-cards strong,.public-requirements-promo-cards small{display:block}.public-requirements-promo-cards strong{font-size:13px;color:#182a43}.public-requirements-promo-cards small{font-size:10px;color:#718194;margin-top:3px}
.requirements-page{background:radial-gradient(circle at 8% 6%,rgba(20,184,166,.13),transparent 24%),radial-gradient(circle at 92% 7%,rgba(99,102,241,.10),transparent 23%),linear-gradient(180deg,#f4fbfc,#f3f6fb)}
.requirements-main{width:min(1380px,calc(100% - 40px));margin:28px auto 42px}
.requirements-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:1.25fr .75fr;align-items:center;gap:34px;padding:52px;border-radius:34px;border:1px solid #d8ebe7;background:radial-gradient(circle at 86% 18%,rgba(99,102,241,.18),transparent 29%),radial-gradient(circle at 18% 100%,rgba(20,184,166,.15),transparent 27%),linear-gradient(135deg,#fff,#f4fdfa);box-shadow:0 24px 60px rgba(20,58,76,.09)}
.requirements-kicker{font-size:10px;font-weight:900;letter-spacing:.18em;color:#0b8e7d}.requirements-hero h1{font-size:45px;line-height:1.08;margin:12px 0;color:#18243d;letter-spacing:-.045em}.requirements-hero p{font-size:15px;line-height:1.75;color:#687a8f;max-width:760px}.requirements-summary{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.requirements-summary span{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:13px;border:1px solid #d8e7e8;background:rgba(255,255,255,.9);font-size:11px;font-weight:800;color:#536b7f}.requirements-summary b{font-size:17px;color:#0b8d7c}
.requirements-hero-visual{display:grid;place-items:center;min-height:210px}.requirements-couple{display:flex;align-items:center;gap:14px;font-size:72px;filter:drop-shadow(0 18px 18px rgba(23,61,80,.12));animation:reqFloat 3s ease-in-out infinite}.requirements-couple i{font-style:normal;font-size:32px;color:#ef476f;animation:reqPulse 1.35s ease-in-out infinite}.requirements-docs{margin-top:8px;font-size:27px;letter-spacing:10px;opacity:.85}
.requirements-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:26px;align-items:start}.requirements-card{overflow:hidden;border-radius:30px;border:1px solid #dce8ed;background:#fff;box-shadow:0 20px 50px rgba(22,58,78,.08)}.requirements-card header{display:grid;grid-template-columns:74px 1fr;gap:18px;align-items:center;padding:28px 30px;border-bottom:1px solid #e6eef2}.male-card header{background:radial-gradient(circle at 93% 8%,rgba(37,99,235,.14),transparent 30%),linear-gradient(135deg,#f7fbff,#edf5ff)}.female-card header{background:radial-gradient(circle at 93% 8%,rgba(236,72,153,.13),transparent 30%),linear-gradient(135deg,#fff8fc,#fdf0f7)}.requirements-avatar{width:68px;height:68px;border-radius:22px;display:grid;place-items:center;font-size:35px;background:#fff;border:1px solid rgba(211,226,233,.95);box-shadow:0 13px 28px rgba(24,63,82,.10)}.requirements-card header small{font-size:9px;letter-spacing:.15em;font-weight:900;color:#0b8c7b}.requirements-card header h2{font-size:26px;margin:4px 0 2px;color:#17243b}.requirements-card header p{margin:0;color:#718195;font-size:12px;line-height:1.55}
.requirements-list{list-style:none;margin:0;padding:18px}.requirements-list li{position:relative;display:grid;grid-template-columns:48px 1fr;gap:14px;align-items:start;margin:0;padding:15px;border-radius:18px;border:1px solid transparent;transition:.23s}.requirements-list li:not(:last-child){margin-bottom:4px}.requirements-list li:hover{background:#f6fbfb;border-color:#dcebea;transform:translateX(3px)}.requirements-list li.important{background:linear-gradient(135deg,#fff9ed,#fff4f3);border-color:#f2dfbf}.req-icon{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;color:#0b897a;background:linear-gradient(145deg,#e8faf5,#f7fffd);border:1px solid #d0ebe4}.female-card .req-icon{color:#c2417a;background:linear-gradient(145deg,#fff0f7,#fffafd);border-color:#f2d8e5}.requirements-list li.important .req-icon{color:#c36b13;background:#fff4dc;border-color:#f0d6a3}.req-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.requirements-list strong,.requirements-list small{display:block}.requirements-list strong{font-size:14px;color:#1b3045;margin:2px 0 4px}.requirements-list small{font-size:12px;color:#708093;line-height:1.55}
.requirements-note{display:grid;grid-template-columns:70px 1fr;gap:18px;align-items:center;margin-top:26px;padding:26px 30px;border-radius:26px;border:1px solid #d4e8e4;background:radial-gradient(circle at 94% 15%,rgba(14,165,164,.12),transparent 29%),linear-gradient(135deg,#ecfbf7,#f7fbff);box-shadow:0 17px 42px rgba(22,60,78,.07)}.requirements-note-icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;font-size:30px;background:#fff;box-shadow:0 12px 27px rgba(23,62,80,.09)}.requirements-note small{font-size:9px;letter-spacing:.15em;font-weight:900;color:#0b8d7b}.requirements-note h2{font-size:24px;margin:5px 0 3px;color:#17243b}.requirements-note p{margin:0;color:#6d7f92;font-size:13px}
@keyframes reqFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes reqPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}
@media(max-width:980px){.public-requirements-promo,.requirements-hero,.requirements-grid{grid-template-columns:1fr}.public-requirements-promo-cards{max-width:650px}.requirements-hero-visual{min-height:155px}.requirements-couple{font-size:58px}}
@media(max-width:650px){.public-requirements-promo-cards{grid-template-columns:1fr}.requirements-main{width:calc(100% - 18px);margin:10px auto 25px}.requirements-hero{padding:30px 22px;border-radius:26px}.requirements-hero h1{font-size:32px}.requirements-couple{font-size:47px}.requirements-card{border-radius:24px}.requirements-card header{grid-template-columns:58px 1fr;padding:22px 18px}.requirements-avatar{width:54px;height:54px;border-radius:17px;font-size:28px}.requirements-list{padding:10px}.requirements-list li{grid-template-columns:42px 1fr;padding:13px 10px}.req-icon{width:40px;height:40px}.requirements-note{grid-template-columns:1fr;text-align:center;padding:22px}.requirements-note-icon{margin:auto}.public-nav-actions .public-requirements-link{display:none}}

/* Penyempurnaan kartu menu persyaratan publik v4.5.9 */
.public-requirements-promo{position:relative;overflow:hidden;border-color:#d9e8eb!important;background:linear-gradient(135deg,#ffffff 0%,#f2fbf8 55%,#f2f6ff 100%)!important}
.public-requirements-promo:before{content:"";position:absolute;width:260px;height:260px;border-radius:50%;right:-90px;top:-120px;background:radial-gradient(circle,rgba(37,99,235,.12),rgba(37,99,235,0) 72%)}
.public-requirements-promo>*{position:relative;z-index:1}.public-requirements-promo-copy h2{font-size:32px!important}.public-requirements-button{transition:.22s}.public-requirements-button:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(37,99,235,.23)}
.public-requirements-promo-cards article{border-radius:22px!important}.public-requirements-promo-cards .promo-icon{width:50px;height:50px;margin:0 auto 10px!important;border-radius:16px;display:grid!important;place-items:center;background:linear-gradient(145deg,#e9faf5,#eef4ff);color:#0b8578;border:1px solid #d5e8e5}.public-requirements-promo-cards .promo-icon svg{width:25px;height:25px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.public-requirements-promo-cards article:nth-child(2) .promo-icon{color:#c2417a;background:linear-gradient(145deg,#fff0f7,#fffafd);border-color:#f0dae5}.public-requirements-promo-cards article:nth-child(3) .promo-icon{color:#2563ae;background:linear-gradient(145deg,#edf4ff,#f8fbff);border-color:#dbe6f6}


/* =========================================================
   Public mobile responsive + navigation v4.6.0
   ========================================================= */
.public-mobile-toggle{display:none;width:44px;height:44px;border:1px solid #d8e5e9;border-radius:13px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:4px;cursor:pointer;box-shadow:0 8px 20px rgba(22,59,78,.07)}
.public-mobile-toggle span{display:block;width:19px;height:2px;border-radius:99px;background:#174052;transition:.22s}
.public-nav.menu-open .public-mobile-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.public-nav.menu-open .public-mobile-toggle span:nth-child(2){opacity:0}
.public-nav.menu-open .public-mobile-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:760px){
  .public-dashboard-body{overflow-x:hidden}
  .public-nav{height:auto;min-height:68px;padding:10px 12px;gap:10px;align-items:center;position:sticky;top:0}
  .public-brand{min-width:0;flex:1;gap:9px}.public-brand>span,.req-brand-logo,.req-brand-fallback{width:42px!important;height:42px!important;flex:0 0 42px!important;border-radius:13px!important}
  .public-brand div{min-width:0}.public-brand strong{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.public-brand small{font-size:10px}
  .public-mobile-toggle{display:flex;flex:0 0 44px}
  .public-nav-actions{display:none!important;position:absolute;left:10px;right:10px;top:calc(100% + 7px);padding:10px;flex-direction:column;align-items:stretch;gap:8px;border:1px solid #d9e6ea;border-radius:18px;background:rgba(255,255,255,.98);box-shadow:0 22px 50px rgba(13,48,66,.18);backdrop-filter:blur(14px)}
  .public-nav.menu-open .public-nav-actions{display:flex!important;animation:publicMenuIn .2s ease}
  .public-nav-actions>span{display:none!important}.public-nav-actions>a{display:flex!important;width:100%;min-height:44px;align-items:center;justify-content:center;padding:10px 12px!important;border-radius:12px!important;font-size:11px!important}
  .public-dashboard{width:calc(100% - 16px);margin:10px auto 24px}
  .public-hero{min-height:0;padding:25px 18px;border-radius:24px;grid-template-columns:1fr;gap:22px}
  .public-kicker{font-size:9px;letter-spacing:.12em}.public-hero h1{font-size:29px;line-height:1.12;margin:10px 0}.public-hero p{font-size:13px;line-height:1.65}
  .public-hero-actions{display:grid;grid-template-columns:1fr;gap:9px;margin-top:18px}.public-hero-actions a{width:100%;min-height:45px;padding:11px 14px;text-align:center}
  .public-hero-summary{grid-template-columns:1fr 1fr;gap:10px}.public-hero-summary article{padding:17px 14px;border-radius:18px}.public-hero-summary strong{font-size:31px}.public-hero-summary span{font-size:10px}.public-hero-summary small{font-size:10px}
  .public-section{margin-top:14px;padding:20px 14px;border-radius:22px}.public-section-title h2{font-size:23px;line-height:1.18}.public-section-title p{font-size:12px;line-height:1.6}
  .public-requirements-promo{grid-template-columns:1fr!important;gap:20px!important}.public-requirements-promo-copy h2{font-size:25px!important}.public-requirements-promo-copy p{font-size:12px}.public-requirements-button{width:100%;justify-content:center}
  .public-requirements-promo-cards{grid-template-columns:1fr!important;gap:9px!important}.public-requirements-promo-cards article{display:grid;grid-template-columns:48px 1fr;column-gap:12px;align-items:center;text-align:left!important;padding:13px!important}.public-requirements-promo-cards .promo-icon{grid-row:1/3;margin:0!important}.public-requirements-promo-cards strong,.public-requirements-promo-cards small{text-align:left}
  .public-chart-grid{grid-template-columns:1fr;gap:12px;margin-top:16px}.public-chart-card.wide{grid-column:auto}.public-chart-card{border-radius:19px}.public-chart-card header{padding:16px 14px 10px;align-items:flex-start;gap:8px}.public-chart-card h3{font-size:15px}.public-chart-card header>b{font-size:10px}.public-canvas,.public-canvas.tall{min-height:230px;padding:8px 5px}
  .public-rec-summary{flex-direction:column;align-items:stretch;gap:12px;padding:14px}.public-filter{width:100%;display:grid;grid-template-columns:1fr 1fr}.public-filter button{width:100%}
  .public-footer{padding:20px 14px;display:block;text-align:center;font-size:10px}.public-footer span{display:block;margin:4px 0}
  .req-main{width:calc(100% - 14px)!important;margin:8px auto 24px!important}.req-hero{padding:24px 16px!important;border-radius:23px!important}.req-hero h1{font-size:30px!important}.req-hero p{font-size:12.5px!important}.req-hero-actions{display:grid!important;grid-template-columns:1fr!important}.req-hero-actions a,.req-hero-actions button{width:100%!important}.req-hero-visual{min-height:150px!important}.req-couple-card{width:180px!important;height:155px!important}.req-couple-svg{width:110px!important;height:110px!important}.req-stats{gap:9px!important;margin:14px 0!important}.req-stat{padding:14px!important;border-radius:18px!important}.req-stat strong{font-size:25px!important}.req-jump{display:grid!important;grid-template-columns:1fr!important;gap:8px!important}.req-jump a{text-align:center!important}.req-grid{gap:14px!important}.req-panel-head{grid-template-columns:48px 1fr!important;gap:11px!important;padding:18px 14px!important}.req-panel-head h2{font-size:22px!important}.req-panel-head p{font-size:11px!important}.req-count{grid-column:2!important;justify-self:start!important}.req-list{padding:8px!important}.req-item{grid-template-columns:38px minmax(0,1fr)!important;gap:10px!important;padding:12px 9px!important}.req-item-icon{width:38px!important;height:38px!important}.req-item-copy strong{font-size:13px!important}.req-item-copy small{font-size:11px!important}.req-badge{grid-column:2!important;justify-self:start!important}.req-note{grid-template-columns:1fr!important;text-align:center!important;padding:20px 16px!important}.req-note-icon{margin:auto!important}.req-note h2{font-size:21px!important}.req-note p{font-size:11.5px!important}.req-note-mark{justify-self:center!important}
}
@media(max-width:420px){.public-hero-summary{grid-template-columns:1fr}.public-hero h1{font-size:26px}.public-section{padding:18px 12px}.public-chart-card header{flex-direction:column}.public-chart-card header>b{align-self:flex-start}}
@keyframes publicMenuIn{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:none}}


.public-brand.with-logo{gap:14px}
.public-brand-logo{width:48px;height:48px;display:grid;place-items:center;border-radius:15px;background:linear-gradient(180deg,#ffffff,#f5fbfb);border:1px solid #d7e8ea;box-shadow:0 10px 24px rgba(8,125,121,.12);overflow:hidden;flex:0 0 48px}
.public-brand-logo img{width:100%;height:100%;object-fit:contain;display:block;padding:3px}
.public-nav-logo{width:44px;height:44px;display:grid;place-items:center;border-radius:14px;background:linear-gradient(180deg,#ffffff,#f4fbfb);border:1px solid #d6e8eb;box-shadow:0 10px 20px rgba(16,74,91,.10);overflow:hidden;padding:3px}
.public-nav-logo img{width:100%;height:100%;object-fit:contain;display:block}
.public-akad-badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:11px;font-weight:800;white-space:nowrap;border:1px solid transparent}
.public-akad-badge.done{background:#eaf9f0;color:#137a43;border-color:#bfe6cf}
.public-akad-badge.pending{background:#fff6e6;color:#a55a00;border-color:#f2d39a}
@media(max-width:600px){.public-nav-logo{display:none}.public-brand-logo{width:42px;height:42px;flex-basis:42px;border-radius:13px}}


.statistics-page .public-education-chart{background:linear-gradient(180deg,#ffffff,#fbfdff)}
.statistics-page .education-canvas{min-height:480px;padding:14px 16px 10px}
@media(max-width:760px){.statistics-page .education-canvas{min-height:520px;padding:10px 4px}.statistics-page .public-education-chart header{align-items:flex-start;gap:10px;flex-direction:column}}


/* Perbaikan presisi logo desa pada sidebar admin */
.sidebar .brand{align-items:center;gap:14px;padding-left:4px;padding-right:4px}
.sidebar .brand-mark.brand-mark--logo{width:62px!important;height:62px!important;flex:0 0 62px!important;padding:5px!important;border-radius:18px!important;background:#ffffff!important;border:1px solid rgba(255,255,255,.88)!important;box-shadow:0 14px 30px rgba(0,35,44,.22),inset 0 0 0 1px rgba(9,121,111,.06)!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;isolation:isolate}
.sidebar .brand-mark.brand-mark--logo:before,.sidebar .brand-mark.brand-mark--logo:after{display:none!important;content:none!important}
.sidebar .brand-mark.brand-mark--logo img{position:relative!important;z-index:2!important;display:block!important;width:auto!important;height:auto!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important;object-position:center!important;margin:auto!important;padding:0!important;border:0!important;border-radius:0!important;transform:none!important;filter:none!important;opacity:1!important}
.sidebar .brand-mark.brand-mark--logo.logo-load-error:after{content:"CD"!important;display:grid!important;place-items:center!important;position:absolute!important;inset:0!important;color:#08796f!important;font-weight:900!important;font-size:17px!important}
.sidebar .brand-copy{min-width:0;flex:1}
.sidebar .brand-copy strong{line-height:1.15}
@media(max-width:900px){.sidebar .brand-mark.brand-mark--logo{width:58px!important;height:58px!important;flex-basis:58px!important}}


