/*! Semara Incorporated - @semarainc (BETA) */
:root{--primary: #0077B6;--primary-dark: #023E8A;--primary-light: #90E0EF;--primary-glow: rgba(0, 119, 182, .15);--bg: #F8FAFC;--bg-card: #FFFFFF;--bg-dark: #0A1628;--text: #1E293B;--text-muted: #64748B;--text-light: #94A3B8;--border: #E2E8F0;--border-light: #F1F5F9;--danger: #B00020;--danger-light: #FDECEA;--success: #2E7D32;--success-light: #E8F5E9;--warning: #E65100;--warning-light: #FFF3E0;--info: #0288D1;--info-light: #E1F5FE;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Outfit", "Inter", sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .15);--shadow-glow: 0 0 20px rgba(0, 119, 182, .25);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--primary-dark)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:10000;background:linear-gradient(135deg,var(--danger),#D32F2F);color:#fff;text-align:center;padding:var(--space-sm) var(--space-md);font-weight:600;font-size:.85rem;box-shadow:0 2px 10px #b0002066;animation:slideDown .3s ease}.offline-banner.hidden{display:none}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}body.is-offline{padding-top:40px}body.is-offline .btn,body.is-offline button,body.is-offline input,body.is-offline select,body.is-offline textarea{pointer-events:none!important;opacity:.5!important}#app{min-height:100vh}.app-header{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.app-header .logo-area{display:flex;align-items:center;gap:var(--space-sm)}.app-header .logo-area h1{font-size:1.2rem;color:#fff;font-family:var(--font-display);font-weight:800;letter-spacing:-.02em}.app-header .logo-area .logo-icon{width:36px;height:36px;background:#fff3;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.header-actions{display:flex;align-items:center;gap:var(--space-sm);position:relative}.badge-negatif{background:#e5393526;color:#c62828}.badge-biru{background:#2196f326;color:#1976d2}.badge-abu{background:#9e9e9e26;color:#616161}.btn-header{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-header:hover{background:#ffffff40}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);padding:6px}.hamburger-btn:hover{background:#ffffff40}.hamburger-line{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease}.hamburger-btn.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.hamburger-dropdown{position:absolute;top:calc(100% + var(--space-sm));right:0;background:#fff;backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;min-width:200px;padding:var(--space-xs);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s ease;z-index:200}.hamburger-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.menu-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-size:.88rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);text-align:left}.menu-item:hover{background:var(--primary-glow)}.menu-item-danger{color:var(--error)}.menu-item-danger:hover{background:#ef44441a}.menu-icon{font-size:1rem;width:24px;text-align:center}.menu-divider{height:1px;background:var(--border);margin:var(--space-xs) 0}.hero{position:relative;background:linear-gradient(160deg,var(--primary-dark) 0%,var(--primary) 50%,#00B4D8 100%);color:#fff;padding:var(--space-2xl) var(--space-lg);text-align:center;overflow:hidden}.hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(144,224,239,.15) 0%,transparent 60%);animation:heroGlow 8s ease-in-out infinite alternate}@keyframes heroGlow{0%{transform:translate(0)}to{transform:translate(5%,3%)}}.hero-bg{background:linear-gradient(160deg,#023e8abf,#0077b6a6,#00b4d899),url(/assets/background.webp) center/cover no-repeat;min-height:280px}.hero-bg:before{background:radial-gradient(circle at 30% 50%,rgba(144,224,239,.1) 0%,transparent 60%)}.hero-content{position:relative;z-index:1;max-width:600px;margin:0 auto}.hero h1{font-family:var(--font-display);font-size:2.2rem;font-weight:800;color:#fff;margin-bottom:var(--space-sm);letter-spacing:-.02em}.hero .tagline{font-size:.95rem;opacity:.92;margin-top:var(--space-sm);line-height:1.6;letter-spacing:.02em}.hero .tagline strong{color:gold;font-weight:700}.hero .acronym-line{font-size:.78rem;opacity:.8;margin-top:var(--space-xs);letter-spacing:.04em;line-height:1.5}.hero .acronym-line strong{color:gold;font-weight:700;font-size:.88rem}.hero-image{width:100%;max-width:400px;margin:var(--space-lg) auto 0;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}.ornament-divider{width:80px;height:3px;background:linear-gradient(90deg,transparent,var(--primary-light),transparent);margin:var(--space-md) auto;border-radius:var(--radius-full)}.nav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:var(--space-lg);max-width:600px;margin:0 auto}.nav-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal);border:1px solid var(--border);position:relative;overflow:hidden}.nav-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--primary-light));transform:scaleX(0);transition:transform var(--transition-normal)}.nav-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.nav-card:hover:before{transform:scaleX(1)}.nav-card:active{transform:translateY(-2px)}.nav-card .card-icon{width:56px;height:56px;border-radius:var(--radius-md);background:var(--primary-glow);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto var(--space-sm)}.nav-card .card-title{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--primary-dark);margin-bottom:var(--space-xs)}.nav-card .card-desc{font-size:.75rem;color:var(--text-muted)}.page{padding:var(--space-lg);max-width:900px;margin:0 auto;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-title{font-size:1.4rem;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.page-title .back-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);font-size:1rem}.page-title .back-btn:hover{background:var(--primary-glow);border-color:var(--primary-light)}.toolbar{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md);align-items:center}.search-input{flex:1;min-width:180px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);font-family:var(--font-body);font-size:.85rem;transition:all var(--transition-fast);outline:none}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.filter-select{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);font-family:var(--font-body);font-size:.85rem;outline:none;cursor:pointer;transition:all var(--transition-fast)}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);border:none;font-family:var(--font-body);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;line-height:1.4}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 2px 8px #0077b64d}.btn-primary:hover{box-shadow:0 4px 16px #0077b666;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#c62828}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#1b5e20}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.78rem}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.btn-fab{position:fixed;bottom:var(--space-xl);right:var(--space-lg);width:56px;height:56px;border-radius:50%;font-size:1.5rem;box-shadow:var(--shadow-lg);z-index:50}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table thead{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff}.data-table th{padding:var(--space-sm) var(--space-md);text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-light);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--primary-glow)}.data-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:var(--space-xs)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-curiga{background:var(--warning-light);color:var(--warning)}.badge-sampel{background:var(--info-light);color:var(--info)}.badge-negatif{background:var(--success-light);color:var(--success)}.badge-positif{background:var(--danger-light);color:var(--danger)}.badge-pengobatan{background:var(--info-light);color:var(--info)}.badge-tuntas{background:var(--success-light);color:var(--success)}.badge-dropout{background:var(--danger-light);color:var(--danger)}.badge-belum{background:var(--border-light);color:var(--text-muted)}.badge-sudah{background:var(--success-light);color:var(--success)}.badge-tpt{background:var(--warning-light);color:var(--warning)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:var(--space-xs)}.form-control{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);font-family:var(--font-body);font-size:.9rem;background:var(--bg-card);transition:all var(--transition-fast);outline:none}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}select.form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.checkbox-group{display:flex;flex-direction:column;gap:var(--space-sm)}.checkbox-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.checkbox-item:hover{background:var(--primary-glow);border-color:var(--primary-light)}.checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.checkbox-item span,.checkbox-item label{font-size:.85rem;cursor:pointer;margin:0}.modal-overlay{position:fixed;inset:0;background:#0a162899;backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}@media(min-width:640px){.modal-overlay{align-items:center}}.modal{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-xl)}@media(min-width:640px){.modal{border-radius:var(--radius-xl)}}@keyframes slideUp{0%{transform:translateY(40px);opacity:.8}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-light)}.modal-header h3{font-size:1.1rem}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:var(--border-light);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--danger-light);color:var(--danger)}.modal-body{padding:var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-light);display:flex;gap:var(--space-sm);justify-content:flex-end}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;display:flex;align-items:center;gap:var(--space-sm);min-width:250px;max-width:380px}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--primary);color:#fff}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.confirm-overlay{position:fixed;inset:0;background:#0a162880;backdrop-filter:blur(2px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.confirm-dialog{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-xl);max-width:360px;width:90%;text-align:center;box-shadow:var(--shadow-xl);animation:slideUp .2s ease}.confirm-dialog p{margin-bottom:var(--space-lg);color:var(--text);font-size:.95rem}.confirm-actions{display:flex;gap:var(--space-sm);justify-content:center}.pmo-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-sm)}.pmo-day{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.7rem;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-card);position:relative}.pmo-day:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.pmo-day.minum{background:var(--success);color:#fff;border-color:var(--success)}.pmo-day.tidak{background:var(--danger);color:#fff;border-color:var(--danger)}.pmo-day .day-num{font-weight:600}.pmo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:all var(--transition-fast)}.pmo-card:hover{box-shadow:var(--shadow-md)}.pmo-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.pmo-patient-name{font-weight:700;color:var(--primary-dark)}.pmo-patient-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-sm);cursor:pointer;transition:all .15s}.pmo-patient-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.pmo-patient-card-left{min-width:0;flex:1}.pmo-patient-card-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.pmo-patient-card-meta{font-size:.78rem;color:var(--text-muted);margin-top:2px}.pmo-patient-card-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.pmo-arrow{font-size:.7rem;color:var(--text-muted)}.pmo-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg)}.pmo-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.pmo-detail-name{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.pmo-detail-meta{font-size:.8rem;color:var(--text-muted);margin-top:2px}.pmo-detail-status-area .status-select{padding:6px 28px 6px 10px;border-radius:var(--radius-md);border:1px solid var(--border);background-color:var(--bg-card);font-weight:500;font-size:.82rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;color:var(--text-primary)}.pmo-stats{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.pmo-stat{flex:1;text-align:center;padding:var(--space-sm);background:var(--bg-hover);border-radius:var(--radius-md)}.pmo-stat-value{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.pmo-stat-minum{color:var(--success)}.pmo-stat-tidak{color:var(--danger)}.pmo-stat-label{font-size:.72rem;color:var(--text-muted);margin-top:2px}.pmo-calendar-legend{font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.pmo-legend-item{display:flex;align-items:center;gap:4px}.pmo-legend-dot{width:12px;height:12px;border-radius:3px;border:1px solid var(--border)}.pmo-legend-dot.minum{background:var(--success);border-color:var(--success)}.pmo-legend-dot.tidak{background:var(--danger);border-color:var(--danger)}.pmo-legend-dot.empty{background:var(--bg-card)}.pmo-month-label{position:absolute;top:-14px;left:0;font-size:.6rem;color:var(--text-muted);font-weight:600}.pmo-month-section{margin-bottom:var(--space-lg)}.pmo-month-header{font-weight:700;font-size:.9rem;color:var(--text-primary);margin-bottom:var(--space-xs);text-transform:capitalize}.pmo-month-picker{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.pmo-month-picker-selects{flex:1;display:flex;gap:var(--space-xs)}.pmo-picker-select{flex:1;padding:8px 28px 8px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background-color:var(--bg-card);font-weight:600;font-size:.88rem;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;transition:all .15s}.pmo-picker-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0077b626}.pmo-month-picker .btn{flex-shrink:0;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:.85rem}.pmo-weekday-header{display:grid;grid-template-columns:repeat(7,44px);gap:4px;margin-bottom:4px;justify-content:center}.pmo-weekday-header span{text-align:center;font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.pmo-grid-calendar{display:grid;grid-template-columns:repeat(7,44px);gap:4px;justify-content:center}.pmo-grid-calendar .pmo-day{width:44px;height:44px;aspect-ratio:unset}@media(max-width:400px){.pmo-weekday-header,.pmo-grid-calendar{grid-template-columns:repeat(7,1fr)}.pmo-grid-calendar .pmo-day{width:auto;height:auto;aspect-ratio:1}}.pmo-day.spacer{border:none;background:transparent;cursor:default;pointer-events:none}.pmo-choice-dialog{text-align:center}.pmo-choice-buttons{display:flex;gap:var(--space-sm)}.pmo-choice-btn{flex:1;padding:var(--space-md) var(--space-sm);font-size:.95rem;font-weight:600;border-radius:var(--radius-md);border:none;color:#fff;cursor:pointer;transition:all .15s}.pmo-choice-minum{background:var(--primary)}.pmo-choice-minum:hover{background:var(--primary-dark);box-shadow:0 2px 8px #0077b64d}.pmo-choice-tidak{background:var(--danger)}.pmo-choice-tidak:hover{filter:brightness(.9);box-shadow:0 2px 8px #dc35454d}.pmo-choice-hapus{background:var(--text-muted)}.pmo-choice-hapus:hover{filter:brightness(.85);box-shadow:0 2px 8px #00000026}.pmo-day.locked{opacity:.45;cursor:default;pointer-events:none}.pmo-day.locked:hover{border-color:var(--border);box-shadow:none}.chart-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.chart-container canvas{width:100%!important;height:250px!important}.chart-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--primary-dark);margin-bottom:var(--space-md)}.ranking-scroll-wrapper{max-height:400px;overflow-y:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.ranking-scroll-wrapper .table-container{overflow-x:auto}.ranking-scroll-wrapper .data-table thead th{position:sticky;top:0;z-index:2;background:var(--primary)}.ranking-badge{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.ranking-badge.gold{background:linear-gradient(135deg,gold,#ffa000)}.ranking-badge.silver{background:linear-gradient(135deg,silver,#9e9e9e)}.ranking-badge.bronze{background:linear-gradient(135deg,#cd7f32,sienna)}.combobox-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:220px;overflow-y:auto;z-index:90;animation:fadeIn .15s ease}.combobox-item{padding:var(--space-sm) var(--space-md);font-size:.85rem;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-light)}.combobox-item:last-child{border-bottom:none}.combobox-item:hover{background:var(--primary-glow);color:var(--primary-dark)}.combobox-item.combobox-all{font-weight:600;color:var(--primary)}.combobox-item.combobox-empty{color:var(--text-muted);cursor:default;font-style:italic}.active-filter-tag{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--primary-glow);border:1px solid var(--primary-light);color:var(--primary-dark);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.82rem;font-weight:600;margin-bottom:var(--space-md);animation:fadeIn .2s ease}.filter-clear-btn{width:20px;height:20px;border:none;border-radius:50%;background:var(--primary);color:#fff;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.filter-clear-btn:hover{background:var(--danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--primary-dark) 0%,var(--primary) 50%,#00B4D8 100%);padding:var(--space-lg)}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:400px;box-shadow:var(--shadow-xl);text-align:center}.login-card h2{margin-bottom:var(--space-xs)}.login-card .login-subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:var(--space-xl)}.login-card .form-control{text-align:center;font-size:1.1rem;letter-spacing:.1em;padding:var(--space-md)}.login-card .btn{width:100%;padding:var(--space-md);font-size:1rem;margin-top:var(--space-md)}.login-error{color:var(--danger);font-size:.82rem;margin-top:var(--space-sm);min-height:1.2em}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-muted)}.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}.empty-state p{font-size:.9rem}.spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);flex-direction:column;gap:var(--space-md);color:var(--text-muted)}.status-select{padding:4px 28px 4px 8px;border-radius:var(--radius-full);border:1px solid var(--border);font-size:.78rem;font-family:var(--font-body);font-weight:500;cursor:pointer;outline:none;background:var(--bg-card);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:all var(--transition-fast)}.status-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}@media(max-width:480px){.nav-grid{grid-template-columns:1fr 1fr;gap:var(--space-sm);padding:var(--space-md)}.nav-card{padding:var(--space-md)}.nav-card .card-icon{width:44px;height:44px;font-size:1.2rem}.page{padding:var(--space-md)}.toolbar{flex-direction:column}.search-input,.filter-select{width:100%}.form-row{grid-template-columns:1fr}.data-table{font-size:.78rem}.data-table th,.data-table td{padding:var(--space-xs) var(--space-sm)}.hero h1{font-size:1.6rem}.toast-container{left:var(--space-md);right:var(--space-md)}.toast{min-width:auto;max-width:none}}@media(min-width:768px){.hero h1{font-size:2.8rem}.hero .tagline{font-size:1.15rem}.nav-grid{grid-template-columns:repeat(4,1fr);max-width:800px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--border-light)}::-webkit-scrollbar-thumb{background:var(--text-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.hidden{display:none!important}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.gap-sm{gap:var(--space-sm)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.install-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:var(--space-md);animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.install-banner.hidden{display:none}.install-card{display:flex;align-items:center;gap:var(--space-md);max-width:480px;margin:0 auto;padding:var(--space-md) var(--space-lg);background:#023e8aeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);box-shadow:0 8px 32px #0000004d,0 0 0 1px #0077b64d}.install-icon{font-size:2.2rem;flex-shrink:0}.install-text{flex:1;display:flex;flex-direction:column;gap:2px}.install-text strong{color:#fff;font-size:.95rem;font-weight:700}.install-text span{color:#ffffffa6;font-size:.78rem}.install-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.install-btn-primary{background:linear-gradient(135deg,#00b4d8,#0077b6);color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-md);font-weight:700;font-size:.85rem;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.install-btn-primary:hover{transform:scale(1.05);box-shadow:0 4px 12px #00b4d866}.install-btn-primary:active{transform:scale(.97)}.install-btn-dismiss{background:transparent;color:#ffffff80;border:1px solid rgba(255,255,255,.15);padding:8px 12px;border-radius:var(--radius-md);font-size:.8rem;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.install-btn-dismiss:hover{color:#fffc;border-color:#ffffff4d}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.global-loading{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .15s ease}.global-loading.hidden{display:none}.global-loading-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:2.5rem 3.5rem;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.global-loading-card .spinner{width:44px;height:44px}.global-loading-card span{color:var(--text-secondary);font-size:1rem;font-weight:600}.accordion-group{background:var(--bg-card);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);overflow:hidden;border:1px solid var(--border)}.accordion-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);cursor:pointer;transition:background .15s;gap:var(--space-sm)}.accordion-header:hover{background:var(--bg-hover)}.accordion-header.active{background:var(--bg-hover);border-bottom:1px solid var(--border)}.accordion-title{display:flex;align-items:center;gap:var(--space-sm);min-width:0;flex:1}.accordion-arrow{font-size:.7rem;color:var(--text-muted);flex-shrink:0;width:1rem;text-align:center;transition:transform .2s}.accordion-patient-info{min-width:0}.accordion-patient-name{font-weight:600;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.accordion-patient-meta{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap;margin-top:2px}.accordion-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-hover);padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;font-weight:500}.accordion-header-right{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.accordion-header-right .btn-add-kontak-acc{width:26px;height:26px;padding:0;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:50%}.btn-xs{padding:2px 6px;font-size:.72rem;border-radius:var(--radius-sm)}.kontak-actions-row{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.kontak-action-btns{display:flex;gap:4px}.empty-kontak-row{justify-content:center;padding:var(--space-md) var(--space-lg)!important}.accordion-body{padding:0}.accordion-body.hidden{display:none}.kontak-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);padding-left:calc(var(--space-lg) + 1.5rem);border-top:1px solid var(--border);gap:var(--space-sm)}.kontak-row:first-child{border-top:none}.kontak-info{min-width:0;flex:1}.kontak-name{font-weight:500;font-size:.88rem;color:var(--text-primary)}.kontak-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.kontak-status{flex-shrink:0}.kontak-status .status-select{font-size:.78rem;padding:6px 28px 6px 10px;border-radius:var(--radius-md);border:1px solid var(--border);background-color:var(--bg-card);font-weight:500;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;color:var(--text-primary);box-shadow:0 1px 2px #0000000d;transition:all .2s}.kontak-status .status-select:hover{border-color:var(--primary);box-shadow:0 0 0 2px #0077b61a}.kontak-status .status-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0077b633}@keyframes highlightPulseRow{0%{background-color:#ffc1074d}to{background-color:transparent}}@keyframes highlightPulseHeader{0%{background-color:#ffc10766}to{background-color:var(--bg-card)}}.highlight-row{animation:highlightPulseRow 2s ease-out}.highlight-header{animation:highlightPulseHeader 2s ease-out}.view-toggle{display:inline-flex;align-items:center;gap:4px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-lg);padding:4px;box-shadow:inset 0 1px 3px #0000000d}.view-toggle-btn{display:flex;align-items:center;gap:6px;padding:6px 16px;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1)}.view-toggle-btn.active{background:var(--bg-card);color:var(--primary);box-shadow:0 2px 5px #00000014}.view-toggle-btn:hover:not(.active){background:#0000000d}#kontak-graph-container{position:relative}#cy-graph{width:100%;height:65vh;min-height:400px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card)}.graph-legend{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-sm) 0;font-size:.75rem;color:var(--text-muted)}.graph-legend-item{display:flex;align-items:center;gap:4px}.graph-legend-dot{width:12px;height:12px;border-radius:50%}.gl-positif{background:#dc3545}.gl-kontak-belum{background:#ffc107}.gl-kontak-sudah{background:#28a745}.gl-kontak-tpt{background:#6f42c1}.graph-node-popup{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);z-index:100;width:calc(100% - 2 * var(--space-md));max-width:340px}.graph-popup-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:0 4px 20px #00000026;position:relative}.graph-popup-close{position:absolute;top:8px;right:10px;border:none;background:none;font-size:1rem;cursor:pointer;color:var(--text-muted);padding:4px;line-height:1}.graph-popup-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.graph-popup-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.graph-popup-name{font-weight:700;font-size:.95rem;color:var(--text-primary)}.graph-popup-type{font-size:.75rem;color:var(--text-muted)}.graph-popup-info{font-size:.8rem;color:var(--text-secondary);line-height:1.6}.graph-popup-info .status-select{margin-top:4px}.graph-popup-tb{font-size:.78rem;font-weight:600;color:var(--primary);margin-top:2px}.graph-popup-tb-none{font-weight:400;color:var(--text-muted);font-style:italic}.dp-dropdown{position:absolute;top:100%;left:0;right:0;z-index:10;margin-top:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 4px 16px #0000001f;padding:var(--space-sm);animation:fadeIn .15s ease}.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.dp-selectors{display:flex;gap:4px;flex:1;justify-content:center}.dp-month-select,.dp-year-select{padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:.82rem;font-weight:600;color:var(--text-primary);cursor:pointer;appearance:auto}.dp-month-select{min-width:90px}.dp-year-select{min-width:68px}.dp-nav{border:none;background:var(--bg-hover);border-radius:var(--radius-sm);width:30px;height:30px;cursor:pointer;font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .15s}.dp-nav:hover{background:var(--primary);color:#fff}.dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.dp-weekdays span{text-align:center;font-size:.65rem;font-weight:600;color:var(--text-muted)}.dp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-day{text-align:center;padding:6px 0;font-size:.8rem;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-primary);transition:all .12s}.dp-day:hover:not(.dp-empty){background:var(--bg-hover)}.dp-day.dp-selected{background:var(--primary);color:#fff;font-weight:700}.dp-day.dp-empty{cursor:default}.dp-day.dp-today:not(.dp-selected){border:2px solid var(--primary);font-weight:600}.datepicker-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px!important}.slider{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--card-bg);border:1px solid var(--border);margin:0 auto;max-width:500px}.slider-track{display:flex;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}.slide{min-width:100%;box-sizing:border-box;padding:var(--space-lg)}.slide-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);border:2px dashed var(--border);border-radius:var(--radius-md);color:var(--text-muted);text-align:center;min-height:200px}.slide-placeholder-icon{font-size:3rem;margin-bottom:var(--space-sm)}.slide-placeholder-hint{font-size:.78rem;opacity:.6;margin-top:var(--space-xs)}.slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text-primary);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:5;line-height:1}.slider-btn:hover{background:var(--primary-glow);border-color:var(--primary-light)}.slider-prev{left:var(--space-sm)}.slider-next{right:var(--space-sm)}.slider-dots{display:flex;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) 0 var(--space-md)}.slider-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:all var(--transition-fast)}.slider-dot.active{background:var(--primary);transform:scale(1.3)}.slider-indicator{text-align:center;font-size:.78rem;color:var(--text-muted);padding:var(--space-xs) 0}.tutorial-slide{text-align:center}.tutorial-img{width:100%;max-height:300px;object-fit:contain;border-radius:var(--radius-md);margin-bottom:var(--space-md)}.tutorial-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.tutorial-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.6}.tutorial-comparison{position:relative;width:100%;max-width:400px;max-height:300px;aspect-ratio:4/3;margin:0 auto var(--space-md);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--surface-hover);user-select:none;touch-action:pan-y}.compare-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center;pointer-events:none}.compare-before{z-index:2;clip-path:polygon(0 0,50% 0,50% 100%,0 100%)}.compare-after{z-index:1}.compare-handle{position:absolute;top:0;bottom:0;left:50%;width:40px;transform:translate(-50%);z-index:3;cursor:ew-resize;display:flex;align-items:center;justify-content:center}.compare-handle-line{position:absolute;top:0;bottom:0;left:50%;width:4px;background:var(--primary);transform:translate(-50%);box-shadow:0 0 5px #0000004d}.compare-handle-button{position:relative;width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 0 5px #0006;z-index:3}.compare-label{position:absolute;bottom:8px;padding:4px 8px;background:#0009;color:#fff;font-size:.75rem;border-radius:var(--radius-sm);z-index:3;pointer-events:none}.compare-label-before{left:8px}.compare-label-after{right:8px}.date-range-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:var(--space-sm)}.date-range-row .filter-select{flex:1;min-width:80px}.date-range-sep{color:var(--text-muted);font-size:.85rem;flex-shrink:0}.date-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.gl-kontak-curiga{background:#fd7e14}.gl-kontak-dahak{background:#17a2b8}.gl-kontak-positif{background:#c82333}.gl-kontak-negatif{background:#6c757d}
