:root{--color-green-dark: #04342C;--color-green-mid: #0F6E56;--color-green-light: #1D9E75;--color-orange: #D85A30;--color-orange-light: #E07B45;--color-blue: #185FA5;--color-blue-light: #3B8AD1;--color-text-dark: #2C2C2A;--color-text-mid: #444441;--color-text-muted: #6B6A64;--color-text-light: #999890;--color-bg-body: #EDEEEA;--color-bg-main: #FAFAF7;--color-bg-card: #ffffff;--color-border: #E0DFD8;--color-amber: #854F0B;--color-purple: #3C3489;--color-pink: #993556;--color-red: #A32D2D;--color-green-deep: #085041;--color-green-forest: #3B6D11;--radius-card: 16px;--radius-icon: 14px;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-family);background:var(--color-bg-body);color:var(--color-text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh}.ti{font-family:tabler-icons!important;font-style:normal;font-variant:normal;text-transform:none;line-height:1}a{text-decoration:none;color:inherit}button{font-family:inherit;border:none;background:none;cursor:pointer}img{max-width:100%;height:auto}.app-shell{display:flex;flex-direction:column;height:100dvh;width:100%;overflow:hidden;background:var(--color-bg-main)}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;background:var(--color-bg-main)}.app-header__left{display:flex;align-items:center;gap:10px}.app-header__logo-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--color-green-mid),var(--color-green-light));display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-header__logo-icon .ti{font-size:20px;color:#fff}.app-header__logo-text{display:flex;flex-direction:column}.app-header__logo-title{font-size:16px;font-weight:700;color:var(--color-green-dark)}.app-header__logo-gpr{color:var(--color-orange)}.app-header__logo-subtitle{font-size:10.5px;font-weight:500;color:var(--color-text-muted)}.app-header__right{display:flex;align-items:center;gap:10px}.app-header__bell{position:relative;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#fff;border:.5px solid var(--color-border);text-decoration:none;transition:background .15s}.app-header__bell .ti{font-size:16px;color:var(--color-text-mid)}.app-header__bell:hover{background:#f5f5f2}.app-header__bell-dot{position:absolute;top:-1px;right:-1px;width:8px;height:8px;border-radius:50%;background:var(--color-orange);border:1.5px solid var(--color-bg-main)}.app-header__avatar{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--color-blue);color:#fff;font-size:12px;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.app-content{flex:1;overflow-y:auto;margin-top:68px;margin-bottom:76px;-webkit-overflow-scrolling:touch;background:var(--color-bg-main)}.app-bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:flex-end;justify-content:space-around;height:76px;background:#fff;border-top:.5px solid var(--color-border);padding:12px 8px 18px;padding-bottom:max(16px,env(safe-area-inset-bottom))}.app-bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-decoration:none;color:var(--color-text-light);min-width:56px;font-size:12px!important;font-weight:600;transition:color .15s}.app-bottom-nav__item .ti{font-size:26px!important;line-height:1}.app-bottom-nav__item.active{color:var(--color-orange);font-weight:700}.app-bottom-nav__item--fab{position:relative;justify-content:center}.app-bottom-nav__fab{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-orange),var(--color-orange-light));color:#fff;margin-top:-28px;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 12px #d85a3059}.app-bottom-nav__fab .ti{font-size:28px!important;color:#fff}.app-bottom-nav__item--fab:hover .app-bottom-nav__fab{transform:scale(1.05);box-shadow:0 6px 16px #d85a3073}.app-bottom-nav__item--disabled{color:var(--color-text-light);opacity:.4;cursor:not-allowed;pointer-events:none;-webkit-user-select:none;user-select:none}.app-bottom-nav__fab--disabled{background:linear-gradient(135deg,#b0b0b0,#d0d0d0);box-shadow:none}.app-toast{position:fixed;bottom:80px;left:16px;right:16px;z-index:200;display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-text-dark);color:#f9fafb;border-radius:12px;box-shadow:0 4px 12px #00000026;animation:toast-slide-up .3s ease-out}.app-toast__message{flex:1;margin:0;font-size:.8125rem;line-height:1.4}.app-toast__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#9ca3af;font-size:1.25rem;cursor:pointer;border-radius:4px;flex-shrink:0}.app-toast__close:hover{color:#fff;background:#ffffff1a}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(min-width:429px){.app-toast{left:50%;right:auto;transform:translate(-50%);max-width:400px;width:calc(100% - 32px)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:1rem}.login-card{background:#fff;border-radius:1rem;padding:2rem 1.5rem;width:100%;max-width:380px;box-shadow:0 4px 24px #00000014}.login-card__header{text-align:center;margin-bottom:1.5rem}.login-card__title{font-size:1.5rem;font-weight:700;color:#04342c;margin:0}.login-card__title span{color:#d85a30}.login-card__subtitle{font-size:.8rem;color:#6b6a64;margin:.25rem 0 0}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form__error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:.75rem;font-size:.85rem;color:#991b1b}.login-form__field{display:flex;flex-direction:column;gap:.25rem}.login-form__field label{font-size:.85rem;font-weight:500;color:#374151}.login-form__field input{padding:.7rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;color:#1a1a2e;transition:border-color .15s}.login-form__field input:focus{outline:none;border-color:#0f6e56;box-shadow:0 0 0 2px #0f6e5626}.login-form__submit{padding:.75rem;border:none;border-radius:.5rem;background:#0f6e56;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.5rem}.login-form__submit:hover:not(:disabled){background:#04342c}.login-form__submit:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:#9ca3af;font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.login-google{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.7rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;font-size:.9rem;font-weight:500;color:#374151;cursor:pointer;transition:background .15s}.login-google:hover{background:#f9fafb}.dashboard{padding:4px 16px 24px;display:flex;flex-direction:column;gap:0}.dashboard__loading,.dashboard__error{text-align:center;padding:40px 16px;color:var(--color-text-muted);font-size:14px}.greeting-card{background:linear-gradient(120deg,#d85a30,#e07b45);border-radius:var(--radius-card);padding:16px;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.greeting-card__left{display:flex;flex-direction:column}.greeting-card__name{margin:0;font-size:15px;font-weight:600;color:#fff}.greeting-card__date{margin:3px 0 0;font-size:11.5px;font-weight:500;color:#faece7}.greeting-card__right{text-align:right}.greeting-card__location{display:flex;align-items:center;gap:4px;justify-content:flex-end}.greeting-card__location .ti{font-size:13px;color:#faece7}.greeting-card__blok{font-size:12px;font-weight:700;color:#fff}.greeting-card__rtrw{margin:3px 0 0;font-size:11px;font-weight:500;color:#faece7}.status-bar{background:#fff;border-radius:var(--radius-card);border:.5px solid var(--color-border);padding:14px 16px;display:flex;justify-content:space-between;margin-bottom:16px}.status-bar__item{flex:1;text-align:center}.status-bar__label{margin:0;font-size:10.5px;font-weight:500;color:var(--color-text-muted)}.status-bar__value{margin:3px 0 0;font-size:13.5px;font-weight:700;color:var(--color-text-dark);display:flex;align-items:center;justify-content:center;gap:3px}.status-bar__value .ti{font-size:12px}.status-bar__value--lunas{color:var(--color-green-mid)}.status-bar__value--amber{color:var(--color-amber)}.status-bar__sep{width:.5px;background:var(--color-border)}.hero-banner{background:linear-gradient(135deg,#04342c,#0f6e56 60%,#1d9e75);border-radius:var(--radius-card);padding:18px;position:relative;overflow:hidden;margin-bottom:16px}.hero-banner__circle{position:absolute;border-radius:50%}.hero-banner__circle--1{right:-20px;top:-20px;width:120px;height:120px;background:#ffffff14}.hero-banner__circle--2{right:20px;bottom:-30px;width:90px;height:90px;background:#ffffff0f}.hero-banner__title{margin:0;font-size:17px;font-weight:700;color:#fff;line-height:1.4;position:relative}.hero-banner__subtitle{margin:10px 0 0;font-size:12px;font-weight:500;color:#9fe1cb;line-height:1.6;max-width:75%;position:relative}.hero-banner__dots{display:flex;gap:5px;margin-top:14px;position:relative}.hero-banner__dot{width:5px;height:5px;border-radius:3px;background:#fff6}.hero-banner__dot--active{width:16px;background:#fff}.promo-slider{position:relative;border-radius:var(--radius-card);overflow:hidden;height:108px;margin-bottom:16px}.promo-slide{position:absolute;top:0;right:0;bottom:0;left:0;padding:16px;display:flex;align-items:center;justify-content:space-between;width:100%;border:0;background-color:#185fa5;background-size:cover;background-position:center;text-align:left;transition:opacity .4s;cursor:default}.promo-slide--clickable{cursor:pointer}.promo-slide__content{max-width:70%}.promo-slide__badge{font-size:9px;font-weight:700;background:#fff3;color:#fff;padding:3px 8px;border-radius:8px}.promo-slide__title{margin:8px 0 0;font-size:14px;font-weight:700;color:#fff;line-height:1.3}.promo-slide__subtitle{margin:3px 0 0;font-size:10.5px;font-weight:500;color:#ffffffdb}.promo-slide__icon{font-size:34px;color:#ffffff80}.promo-slider__dots{position:absolute;bottom:9px;left:0;right:0;display:flex;justify-content:center;gap:5px;z-index:5}.promo-slider__dot{width:5px;height:5px;border-radius:3px;background:#ffffff80;border:none;padding:0;cursor:pointer;transition:all .3s}.promo-slider__dot--active{width:16px;background:#fff}.menu-section{margin-bottom:16px}.menu-section__title{margin:0 0 10px;font-size:13px;font-weight:600;color:var(--color-text-muted)}.menu-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px 12px}.menu-grid__item{display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none;cursor:pointer}.menu-grid__icon{width:64px;height:64px;border-radius:var(--radius-icon);display:flex;align-items:center;justify-content:center}.menu-grid__icon .ti{font-size:29px}.menu-grid__icon--iuran{background:#faeeda}.menu-grid__icon--iuran .ti{color:#854f0b}.menu-grid__icon--pengumuman{background:#eaf3de}.menu-grid__icon--pengumuman .ti{color:#3b6d11}.menu-grid__icon--surat{background:#e6f1fb}.menu-grid__icon--surat .ti{color:#185fa5}.menu-grid__icon--lapor{background:#fcebeb}.menu-grid__icon--lapor .ti{color:#a32d2d}.menu-grid__icon--ambulance{background:#fcebeb}.menu-grid__icon--ambulance .ti{color:#a32d2d}.menu-grid__icon--jadwal{background:#eeedfe}.menu-grid__icon--jadwal .ti{color:#3c3489}.menu-grid__icon--keuangan{background:#e8f5ff}.menu-grid__icon--keuangan .ti{color:#0b5e8e}.menu-grid__icon--kegiatan{background:#fbeaf0}.menu-grid__icon--kegiatan .ti{color:#993556}.menu-grid__icon--keluarga{background:#e1f5ee}.menu-grid__icon--keluarga .ti{color:#085041}.menu-grid__icon--lainnya{background:#f1efe8}.menu-grid__icon--lainnya .ti{color:#5f5e5a}.menu-grid__label{font-size:12px;font-weight:600;text-align:center;color:var(--color-text-dark)}.info-section{margin-bottom:8px}.info-card{background:#fff;border:.5px solid var(--color-border);border-radius:var(--radius-card);padding:14px}.info-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.info-card__title{font-size:12.5px;font-weight:700;color:var(--color-text-dark)}.info-card__link{font-size:10.5px;font-weight:600;color:var(--color-blue);cursor:pointer}.info-card__empty{font-size:12px;color:var(--color-text-muted)}.info-card__row{display:flex;gap:8px;cursor:pointer}.info-card__row--border{padding-bottom:9px;margin-bottom:9px;border-bottom:.5px solid var(--color-border)}.info-card__row-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.info-card__row-icon .ti{font-size:14px}.info-card__row-icon--green{background:#eaf3de}.info-card__row-icon--green .ti{color:#3b6d11}.info-card__row-icon--purple{background:#eeedfe}.info-card__row-icon--purple .ti{color:#3c3489}.info-card__row-body{flex:1;min-width:0}.info-card__row-title{margin:0;font-size:11.5px;font-weight:600;color:var(--color-text-dark);line-height:1.3}.info-card__row-time{margin:1px 0 0;font-size:10px;font-weight:500;color:var(--color-text-muted)}.dues-page{padding:1rem;max-width:600px;margin:0 auto}.dues-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 1rem}.dues-arrears-banner{display:flex;align-items:flex-start;gap:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem;padding:.875rem 1rem;margin-bottom:1rem}.dues-arrears-banner__icon{font-size:1.25rem;flex-shrink:0}.dues-arrears-banner__content strong{display:block;font-size:.9rem;color:#991b1b;margin-bottom:.25rem}.dues-arrears-banner__content p{font-size:.8rem;color:#7f1d1d;margin:0;line-height:1.4}.dues-tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:1rem}.dues-tabs__tab{flex:1;padding:.75rem .5rem;border:none;background:none;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.dues-tabs__tab--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.dues-tabs__tab:hover:not(.dues-tabs__tab--active){color:#374151}.dues-section{padding:0}.dues-empty{text-align:center;padding:2.5rem 1rem;color:#6b7280}.dues-empty__icon{display:block;font-size:2rem;margin-bottom:.5rem}.dues-empty p,.dues-empty span{font-size:.875rem}.dues-select-all{margin-bottom:.75rem}.dues-select-all__label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#374151;cursor:pointer}.dues-select-all__label input[type=checkbox]{width:1rem;height:1rem;accent-color:#2563eb}.dues-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.dues-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;transition:border-color .15s,box-shadow .15s}.dues-card--selected{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 1px #2563eb}.dues-card__label{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;cursor:pointer}.dues-card__checkbox{width:1.125rem;height:1.125rem;accent-color:#2563eb;flex-shrink:0}.dues-card__info{flex:1;display:flex;justify-content:space-between;align-items:center}.dues-card__period{font-size:.9rem;font-weight:500;color:#1a1a2e}.dues-card__amount{font-size:.9rem;font-weight:600;color:#374151}.dues-pay-bar{position:sticky;bottom:4.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.875rem 1rem;margin-top:1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -2px 12px #00000014}.dues-pay-bar__info{display:flex;flex-direction:column;gap:.125rem}.dues-pay-bar__count{font-size:.75rem;color:#6b7280}.dues-pay-bar__total{font-size:1rem;font-weight:700;color:#1a1a2e}.dues-btn{border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.dues-btn--primary{background:#2563eb;color:#fff;padding:.625rem 1.25rem}.dues-btn--primary:hover:not(:disabled){background:#1d4ed8}.dues-btn--primary:disabled{background:#93c5fd;cursor:not-allowed}.dues-btn--secondary{background:#f3f4f6;color:#374151;padding:.625rem 1.25rem;width:100%}.dues-btn--secondary:hover{background:#e5e7eb}.dues-receipt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.dues-receipt-card{background:#fff;border-radius:1rem;padding:1.5rem;max-width:360px;width:100%;box-shadow:0 10px 40px #00000026}.dues-receipt-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.dues-receipt-card__header h3{font-size:1.1rem;font-weight:700;color:#065f46;margin:0}.dues-receipt-card__icon{font-size:1.5rem}.dues-receipt-card__details{display:grid;grid-template-columns:auto 1fr;gap:.5rem .75rem;margin-bottom:1.25rem}.dues-receipt-card__details dt{font-size:.8rem;color:#6b7280}.dues-receipt-card__details dd{font-size:.85rem;font-weight:500;color:#1a1a2e;margin:0}.dues-receipt-card__amount{font-weight:700!important;color:#065f46!important}.dues-history{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.dues-history__item{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.875rem 1rem}.dues-history__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.dues-history__ref{font-size:.8rem;font-weight:600;color:#2563eb}.dues-history__amount{font-size:.9rem;font-weight:700;color:#065f46}.dues-history__body{margin-bottom:.375rem}.dues-history__periods{font-size:.8rem;color:#374151}.dues-history__footer{display:flex;justify-content:space-between;align-items:center}.dues-history__method{font-size:.75rem;color:#6b7280;background:#f3f4f6;padding:.15rem .5rem;border-radius:.25rem}.dues-history__date{font-size:.75rem;color:#9ca3af;margin-top:.375rem}.dues-history__period{font-size:.9rem;font-weight:500;color:#1a1a2e}.dues-history__item--pending{border-color:#fcd34d;background:#fffbeb}.dues-history__item{cursor:pointer;transition:border-color .15s,box-shadow .15s}.dues-history__item:hover{border-color:#93c5fd;box-shadow:0 1px 4px #2563eb1a}.dues-history__item--expanded{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.dues-history__detail{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.dues-history__detail-list{display:grid;grid-template-columns:auto 1fr;gap:.375rem .75rem;margin:0 0 .75rem}.dues-history__detail-list dt{font-size:.75rem;color:#6b7280}.dues-history__detail-list dd{font-size:.8rem;font-weight:500;color:#1a1a2e;margin:0}.dues-history__proof{margin-top:.5rem}.dues-history__proof-label{font-size:.75rem;font-weight:600;color:#374151;margin:0 0 .5rem}.dues-history__proof-image{max-width:100%;max-height:240px;width:auto;height:auto;object-fit:contain;border-radius:.5rem;border:1px solid #e5e7eb}.dues-history__no-proof{font-size:.75rem;color:#9ca3af;margin:.5rem 0 0;font-style:italic}.dues-badge{display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:.375rem;white-space:nowrap}.dues-badge--pending{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.dues-badge--rejected{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.dues-badge--paid{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.dues-card--pending{border-color:#d1d5db;background:#f3f4f6;opacity:.75}.dues-card--pending .dues-card__checkbox{opacity:.3;pointer-events:none}.dues-card--pending .dues-card__period,.dues-card--pending .dues-card__amount{color:#6b7280}.dues-card--rejected{border-color:#fecaca;background:#fef2f2}.dues-card--rejected .dues-card__checkbox{opacity:.5}.dues-card__top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.dues-card__rejection-reason{font-size:.75rem;color:#991b1b;margin:.375rem 0 0;line-height:1.4;font-style:italic}.dues-card__actions{padding:0 1rem .875rem;display:flex;justify-content:flex-end}.dues-btn--warning{background:#f59e0b;color:#fff;padding:.5rem 1rem;font-size:.8rem}.dues-btn--warning:hover:not(:disabled){background:#d97706}.dues-payment-unavailable{display:flex;align-items:flex-start;gap:.5rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem 1rem;margin-top:.75rem}.dues-payment-unavailable__icon{font-size:1rem;flex-shrink:0}.dues-payment-unavailable p{font-size:.8rem;color:#6b7280;margin:0;line-height:1.4}.dues-history__proof-btn{display:block;background:none;border:none;padding:0;cursor:zoom-in;width:100%;text-align:left}.dues-history__proof-btn:hover .dues-history__proof-image{opacity:.85}.dues-history__proof-hint{display:block;font-size:.7rem;color:#6b7280;margin-top:.25rem}.dues-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e0;display:flex;align-items:center;justify-content:center;padding:1rem;cursor:zoom-out;animation:dues-lightbox-fade .2s ease}@keyframes dues-lightbox-fade{0%{opacity:0}to{opacity:1}}.dues-lightbox__image{max-width:100%;max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:.5rem;cursor:default;box-shadow:0 8px 40px #00000080}.dues-lightbox__close{position:fixed;top:1rem;right:1rem;background:#ffffff26;border:none;color:#fff;font-size:1.75rem;line-height:1;width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.dues-lightbox__close:hover{background:#ffffff4d}.letters-page{padding:1rem;max-width:600px;margin:0 auto}.letters-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 1rem}.letters-success{display:flex;align-items:center;gap:.5rem;background:#d1fae5;border:1px solid #a7f3d0;border-radius:.75rem;padding:.75rem 1rem;margin-bottom:1rem}.letters-success__icon{font-size:1.1rem;flex-shrink:0}.letters-success p{flex:1;font-size:.85rem;color:#065f46;margin:0}.letters-success__close{background:none;border:none;color:#065f46;font-size:1rem;cursor:pointer;padding:.25rem;line-height:1}.letters-tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:1rem}.letters-tabs__tab{flex:1;padding:.75rem .5rem;border:none;background:none;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.letters-tabs__tab--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.letters-tabs__tab:hover:not(.letters-tabs__tab--active){color:#374151}.letters-section-title{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0 0 .75rem}.letters-types{margin-bottom:1.5rem}.letters-types__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.letters-types__item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem 1rem}.letters-types__name{display:block;font-size:.9rem;color:#1a1a2e;margin-bottom:.25rem}.letters-types__desc{font-size:.8rem;color:#6b7280;margin:0;line-height:1.4}.letters-form-section{margin-top:1.5rem}.letters-form{display:flex;flex-direction:column;gap:1rem}.letters-form__field{display:flex;flex-direction:column;gap:.25rem}.letters-form__label{font-size:.85rem;font-weight:500;color:#374151}.letters-form__required{color:#dc2626}.letters-form__select,.letters-form__textarea{width:100%;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;color:#1a1a2e;background:#fff;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.letters-form__select:focus,.letters-form__textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.letters-form__input--error{border-color:#dc2626!important;box-shadow:0 0 0 2px #dc26261a!important}.letters-form__textarea{resize:vertical;min-height:80px;font-family:inherit}.letters-form__char-count{font-size:.75rem;color:#9ca3af;text-align:right}.letters-form__error{font-size:.8rem;color:#dc2626;display:flex;align-items:center;gap:.25rem}.letters-form__error:before{content:"⚠";font-size:.75rem}.letters-btn{border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.letters-btn--primary{background:#2563eb;color:#fff;padding:.75rem 1.25rem;width:100%}.letters-btn--primary:hover:not(:disabled){background:#1d4ed8}.letters-btn--primary:disabled{background:#93c5fd;cursor:not-allowed}.letters-btn--small{padding:.4rem .75rem;font-size:.8rem}.letters-btn--success{background:#10b981;color:#fff}.letters-btn--success:hover{background:#059669}.letters-btn--danger{background:#ef4444;color:#fff}.letters-btn--danger:hover{background:#dc2626}.letters-empty{text-align:center;padding:2.5rem 1rem;color:#6b7280}.letters-empty__icon{display:block;font-size:2rem;margin-bottom:.5rem}.letters-empty p{font-size:.875rem;margin:0}.letters-history__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.letters-history__item{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.875rem 1rem}.letters-history__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.letters-history__no{font-size:.8rem;font-weight:600;color:#2563eb}.letters-status{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.02em}.letters-status--pending{background:#fef3c7;color:#92400e}.letters-status--approved{background:#d1fae5;color:#065f46}.letters-status--rejected{background:#fee2e2;color:#991b1b}.letters-status--cancelled{background:#f3f4f6;color:#6b7280}.letters-history__details{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.letters-history__type{font-size:.85rem;font-weight:500;color:#1a1a2e}.letters-history__date{font-size:.75rem;color:#9ca3af}.letters-history__purpose{font-size:.8rem;color:#6b7280;margin:.25rem 0 .5rem;line-height:1.4}.letters-history__reason{font-size:.8rem;color:#991b1b;background:#fef2f2;padding:.5rem .75rem;border-radius:.375rem;margin:.25rem 0 .5rem;line-height:1.4}.letters-history__pickup{font-size:.8rem;color:#065f46;background:#ecfdf5;padding:.5rem .75rem;border-radius:.375rem;margin:.25rem 0 .5rem;line-height:1.4}.letters-history__pickup p{margin:0}.letters-history__approval-note{margin-top:.375rem!important;padding-top:.375rem;border-top:1px solid #bbf7d0;white-space:pre-line}.letters-history__actions{display:flex;gap:.5rem;margin-top:.5rem}.announcements-page__title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 16px}.announcements-page__back{display:inline-flex;align-items:center;gap:4px;padding:8px 0;margin-bottom:12px;background:none;border:none;color:#2563eb;font-size:.875rem;font-weight:500;cursor:pointer}.announcements-page__back:hover{text-decoration:underline}.announcements-page__loading,.announcements-page__error,.announcements-page__empty{text-align:center;padding:32px 16px;color:#6b7280;font-size:.875rem}.announcements-page__error{color:#dc2626}.announcements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.announcements-list__item{border-radius:12px;background:#fff;border:1px solid #e5e7eb;overflow:hidden;transition:box-shadow .15s}.announcements-list__item:hover{box-shadow:0 2px 8px #0000000f}.announcements-list__button{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:14px 16px;background:none;border:none;text-align:left;cursor:pointer;gap:4px}.announcements-list__category{display:inline-block;font-size:.6875rem;font-weight:600;text-transform:uppercase;color:#2563eb;background:#eff6ff;padding:2px 8px;border-radius:4px;letter-spacing:.02em}.announcements-list__title{font-size:.9375rem;font-weight:600;color:#111827;margin:4px 0 0;line-height:1.35}.announcements-list__date{font-size:.75rem;color:#6b7280}.announcements-page__pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding:8px 0}.announcements-page__page-btn{padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.announcements-page__page-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.announcements-page__page-btn:disabled{opacity:.4;cursor:not-allowed}.announcements-page__page-info{font-size:.8125rem;color:#6b7280;font-weight:500}.announcement-detail{padding:4px 0}.announcement-detail__category{display:inline-block;font-size:.6875rem;font-weight:600;text-transform:uppercase;color:#2563eb;background:#eff6ff;padding:3px 10px;border-radius:4px;letter-spacing:.02em}.announcement-detail__title{font-size:1.25rem;font-weight:700;color:#111827;margin:10px 0 4px;line-height:1.3}.announcement-detail__date{display:block;font-size:.8125rem;color:#6b7280;margin-bottom:16px}.announcement-detail__event-time{font-size:.875rem;color:#374151;background:#fefce8;border:1px solid #fde68a;border-radius:8px;padding:10px 12px;margin-bottom:16px}.announcement-detail__description{font-size:.9375rem;color:#374151;line-height:1.6;white-space:pre-wrap;margin-bottom:24px}.announcement-detail__attachments{border-top:1px solid #e5e7eb;padding-top:16px}.announcement-detail__attachments-title{font-size:.875rem;font-weight:600;color:#111827;margin:0 0 10px}.announcement-detail__attachments-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.announcement-detail__attachment-item{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.announcement-detail__attachment-link{display:flex;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;color:#374151;transition:background .15s}.announcement-detail__attachment-link:hover{background:#f9fafb}.announcement-detail__attachment-icon{flex-shrink:0;color:#6b7280}.announcement-detail__attachment-name{flex:1;font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.announcement-detail__attachment-size{font-size:.75rem;color:#9ca3af;flex-shrink:0}.report-page{padding:0}.report-page__title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 20px}.report-form{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px 16px;margin-bottom:28px}.report-form__heading{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 16px}.report-form__success{background:#ecfdf5;border:1px solid #6ee7b7;border-radius:8px;padding:12px;font-size:.875rem;color:#065f46;margin-bottom:16px}.report-form__field{margin-bottom:16px}.report-form__label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:6px}.report-form__required{color:#dc2626}.report-form__optional{font-weight:400;color:#6b7280;font-size:.75rem}.report-form__select{width:100%;padding:10px 12px;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;transition:border-color .15s}.report-form__select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.report-form__select--error{border-color:#dc2626}.report-form__input{width:100%;padding:10px 12px;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;transition:border-color .15s;box-sizing:border-box}.report-form__input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.report-form__input--error{border-color:#dc2626}.report-form__textarea{width:100%;padding:10px 12px;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;resize:vertical;min-height:100px;font-family:inherit;transition:border-color .15s;box-sizing:border-box}.report-form__textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.report-form__textarea--error{border-color:#dc2626}.report-form__field-footer{display:flex;justify-content:flex-end;margin-top:4px}.report-form__hint{font-size:.75rem;color:#9ca3af}.report-form__error{font-size:.75rem;color:#dc2626;margin:4px 0 0}.report-form__file-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed #d1d5db;border-radius:8px;background:#f9fafb;color:#374151;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.report-form__file-btn:hover{background:#f3f4f6;border-color:#9ca3af}.report-form__file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.report-form__attachments-list{list-style:none;padding:0;margin:10px 0 0;display:flex;flex-direction:column;gap:8px}.report-form__attachment-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;position:relative}.report-form__attachment-item--error{border-color:#fca5a5;background:#fef2f2}.report-form__attachment-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.report-form__attachment-name{font-size:.8125rem;font-weight:500;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-form__attachment-size{font-size:.6875rem;color:#9ca3af}.report-form__attachment-error{width:100%;font-size:.75rem;color:#dc2626;margin:0}.report-form__attachment-remove{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:#e5e7eb;border-radius:50%;color:#6b7280;font-size:.75rem;cursor:pointer;transition:background .15s,color .15s}.report-form__attachment-remove:hover{background:#dc2626;color:#fff}.report-form__submit{width:100%;padding:12px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}.report-form__submit:hover:not(:disabled){background:#1d4ed8}.report-form__submit:disabled{opacity:.6;cursor:not-allowed}.report-history{margin-top:8px}.report-history__heading{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 14px}.report-history__empty{text-align:center;color:#6b7280;font-size:.875rem;padding:24px 16px}.report-history__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.report-history__item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;transition:box-shadow .15s}.report-history__item:hover{box-shadow:0 2px 8px #0000000d}.report-history__item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.report-history__category{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#7c3aed;background:#f5f3ff;padding:2px 8px;border-radius:4px;letter-spacing:.02em}.report-history__description{font-size:.8125rem;color:#374151;margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.report-history__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.report-history__location{font-size:.75rem;color:#6b7280}.report-history__date{font-size:.75rem;color:#9ca3af}.report-status{font-size:.6875rem;font-weight:600;padding:3px 8px;border-radius:12px;white-space:nowrap}.report-status--diterima{background:#fef3c7;color:#92400e}.report-status--ditindaklanjuti{background:#dbeafe;color:#1e40af}.report-status--selesai{background:#d1fae5;color:#065f46}.donations-page{padding:1rem;max-width:600px;margin:0 auto}.donations-page__title{font-size:1.25rem;font-weight:700;margin-bottom:1rem;color:#1a1a2e}.donations-page__loading,.donations-page__error,.donations-page__empty{text-align:center;padding:2rem 1rem;color:#666}.donations-page__error{color:#dc2626}.donations-page__back-btn{background:none;border:none;color:#2563eb;font-size:.9rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem}.donations-page__list{display:flex;flex-direction:column;gap:.75rem}.donation-card{display:block;width:100%;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;cursor:pointer;transition:box-shadow .15s;position:relative}.donation-card:hover{box-shadow:0 2px 8px #00000014}.donation-card__title{font-size:1rem;font-weight:600;margin:0 0 .25rem;color:#1a1a2e}.donation-card__desc{font-size:.85rem;color:#6b7280;margin:0 0 .75rem}.donation-card__progress{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.donation-card__progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.donation-card__progress-fill{height:100%;background:#10b981;border-radius:4px;transition:width .3s}.donation-card__pct{font-size:.8rem;font-weight:600;color:#10b981;min-width:36px;text-align:right}.donation-card__amounts{display:flex;justify-content:space-between;font-size:.8rem;color:#6b7280}.donation-card__badge{position:absolute;top:.75rem;right:.75rem;font-size:.7rem;padding:.2rem .5rem;border-radius:.25rem;font-weight:600}.donation-card__badge--completed{background:#dbeafe;color:#1d4ed8}.donations-page__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.donations-page__page-btn{background:#2563eb;color:#fff;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.85rem;cursor:pointer}.donations-page__page-btn:disabled{background:#d1d5db;cursor:not-allowed}.donations-page__page-info{font-size:.85rem;color:#6b7280}.donation-detail__title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:#1a1a2e}.donation-detail__desc{font-size:.9rem;color:#374151;margin-bottom:1rem;line-height:1.5}.donation-detail__stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.donation-detail__stat{background:#f9fafb;padding:.75rem;border-radius:.5rem}.donation-detail__stat-label{display:block;font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.donation-detail__stat-value{display:block;font-size:.9rem;font-weight:600;color:#1a1a2e}.donation-detail__progress-bar{height:10px;background:#e5e7eb;border-radius:5px;overflow:hidden;margin-bottom:1rem}.donation-detail__progress-fill{height:100%;background:#10b981;border-radius:5px;transition:width .3s}.donation-detail__closed-badge{background:#fef3c7;color:#92400e;padding:.75rem;border-radius:.5rem;font-size:.85rem;text-align:center;margin-bottom:1rem}.donation-form{background:#f9fafb;padding:1rem;border-radius:.75rem;margin-bottom:1.5rem}.donation-form__title{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:#1a1a2e}.donation-form__label{display:block;font-size:.85rem;color:#374151;margin-bottom:.25rem}.donation-form__input{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;margin-bottom:.75rem;box-sizing:border-box}.donation-form__input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.donation-form__checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#374151;margin-bottom:1rem;cursor:pointer}.donation-form__submit{width:100%;background:#10b981;color:#fff;border:none;border-radius:.5rem;padding:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.donation-form__submit:hover:not(:disabled){background:#059669}.donation-form__submit:disabled{background:#9ca3af;cursor:not-allowed}.donation-form__success{margin-top:.75rem;padding:.75rem;background:#d1fae5;color:#065f46;border-radius:.5rem;font-size:.85rem}.donation-form__error{margin-top:.75rem;padding:.75rem;background:#fee2e2;color:#991b1b;border-radius:.5rem;font-size:.85rem}.donation-donors{margin-top:1rem}.donation-donors__title{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:#1a1a2e}.donation-donors__list{list-style:none;padding:0;margin:0}.donation-donors__item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid #f3f4f6}.donation-donors__item:last-child{border-bottom:none}.donation-donors__name{font-size:.85rem;color:#374151}.donation-donors__amount{font-size:.85rem;font-weight:600;color:#10b981}.donation-donors__empty{font-size:.85rem;color:#9ca3af;text-align:center;padding:1rem 0}.activities-page{padding:1rem;max-width:600px;margin:0 auto}.activities-page__title{font-size:1.25rem;font-weight:700;margin-bottom:1rem;color:#1a1a2e}.activities-page__loading,.activities-page__error,.activities-page__empty{text-align:center;padding:1.5rem 1rem;color:#666;font-size:.9rem}.activities-page__error{color:#dc2626}.activities-page__back-btn{background:none;border:none;color:#2563eb;font-size:.9rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem}.activities-section{margin-bottom:1.5rem}.activities-section__heading{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.activities-section__list{display:flex;flex-direction:column;gap:.75rem}.activity-card{display:block;width:100%;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;cursor:pointer;transition:box-shadow .15s}.activity-card:hover{box-shadow:0 2px 8px #00000014}.activity-card--past{opacity:.8;background:#f9fafb}.activity-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.activity-card__title{font-size:.95rem;font-weight:600;margin:0 0 .5rem;color:#1a1a2e}.activity-card__badge-selesai{font-size:.7rem;padding:.2rem .5rem;border-radius:.25rem;font-weight:600;background:#dbeafe;color:#1d4ed8;white-space:nowrap;flex-shrink:0}.activity-card__meta{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:#6b7280}.activity-card__date,.activity-card__time,.activity-card__location{display:inline-flex;align-items:center;gap:.25rem}.activities-page__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.activities-page__page-btn{background:#2563eb;color:#fff;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.85rem;cursor:pointer}.activities-page__page-btn:disabled{background:#d1d5db;cursor:not-allowed}.activities-page__page-info{font-size:.85rem;color:#6b7280}.activity-detail{background:#fff;border-radius:.75rem;padding:1rem;border:1px solid #e5e7eb}.activity-detail__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.activity-detail__title{font-size:1.2rem;font-weight:700;color:#1a1a2e;margin:0}.activity-detail__badge-selesai{font-size:.75rem;padding:.3rem .6rem;border-radius:.3rem;font-weight:600;background:#dbeafe;color:#1d4ed8;white-space:nowrap;flex-shrink:0}.activity-detail__info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#f9fafb;border-radius:.5rem}.activity-detail__info-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#374151}.activity-detail__info-icon{font-size:1rem;width:1.5rem;text-align:center;flex-shrink:0}.activity-detail__description{margin-bottom:1.25rem}.activity-detail__section-title{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0 0 .5rem}.activity-detail__description p{font-size:.9rem;color:#374151;line-height:1.6;margin:0}.activity-detail__actions{margin-bottom:1.25rem}.activity-detail__btn{width:100%;padding:.75rem;border:none;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.activity-detail__btn--join{background:#10b981;color:#fff}.activity-detail__btn--join:hover{background:#059669}.activity-detail__btn--leave{background:#ef4444;color:#fff}.activity-detail__btn--leave:hover{background:#dc2626}.activity-detail__btn--disabled{background:#d1d5db;color:#6b7280;cursor:not-allowed}.activity-detail__error{margin-top:.5rem;font-size:.85rem;color:#dc2626}.activity-detail__participants{margin-top:1rem}.activity-detail__participants-list{list-style:none;padding:0;margin:0}.activity-detail__participant{padding:.5rem 0;border-bottom:1px solid #f3f4f6;font-size:.9rem;color:#374151}.activity-detail__participant:last-child{border-bottom:none}.activity-detail__no-participants{font-size:.85rem;color:#9ca3af;text-align:center;padding:1rem 0}.family-page{padding:16px;display:flex;flex-direction:column;gap:16px}.family-page__header{display:flex;justify-content:space-between;align-items:center}.family-page__title{font-size:20px;font-weight:700;margin:0;color:#222}.family-page__add-btn{padding:8px 14px;border:none;border-radius:8px;background:#1e88e5;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.family-page__back-btn{background:none;border:none;color:#1e88e5;font-size:14px;cursor:pointer;padding:0;align-self:flex-start}.family-page__loading,.family-page__error,.family-page__empty{font-size:14px;color:#666;text-align:center;padding:24px 0}.family-page__error{color:#c62828}.family-page__list{display:flex;flex-direction:column;gap:12px}.family-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:10px}.family-card--incomplete{border-left:3px solid #fb8c00}.family-card__header{display:flex;justify-content:space-between;align-items:baseline}.family-card__name-row{display:flex;gap:6px;align-items:center}.family-card__name{font-size:15px;font-weight:600;margin:0}.family-card__warning-icon{font-size:14px}.family-card__relationship{font-size:12px;color:#666;background:#f5f5f5;padding:2px 8px;border-radius:4px}.family-card__info{display:grid;grid-template-columns:1fr 1fr;gap:8px}.family-card__info-item{display:flex;flex-direction:column;gap:2px}.family-card__info-label{font-size:11px;color:#888}.family-card__info-value{font-size:13px;color:#333}.family-card__status{font-size:12px;padding:4px 8px;border-radius:4px;align-self:flex-start}.family-card__status--pending_verification{background:#fff3e0;color:#e65100}.family-card__status--pending_deletion{background:#fce4ec;color:#b71c1c}.family-card__status--rejected{background:#ffebee;color:#c62828}.family-card__actions{display:flex;gap:8px}.family-card__edit-btn,.family-card__delete-btn{padding:6px 12px;border:1px solid #ddd;border-radius:6px;font-size:12px;cursor:pointer;background:#fff}.family-card__edit-btn{color:#1e88e5;border-color:#1e88e5}.family-card__delete-btn{color:#c62828;border-color:#c62828}.family-card__delete-btn:disabled{opacity:.5;cursor:not-allowed}.family-form{display:flex;flex-direction:column;gap:16px}.family-form__field{display:flex;flex-direction:column;gap:4px}.family-form__label{font-size:13px;font-weight:600;color:#333}.family-form__input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px}.family-form__input--error{border-color:#c62828}.family-form__error{font-size:12px;color:#c62828}.family-form__server-error{font-size:13px;color:#c62828;background:#ffebee;padding:10px 12px;border-radius:8px}.family-form__submit{padding:12px;border:none;border-radius:8px;background:#1e88e5;color:#fff;font-size:15px;font-weight:600;cursor:pointer}.family-form__submit:disabled{opacity:.6;cursor:not-allowed}.payment-process-page{padding:1rem;max-width:600px;margin:0 auto}.payment-process-page__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.payment-process-page__back{border:none;background:none;font-size:1.25rem;cursor:pointer;padding:.25rem;color:#374151;border-radius:.375rem;transition:background .15s}.payment-process-page__back:hover{background:#f3f4f6}.payment-process-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0}.payment-process-page__loading{text-align:center;padding:2rem 1rem;color:#6b7280;font-size:.875rem}.payment-process-page__error{text-align:center;padding:1rem;color:#dc2626;font-size:.875rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem}.payment-process-page__unavailable{display:flex;align-items:flex-start;gap:.75rem;background:#fffbeb;border:1px solid #fde68a;border-radius:.75rem;padding:1.25rem 1rem;margin-top:1rem}.payment-process-page__unavailable-icon{font-size:1.25rem;flex-shrink:0}.payment-process-page__unavailable p{font-size:.875rem;color:#92400e;margin:0;line-height:1.5}.payment-process-page__total{display:flex;justify-content:space-between;align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.75rem;padding:1rem;margin-bottom:1.25rem}.payment-process-page__total-label{font-size:.875rem;color:#374151;font-weight:500}.payment-process-page__total-amount{font-size:1.125rem;font-weight:700;color:#1d4ed8}.payment-process-page__methods{border:none;padding:0;margin:0 0 1.25rem}.payment-process-page__methods-legend{font-size:.9rem;font-weight:600;color:#1a1a2e;margin-bottom:.75rem}.payment-process-page__method-option{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:1px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;margin-bottom:.5rem}.payment-process-page__method-option:hover{border-color:#93c5fd}.payment-process-page__method-option--selected{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 1px #2563eb}.payment-process-page__method-radio{width:1.125rem;height:1.125rem;accent-color:#2563eb;flex-shrink:0}.payment-process-page__method-label{font-size:.9rem;font-weight:500;color:#1a1a2e}.payment-process-page__section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;margin-bottom:1rem;transition:border-color .2s,background .2s,box-shadow .2s}.payment-process-page__section--highlighted{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 1px #2563eb}.payment-process-page__section-title{font-size:.9rem;font-weight:600;color:#1a1a2e;margin:0 0 .75rem}.payment-process-page__bank-info{display:grid;grid-template-columns:auto 1fr;gap:.5rem .75rem;margin:0}.payment-process-page__bank-info dt{font-size:.8rem;color:#6b7280}.payment-process-page__bank-info dd{font-size:.875rem;font-weight:500;color:#1a1a2e;margin:0}.payment-process-page__account-number{font-family:Courier New,Courier,monospace;letter-spacing:.05em}.payment-process-page__qris-wrapper{display:flex;justify-content:center;padding:.5rem 0}.payment-process-page__qris-image{max-width:240px;width:100%;height:auto;border-radius:.5rem;border:1px solid #e5e7eb}.payment-process-page__qris-unavailable{font-size:.8rem;color:#6b7280;text-align:center;margin:0;padding:1rem 0}.payment-process-page__actions{position:sticky;bottom:4.5rem;padding:1rem 0;margin-top:.5rem}.payment-process-page__btn{border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;width:100%;padding:.875rem 1.25rem}.payment-process-page__btn--primary{background:#2563eb;color:#fff}.payment-process-page__btn--primary:hover:not(:disabled){background:#1d4ed8}.payment-process-page__btn--primary:disabled{background:#93c5fd;cursor:not-allowed}.payment-confirm-page{padding:1rem;max-width:600px;margin:0 auto}.payment-confirm-page__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.payment-confirm-page__back{border:none;background:none;font-size:1.25rem;cursor:pointer;padding:.25rem;color:#374151;border-radius:.375rem;transition:background .15s}.payment-confirm-page__back:hover{background:#f3f4f6}.payment-confirm-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0}.payment-confirm-page__summary{background:#eff6ff;border:1px solid #bfdbfe;border-radius:.75rem;padding:1rem;margin-bottom:1.25rem}.payment-confirm-page__summary-row{display:flex;justify-content:space-between;align-items:center}.payment-confirm-page__summary-row+.payment-confirm-page__summary-row{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #dbeafe}.payment-confirm-page__summary-label{font-size:.875rem;color:#374151;font-weight:500}.payment-confirm-page__summary-value{font-size:.9rem;font-weight:700;color:#1d4ed8}.payment-confirm-page__upload-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;margin-bottom:1rem}.payment-confirm-page__section-title{font-size:.9rem;font-weight:600;color:#1a1a2e;margin:0 0 .25rem}.payment-confirm-page__section-hint{font-size:.8rem;color:#6b7280;margin:0 0 1rem}.payment-confirm-page__file-input{display:none}.payment-confirm-page__upload-area{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;padding:2rem 1rem;border:2px dashed #d1d5db;border-radius:.75rem;background:#f9fafb;cursor:pointer;transition:border-color .15s,background .15s}.payment-confirm-page__upload-area:hover{border-color:#93c5fd;background:#eff6ff}.payment-confirm-page__upload-icon{font-size:2rem}.payment-confirm-page__upload-text{font-size:.875rem;font-weight:500;color:#374151}.payment-confirm-page__upload-hint{font-size:.75rem;color:#6b7280;text-align:center}.payment-confirm-page__preview{display:flex;flex-direction:column;align-items:center;gap:.75rem}.payment-confirm-page__preview-image{max-width:100%;max-height:280px;width:auto;height:auto;object-fit:contain;border-radius:.5rem;border:1px solid #e5e7eb}.payment-confirm-page__preview-info{display:flex;flex-direction:column;align-items:center;gap:.125rem}.payment-confirm-page__preview-name{font-size:.8rem;color:#374151;font-weight:500;word-break:break-all;text-align:center}.payment-confirm-page__preview-size{font-size:.75rem;color:#6b7280}.payment-confirm-page__preview-actions{display:flex;gap:.5rem}.payment-confirm-page__file-error{margin:.75rem 0 0;padding:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.8rem;line-height:1.4}.payment-confirm-page__progress{margin-bottom:1rem}.payment-confirm-page__progress-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-bottom:.375rem}.payment-confirm-page__progress-fill{height:100%;background:#2563eb;border-radius:3px;transition:width .2s ease}.payment-confirm-page__progress-text{font-size:.75rem;color:#6b7280}.payment-confirm-page__actions{position:sticky;bottom:4.5rem;padding:1rem 0;margin-top:.5rem}.payment-confirm-page__btn{border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;padding:.75rem 1.25rem}.payment-confirm-page__btn--primary{background:#2563eb;color:#fff;width:100%;padding:.875rem 1.25rem}.payment-confirm-page__btn--primary:hover:not(:disabled){background:#1d4ed8}.payment-confirm-page__btn--primary:disabled{background:#93c5fd;cursor:not-allowed}.payment-confirm-page__btn--outline{background:transparent;color:#2563eb;border:1px solid #2563eb}.payment-confirm-page__btn--outline:hover:not(:disabled){background:#eff6ff}.payment-confirm-page__btn--outline:disabled{opacity:.5;cursor:not-allowed}.payment-confirm-page__btn--text{background:transparent;color:#6b7280;padding:.75rem .5rem}.payment-confirm-page__btn--text:hover:not(:disabled){color:#dc2626}.payment-confirm-page__btn--text:disabled{opacity:.5;cursor:not-allowed}.payment-confirm-page__toast{position:fixed;bottom:80px;left:1rem;right:1rem;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:.75rem;z-index:1000;animation:toast-slide-up .3s ease}.payment-confirm-page__toast--success{background:#065f46;color:#fff}.payment-confirm-page__toast--error{background:#991b1b;color:#fff}.payment-confirm-page__toast-message{flex:1;margin:0;font-size:.8rem;line-height:1.4}.payment-confirm-page__toast-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.payment-confirm-page__toast-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s}.payment-confirm-page__toast-btn:hover{background:#ffffff4d}.payment-confirm-page__toast-close{background:none;border:none;color:#fffc;font-size:1.25rem;cursor:pointer;padding:.125rem .375rem;border-radius:.25rem;transition:background .15s}.payment-confirm-page__toast-close:hover{background:#ffffff1a;color:#fff}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@media(min-width:429px){.payment-confirm-page__toast{left:50%;right:auto;transform:translate(-50%);max-width:400px;width:calc(100% - 2rem)}}.notifications-page{padding:1rem;max-width:600px;margin:0 auto}.notifications-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 1rem}.notifications-page__loading,.notifications-page__error,.notifications-page__empty{text-align:center;padding:2rem 1rem;color:#666}.notifications-page__error{color:#dc2626}.notifications-page__list{display:flex;flex-direction:column;gap:0}.notification-item{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:.875rem 1rem;background:#fff;border:none;border-bottom:1px solid #f3f4f6;text-align:left;cursor:pointer;transition:background .15s}.notification-item:first-child{border-radius:.75rem .75rem 0 0}.notification-item:last-child{border-radius:0 0 .75rem .75rem;border-bottom:none}.notification-item:only-child{border-radius:.75rem}.notification-item:hover{background:#f9fafb}.notification-item--unread{background:#eff6ff}.notification-item--unread:hover{background:#dbeafe}.notification-item__icon{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.notification-item__content{flex:1;min-width:0}.notification-item__header{display:flex;align-items:center;gap:.5rem}.notification-item__title{font-size:.9rem;font-weight:600;color:#1a1a2e;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-item__unread-dot{width:8px;height:8px;border-radius:50%;background:#2563eb;flex-shrink:0}.notification-item__summary{font-size:.8rem;color:#6b7280;margin:.2rem 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item__time{font-size:.7rem;color:#9ca3af}.notifications-page__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:.5rem 0}.notifications-page__page-btn{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.notifications-page__page-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.notifications-page__page-btn:disabled{opacity:.4;cursor:not-allowed}.notifications-page__page-info{font-size:.8rem;color:#6b7280;font-weight:500}.account-page{padding:1rem;max-width:600px;margin:0 auto}.account-page__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 1.25rem}.account-page__notice{margin:0 0 1rem;padding:.75rem 1rem;border-radius:8px;background:#e3f2fd;color:#1565c0;font-size:.875rem}.account-page__loading{text-align:center;padding:2rem 1rem;color:#666}.account-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;margin-bottom:1rem}.account-section__title{font-size:.9rem;font-weight:600;color:#374151;margin:0 0 .75rem}.account-section__desc{font-size:.8rem;color:#6b7280;margin:0 0 .75rem}.account-profile{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.account-profile__avatar{width:48px;height:48px;border-radius:50%;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;flex-shrink:0}.account-profile__info{display:flex;flex-direction:column}.account-profile__name{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0}.account-profile__role{font-size:.75rem;color:#6b7280}.account-profile__details{display:flex;flex-direction:column;gap:.5rem}.account-profile__detail-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid #f3f4f6}.account-profile__detail-item:last-child{border-bottom:none}.account-profile__detail-label{font-size:.8rem;color:#6b7280}.account-profile__detail-value{font-size:.85rem;color:#374151;font-weight:500}.account-google{display:flex;flex-direction:column;gap:.75rem}.account-google__status{display:flex;align-items:center;gap:.5rem;font-size:.85rem;padding:.5rem .75rem;border-radius:.5rem}.account-google__status--linked{background:#d1fae5;color:#065f46}.account-google__status--unlinked{background:#f3f4f6;color:#6b7280}.account-google__icon{font-weight:700}.account-google__btn{width:100%;border:none;border-radius:.5rem;padding:.6rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.account-google__btn--link{background:#2563eb;color:#fff}.account-google__btn--link:hover:not(:disabled){background:#1d4ed8}.account-google__btn--unlink{background:#fee2e2;color:#dc2626}.account-google__btn--unlink:hover:not(:disabled){background:#fecaca}.account-google__btn:disabled{opacity:.5;cursor:not-allowed}.account-google__error{font-size:.8rem;color:#dc2626;margin:0}.account-prefs{display:flex;flex-direction:column;gap:0}.account-prefs__error{font-size:.8rem;color:#dc2626;margin:.5rem 0 0}.pref-toggle{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f3f4f6;cursor:pointer}.pref-toggle:last-child{border-bottom:none}.pref-toggle__text{display:flex;flex-direction:column}.pref-toggle__label{font-size:.85rem;font-weight:500;color:#374151}.pref-toggle__desc{font-size:.7rem;color:#9ca3af;margin-top:.125rem}.pref-toggle__switch-wrapper{position:relative;display:inline-flex;align-items:center}.pref-toggle__input{position:absolute;opacity:0;width:0;height:0}.pref-toggle__switch{display:block;width:40px;height:22px;background:#d1d5db;border-radius:11px;position:relative;transition:background .2s}.pref-toggle__switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #00000026}.pref-toggle__input:checked+.pref-toggle__switch{background:#2563eb}.pref-toggle__input:checked+.pref-toggle__switch:after{transform:translate(18px)}.pref-toggle__input:disabled+.pref-toggle__switch{opacity:.5}.account-page__logout-btn{width:100%;background:#dc2626;color:#fff;border:none;border-radius:.5rem;padding:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.account-page__logout-btn:hover:not(:disabled){background:#b91c1c}.account-page__logout-btn:disabled{background:#9ca3af;cursor:not-allowed}.finance-page{padding:4px 16px 28px}.finance-header{display:flex;flex-direction:column;gap:14px;margin-bottom:16px}.finance-header__title{margin:0;font-size:22px;color:var(--color-text-dark)}.finance-header__subtitle{margin:6px 0 0;font-size:12px;line-height:1.5;color:var(--color-text-muted)}.finance-range{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:4px;background:#fff;border:.5px solid var(--color-border);border-radius:12px}.finance-range__btn{padding:9px 10px;border-radius:9px;font-size:12px;font-weight:700;color:var(--color-text-muted)}.finance-range__btn--active{background:var(--color-green-mid);color:#fff}.finance-state{padding:32px 12px;text-align:center;color:var(--color-text-muted);font-size:13px}.finance-state--error{color:var(--color-red)}.finance-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.finance-summary-card,.finance-panel{background:#fff;border:.5px solid var(--color-border);border-radius:var(--radius-card)}.finance-summary-card{padding:14px}.finance-summary-card span{display:block;margin-bottom:7px;font-size:11px;color:var(--color-text-muted)}.finance-summary-card strong{font-size:15px;line-height:1.25;color:var(--color-text-dark);overflow-wrap:anywhere}.finance-summary-card--balance{background:linear-gradient(135deg,#04342c,#0f6e56)}.finance-summary-card--balance span,.finance-summary-card--balance strong{color:#fff}.finance-summary-card--income strong{color:var(--color-green-mid)}.finance-summary-card--expense strong{color:var(--color-red)}.finance-insights,.finance-breakdown{display:grid;gap:12px;margin-bottom:12px}.finance-panel{padding:14px}.finance-panel__title{margin:0 0 12px;font-size:14px;color:var(--color-text-dark)}.finance-chart{display:grid;gap:10px}.finance-chart__row{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:8px}.finance-chart__month,.finance-chart__net{font-size:10.5px;color:var(--color-text-muted)}.finance-chart__bars{display:grid;gap:3px}.finance-chart__bar{display:block;min-width:3px;height:7px;border-radius:999px}.finance-chart__bar--income{background:var(--color-green-mid)}.finance-chart__bar--expense{background:var(--color-orange)}.finance-kpi{display:grid;gap:9px}.finance-kpi div{display:flex;justify-content:space-between;gap:12px;padding-bottom:8px;border-bottom:.5px solid var(--color-border)}.finance-kpi div:last-child{border-bottom:0;padding-bottom:0}.finance-kpi dt{font-size:11.5px;color:var(--color-text-muted)}.finance-kpi dd{font-size:12px;font-weight:800;color:var(--color-text-dark);text-align:right}.finance-breakdown-list,.finance-transactions{list-style:none;display:grid;gap:10px}.finance-breakdown-list__top{display:flex;justify-content:space-between;gap:10px;margin-bottom:7px;font-size:12px}.finance-breakdown-list__top strong{white-space:nowrap}.finance-breakdown-list__track{height:7px;overflow:hidden;border-radius:999px;background:#edece6}.finance-breakdown-list__track span{display:block;height:100%;border-radius:inherit;background:var(--color-blue)}.finance-empty{font-size:12px;color:var(--color-text-muted)}.finance-transaction{display:grid;grid-template-columns:8px 1fr auto;gap:10px;align-items:start;padding:10px 0;border-bottom:.5px solid var(--color-border)}.finance-transaction:last-child{border-bottom:0}.finance-transaction__mark{width:8px;height:38px;border-radius:999px}.finance-transaction__mark--income{background:var(--color-green-mid)}.finance-transaction__mark--expense{background:var(--color-red)}.finance-transaction__body{min-width:0}.finance-transaction__body strong{display:block;font-size:12.5px;color:var(--color-text-dark)}.finance-transaction__body span,.finance-transaction__body p{margin-top:3px;font-size:10.5px;color:var(--color-text-muted)}.finance-transaction__amount{font-size:12px;font-weight:800;white-space:nowrap}.finance-transaction__amount--income{color:var(--color-green-mid)}.finance-transaction__amount--expense{color:var(--color-red)}.finance-pagination{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding-top:12px;border-top:.5px solid var(--color-border);font-size:11.5px;color:var(--color-text-muted)}.finance-pagination__actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.finance-pagination__actions button{padding:9px 10px;border:.5px solid var(--color-border);border-radius:10px;background:#fff;font-size:12px;font-weight:700;color:var(--color-green-dark)}.finance-pagination__actions button:disabled{cursor:not-allowed;opacity:.45;color:var(--color-text-muted)}@media(min-width:720px){.finance-header{flex-direction:row;align-items:end;justify-content:space-between}.finance-range{width:420px;grid-template-columns:repeat(3,minmax(0,1fr))}.finance-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.finance-insights,.finance-breakdown{grid-template-columns:1.2fr .8fr}.finance-pagination{flex-direction:row;align-items:center;justify-content:space-between}.finance-pagination__actions{width:240px}}.ambulance-page{padding:4px 16px 28px}.ambulance-hero,.ambulance-form,.ambulance-history,.ambulance-card{background:#fff;border:.5px solid var(--color-border);border-radius:var(--radius-card)}.ambulance-hero{padding:18px;margin-bottom:14px;background:linear-gradient(135deg,#a32d2d,#df5c5c);color:#fff}.ambulance-hero__badge{display:inline-flex;margin-bottom:10px;padding:4px 9px;border-radius:999px;background:#ffffff2e;font-size:11px;font-weight:800}.ambulance-hero h1{margin:0;font-size:22px}.ambulance-hero p{margin:8px 0 0;font-size:12px;line-height:1.55}.ambulance-form,.ambulance-history{padding:14px;margin-bottom:14px}.ambulance-form h2,.ambulance-history h2{margin:0 0 12px;font-size:15px;color:var(--color-text-dark)}.ambulance-form label{display:grid;gap:6px;margin-bottom:12px;font-size:12px;font-weight:700;color:var(--color-text-dark)}.ambulance-form input,.ambulance-form textarea,.ambulance-form select{width:100%;border:.5px solid var(--color-border);border-radius:10px;padding:10px 11px;font:inherit;font-weight:500;color:var(--color-text-dark)}.ambulance-form textarea{resize:vertical}.ambulance-form__grid{display:grid;gap:12px}.ambulance-form button{width:100%;border-radius:12px;padding:12px;background:var(--color-red);color:#fff;font-weight:800}.ambulance-form button:disabled{opacity:.7}.ambulance-alert{padding:10px 12px;margin-bottom:12px;border-radius:10px;font-size:12px}.ambulance-alert--success{background:#ecfdf5;color:#065f46}.ambulance-alert--error,.ambulance-empty--error{color:var(--color-red)}.ambulance-empty{font-size:12px;color:var(--color-text-muted)}.ambulance-list{display:grid;gap:10px}.ambulance-card{padding:12px}.ambulance-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.ambulance-card__top strong,.ambulance-card__top span{display:block}.ambulance-card__top strong{font-size:13px;color:var(--color-text-dark)}.ambulance-card__top span,.ambulance-card p{margin:3px 0;font-size:11px;line-height:1.45;color:var(--color-text-muted)}.ambulance-status{white-space:nowrap;border-radius:999px;padding:4px 8px;font-size:10px!important;font-weight:800}.ambulance-status--pending{background:#fef3c7;color:#92400e}.ambulance-status--confirmed{background:#dbeafe;color:#1d4ed8}.ambulance-status--completed{background:#dcfce7;color:#166534}.ambulance-status--cancelled{background:#f3f4f6;color:#4b5563}.ambulance-status--rejected{background:#fee2e2;color:#991b1b}.ambulance-card__admin-note{margin-top:8px!important;padding:8px;border-radius:9px;background:#eff6ff;color:#1d4ed8!important}@media(min-width:720px){.ambulance-form__grid{grid-template-columns:1fr 1fr}}.more-page{padding:4px 16px 28px}.more-page__header{margin-bottom:16px}.more-page__header h1{margin:0;font-size:22px;color:var(--color-text-dark)}.more-page__header p{margin:6px 0 0;font-size:12px;color:var(--color-text-muted)}.more-menu{display:grid;gap:10px}.more-menu__item{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:12px;padding:14px;border:.5px solid var(--color-border);border-radius:var(--radius-card);background:#fff;text-decoration:none}.more-menu__icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center}.more-menu__icon .ti{font-size:25px}.more-menu__icon--red{background:#fcebeb;color:#a32d2d}.more-menu__icon--pink{background:#fbeaf0;color:#993556}.more-menu__icon--green{background:#e1f5ee;color:#085041}.more-menu__icon--brown{background:#faeeda;color:#854f0b}.more-menu__icon--blue{background:#eaf2ff;color:#185fa5}.more-menu__body{min-width:0}.more-menu__body strong{display:block;font-size:14px;color:var(--color-text-dark)}.more-menu__body span{display:block;margin-top:3px;font-size:11px;line-height:1.35;color:var(--color-text-muted)}.more-menu__chevron{color:var(--color-text-muted)}.news-page{padding-bottom:24px}.news-page__header{margin-bottom:18px;padding:18px;border-radius:20px;color:#fff;background:linear-gradient(135deg,#1d4ed8,#7c3aed);box-shadow:0 12px 28px #1d4ed833}.news-page__eyebrow{display:inline-flex;margin-bottom:8px;padding:4px 10px;border-radius:999px;background:#ffffff2e;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.news-page__header h1{margin:0;font-size:1.5rem;line-height:1.2}.news-page__header p{margin:8px 0 0;color:#ffffffdb;font-size:.9rem;line-height:1.45}.news-page__back{margin-bottom:12px;border:0;background:none;color:#2563eb;font-weight:700;cursor:pointer}.news-page__state{padding:28px 16px;text-align:center;color:#6b7280;font-size:.9rem}.news-page__state--error{color:#dc2626}.news-list{display:flex;flex-direction:column;gap:14px}.news-card{display:grid;grid-template-columns:112px 1fr;gap:12px;width:100%;padding:10px;border:1px solid #e5e7eb;border-radius:18px;background:#fff;text-align:left;box-shadow:0 8px 20px #0f172a0d;cursor:pointer}.news-card__image{width:112px;height:98px;border-radius:14px;object-fit:cover;background:#eff6ff}.news-card__image--empty{display:grid;place-items:center;color:#2563eb;font-size:1.8rem}.news-card__body{min-width:0}.news-card__meta{display:flex;flex-wrap:wrap;gap:6px;color:#6b7280;font-size:.72rem;font-weight:600}.news-card__meta span{color:#2563eb}.news-card h2{margin:7px 0 4px;color:#111827;font-size:.98rem;line-height:1.28}.news-card p{display:-webkit-box;margin:0;overflow:hidden;color:#4b5563;font-size:.82rem;line-height:1.4;-webkit-line-clamp:2;-webkit-box-orient:vertical}.news-page__pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:18px}.news-page__pagination button{border:1px solid #d1d5db;border-radius:999px;background:#fff;padding:8px 12px;color:#374151;font-size:.82rem;font-weight:700}.news-page__pagination button:disabled{cursor:not-allowed;opacity:.45}.news-page__pagination span{color:#6b7280;font-size:.82rem;font-weight:700}.news-detail{color:#111827}.news-detail__image{width:100%;max-height:240px;margin-bottom:16px;border-radius:20px;object-fit:cover}.news-detail__category{display:inline-flex;padding:4px 10px;border-radius:999px;background:#eff6ff;color:#2563eb;font-size:.75rem;font-weight:800}.news-detail h1{margin:10px 0 6px;font-size:1.45rem;line-height:1.22}.news-detail__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;color:#6b7280;font-size:.82rem}.news-detail__content{white-space:pre-wrap;color:#374151;font-size:.95rem;line-height:1.7}
