:root{--bg:#f8f8fa;--surface:#fff;--surface-elevated:#fff;--surface-strong:#f1f1f3;--text:#101010;--muted:#6b7280;--line:#e5e7eb;--primary:#010101;--primary-dark:#010101;--primary-soft:#e9fbfb;--accent:#fe2c55;--blue:#0b8f94;--green:#0f8f5f;--amber:#a66300;--red:#d91f43;--tiktok-cyan:#25f4ee;--tiktok-red:#fe2c55;--focus-ring:0 0 0 3px #25f4ee47;--shadow:0 14px 34px #1010101a;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}h1,h2,h3,p{margin:0}#root{min-height:100svh}.app-shell{background:radial-gradient(circle at 12% 4%, #25f4ee2e, transparent 260px), radial-gradient(circle at 92% 0%, #fe2c5524, transparent 280px), var(--bg);min-height:100svh;display:flex}.sidebar{display:none}.main-panel{width:100%;min-width:0}.topbar{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f8f8faeb;border-bottom:1px solid #e5e7ebdb;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px 12px;display:flex;position:sticky;top:0}.topbar__title{gap:3px;min-width:0;display:grid}.topbar h1{font-size:22px;line-height:1.15}.eyebrow{color:var(--primary);text-transform:uppercase;font-size:12px;font-weight:750;line-height:1.2}.content{width:min(1120px,100%);margin:0 auto;padding:18px 16px 108px}.stack{gap:16px;display:grid}.section-header,.panel-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.section-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.section-header h2,.panel h2{color:var(--text);font-size:20px;line-height:1.2}.panel h3,.resident-card h2{color:var(--text);font-size:15px;line-height:1.25}.section-header p,.panel p,.resident-card p,.letter-row p,.bill-row p{color:var(--muted);font-size:13px;line-height:1.4}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.metric-card,.panel,.resident-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.metric-card{align-content:center;gap:8px;min-height:86px;padding:14px;display:grid}.metric-card span{color:var(--muted);font-size:13px}.metric-card strong{font-size:22px;line-height:1.1}.metric-card.success{border-color:#17724559}.metric-card.warning{border-color:#9a620059}.metric-card.danger{border-color:#b4231852}.two-column{gap:16px;display:grid}.panel{gap:14px;padding:16px;display:grid}.bill-list,.letter-list{gap:10px;display:grid}.bill-row,.letter-row,.review-field{border:1px solid var(--line);background:#fbfdfc;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.letter-row__actions{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:8px;display:flex}.letter-pdf-action{justify-items:end;gap:4px;display:grid}.letter-pdf-action__status{max-width:180px;color:var(--muted);text-align:right;font-size:12px;line-height:1.35}.letter-request-layout{gap:16px;max-width:720px;display:grid}.citizen-home__identity{color:var(--text);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px;display:flex}.citizen-home__identity h2{font-size:22px;line-height:1.2}.citizen-home__identity p{color:var(--muted);margin-top:4px;font-size:13px;line-height:1.4}.citizen-home__empty{grid-template-columns:auto minmax(0,1fr);align-items:center}.citizen-home__metrics{gap:10px;display:grid}.citizen-metric{background:var(--surface);border:1px solid var(--line);min-height:94px;box-shadow:var(--shadow);border-radius:8px;grid-template-columns:auto minmax(0,1fr);gap:12px;padding:14px;display:grid}.citizen-metric svg{color:var(--primary-dark)}.citizen-metric span,.citizen-metric p{color:var(--muted);font-size:13px;line-height:1.35}.citizen-metric strong{margin:3px 0;font-size:20px;line-height:1.15;display:block}.citizen-metric--success{border-color:#17724559}.citizen-metric--warning{border-color:#9a620059}.citizen-metric--danger{border-color:#b4231852}.citizen-shortcuts__actions{gap:8px;display:grid}.citizen-letter-status,.citizen-empty-inline,.citizen-announcement-list li{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;align-items:center;gap:10px;min-height:54px;padding:10px;display:flex}.citizen-letter-status{flex-wrap:wrap;justify-content:space-between}.citizen-letter-status strong,.citizen-announcement-list strong{font-size:14px;line-height:1.3}.citizen-letter-status span,.citizen-announcement-list span{color:var(--muted);font-size:12px}.citizen-empty-inline{color:var(--muted);font-size:13px}.citizen-announcement-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.citizen-announcement-list li{justify-content:space-between}.citizen-announcement-list li>div{gap:3px;display:grid}.citizen-bill-list{gap:8px;display:grid}.citizen-bill-list button{width:100%;min-height:62px;color:var(--text);text-align:left;background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px;display:flex}.citizen-bill-list button.active{box-shadow:inset 3px 0 0 var(--primary);border-color:#25f4ee94}.citizen-bill-list strong{font-size:14px;display:block}.citizen-bill-list span{color:var(--muted);font-size:12px}.citizen-payment-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.citizen-payment-list li{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;gap:8px;padding:10px;display:grid}.citizen-payment-list li>div,.citizen-payment-list li>span,.citizen-payment-list__meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.citizen-payment-list li>span{color:var(--muted);justify-content:flex-start;font-size:12px}.citizen-payment-list strong{font-size:14px}.citizen-payment-list span{color:var(--muted);font-size:12px}.bill-row__amount{flex-shrink:0;justify-items:end;gap:6px;display:grid}.badge{border:1px solid;border-radius:999px;justify-content:center;align-items:center;min-height:24px;padding:3px 8px;font-size:12px;font-weight:750;line-height:1;display:inline-flex}.badge.neutral{color:var(--muted)}.badge.success{color:var(--green)}.badge.warning{color:var(--amber)}.badge.danger{color:var(--red)}.field{gap:7px;display:grid}.field span{color:var(--muted);font-size:13px;font-weight:700}.field label{display:inline-flex}.field input,.field select,.field textarea,.search-box input{width:100%;min-height:46px;color:var(--text);border:1px solid var(--line);background:#fbfdfc;border-radius:8px;outline:none;padding:10px 12px}.field textarea{resize:vertical}.field input:focus,.field select:focus,.field textarea:focus,.search-box input:focus{border-color:var(--primary);box-shadow:var(--focus-ring)}.field-with-icon{color:var(--muted);display:grid;position:relative}.field-with-icon svg{pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.field-with-icon input{padding-left:38px}.field-helper,.field-error{font-size:12px;line-height:1.35}.field-helper{color:var(--muted)}.field-error{color:var(--red)}.segmented{background:var(--surface-strong);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:4px;display:grid}.segmented button{min-height:38px;color:var(--muted);background:0 0;border:0;border-radius:6px;font-weight:700}.segmented .active{color:var(--primary-dark);background:var(--surface);border:1px solid var(--line)}.primary-button,.secondary-button,.icon-button,.nav-button,.bottom-nav__button{border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;font-weight:750;display:inline-flex}.primary-button:focus-visible,.secondary-button:focus-visible,.icon-button:focus-visible,.nav-button:focus-visible,.bottom-nav__button:focus-visible{box-shadow:var(--focus-ring);outline:none}.primary-button{color:#fff;background:var(--primary);border-color:var(--primary);padding:0 14px;box-shadow:4px 4px #fe2c552e,-4px -4px #25f4ee2e}.primary-button:hover{background:#181818}.secondary-button{color:var(--primary-dark);background:#f7ffff;border-color:#25f4ee6b;padding:0 12px}.icon-button{width:44px;height:44px;color:var(--primary-dark);background:var(--surface-elevated);border-color:var(--line);padding:0;box-shadow:0 8px 20px #21312d14}.full-width{width:100%}.gateway-note,.form-error{border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.gateway-note{color:var(--blue);background:#1f5f9914;border:1px solid #1f5f992e}.form-error{color:var(--red);background:#b4231814;border:1px solid #b423182e}.form-success{color:var(--green);background:#17724514;border:1px solid #1772452e;border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.dues-dashboard__header p:not(.eyebrow){color:var(--muted);margin-top:4px;font-size:13px;line-height:1.4}.dues-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.dues-summary-card{background:var(--surface);border:1px solid var(--line);min-height:88px;box-shadow:var(--shadow);border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:13px;display:grid}.dues-summary-card__icon{width:38px;height:38px;color:var(--primary-dark);background:var(--primary-soft);border-radius:8px;place-items:center;display:grid}.dues-summary-card span:not(.dues-summary-card__icon){color:var(--muted);font-size:12px;font-weight:700;line-height:1.25;display:block}.dues-summary-card strong{color:var(--text);overflow-wrap:anywhere;margin-top:5px;font-size:20px;line-height:1.1;display:block}.dues-summary-card.success{border-color:#17724559}.dues-summary-card.success .dues-summary-card__icon{color:var(--green);background:#1772451a}.dues-summary-card.warning{border-color:#9a620052}.dues-summary-card.warning .dues-summary-card__icon{color:var(--amber);background:#9a62001a}.dues-summary-card.danger{border-color:#b4231852}.dues-summary-card.danger .dues-summary-card__icon{color:var(--red);background:#b423181a}.dues-summary-card.accent{border-color:#fe2c5542;grid-column:1/-1}.dues-summary-card.accent .dues-summary-card__icon{color:var(--blue);background:#1f5f991a}.dues-filter-bar{gap:10px;display:grid}.dues-search-field{min-width:0}.dues-status-filter{grid-template-columns:repeat(4,minmax(0,1fr))}.dues-status-filter button{gap:2px;min-width:0;line-height:1.1;display:grid}.dues-status-filter span,.dues-status-filter strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dues-status-filter span{font-size:11px}.dues-status-filter strong{color:inherit;font-size:14px}.dues-layout,.dues-side-stack{gap:16px;display:grid}.dues-list-panel{align-content:start}.dues-bill-list{gap:10px;display:grid}.dues-bill-row{display:block}.dues-bill-row button{width:100%;min-width:0;color:var(--text);text-align:left;background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:12px;display:grid}.dues-bill-row button:hover,.dues-bill-row button.active{background:#f4ffff;border-color:#25f4ee8c}.dues-bill-row button:focus-visible{box-shadow:var(--focus-ring);outline:none}.dues-bill-row__main{gap:4px;min-width:0;display:grid}.dues-bill-row__main strong,.dues-bill-row__main span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.dues-bill-row__main strong{color:var(--text);font-size:14px;line-height:1.25}.dues-bill-row__main span,.dues-bill-row__meta{color:var(--muted);font-size:12px;line-height:1.35}.dues-bill-row__amount{white-space:nowrap;justify-items:end;gap:6px;display:grid}.dues-bill-row__amount strong{color:var(--text);font-size:14px;line-height:1.2}.dues-detail-panel,.dues-payment-panel{align-content:start}.dues-detail-amount{color:var(--primary-dark);background:var(--primary-soft);border:1px solid #25f4ee3d;border-radius:8px;gap:4px;padding:13px;display:grid}.dues-detail-amount span{color:var(--primary-dark);font-size:13px;font-weight:800}.dues-detail-amount strong{color:var(--text);font-size:24px;line-height:1.1}.dues-detail-amount p{color:var(--muted);font-size:13px}.dues-empty-state{min-height:180px}.dues-payment-summary{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;gap:4px;padding:13px;display:grid}.dues-payment-summary span{color:var(--muted);font-size:12px;font-weight:750;line-height:1.3}.dues-payment-summary strong{color:var(--text);font-size:22px;line-height:1.12}.manual-payment-dialog{gap:12px;display:grid}.payment-transaction-panel{align-content:start}.payment-transaction-list{gap:10px;display:grid}.payment-transaction-row{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:12px;display:grid}.payment-transaction-row__main{gap:4px;min-width:0;display:grid}.payment-transaction-row__main strong,.payment-transaction-row__main span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.payment-transaction-row__main strong{color:var(--text);font-size:14px;line-height:1.25}.payment-transaction-row__main span{color:var(--muted);font-size:12px;line-height:1.35}.payment-transaction-row__amount{white-space:nowrap;justify-items:end;gap:6px;display:grid}.payment-transaction-row__amount strong{color:var(--text);font-size:14px;line-height:1.2}.payment-transaction-row__actions{grid-column:1/-1;justify-content:flex-end;gap:8px;display:flex}.payment-transaction-row__actions .icon-button{width:40px;height:40px;min-height:40px}.payment-transaction-empty{min-height:150px}.pay-bill-panel{color:var(--primary-dark);background:#f7fbfa;border:1px solid #25f4ee3d;border-radius:8px;gap:10px;padding:12px;display:grid}.pay-bill-panel--settled{color:var(--green);background:#17724514;border-color:#17724538}.pay-bill-panel,.pay-bill-panel__header{min-width:0}.pay-bill-panel__header{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:9px;display:grid}.pay-bill-panel strong,.pay-bill-panel span{min-width:0;line-height:1.35;display:block}.pay-bill-panel strong{color:currentColor;font-size:13px;font-weight:800}.pay-bill-panel span{color:var(--muted);font-size:12px}.qris-code{max-width:100%;color:var(--text);background:var(--surface);overflow-wrap:anywhere;border:1px dashed #25f4ee8c;border-radius:8px;padding:9px 10px;font-size:12px;line-height:1.35;display:block}.payment-receipt{gap:12px;display:grid}.payment-receipt__amount{color:var(--green);background:#17724514;border:1px solid #17724533;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:13px;display:grid}.payment-receipt__amount svg{color:var(--green)}.payment-receipt__amount span,.payment-receipt__empty span{color:var(--muted);font-size:12px;font-weight:750;line-height:1.35;display:block}.payment-receipt__amount strong,.payment-receipt__empty strong{color:var(--text);overflow-wrap:anywhere;font-size:22px;line-height:1.12;display:block}.payment-receipt__empty{min-height:92px;color:var(--amber);background:#9a620014;border:1px solid #9a62002e;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:13px;display:grid}.payment-receipt__empty svg{color:var(--amber)}.payment-receipt__details dd{overflow-wrap:anywhere;min-width:0}.reports-page__header p:not(.eyebrow){color:var(--muted);margin-top:4px;font-size:13px;line-height:1.4}.reports-filter-panel{gap:12px}.reports-filter-grid{gap:12px;display:grid}.dues-generation-panel{gap:12px}.dues-generation-grid{gap:12px;display:grid}.reports-search-field{min-width:0}.reports-export-actions{gap:8px;display:grid}.reports-total-pill{min-height:34px;color:var(--primary-dark);background:var(--primary-soft);white-space:nowrap;border:1px solid #25f4ee3d;border-radius:8px;align-items:center;gap:7px;padding:6px 10px;font-size:13px;font-weight:800;display:inline-flex}.reports-table-wrap{width:100%;overflow-x:auto}.reports-table{border-collapse:collapse;width:100%;min-width:760px;font-size:13px}.reports-table th,.reports-table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:10px 9px}.reports-table th{color:var(--muted);background:var(--surface-strong);font-size:12px;font-weight:800}.reports-table td{color:var(--text);background:var(--surface)}.reports-table td:nth-child(4),.reports-table td:nth-child(5),.reports-table td:nth-child(6){white-space:nowrap}.reports-table strong,.reports-table span{max-width:260px;line-height:1.35;display:block}.reports-table span{color:var(--muted);font-size:12px}.reports-empty-state{min-height:180px}.notification-settings{gap:14px;display:grid}.notification-settings__intro{color:var(--primary-dark);background:var(--primary-soft);border:1px solid #25f4ee3d;border-radius:8px;grid-template-columns:auto minmax(0,1fr);gap:10px;padding:12px;display:grid}.notification-settings__intro svg{margin-top:2px}.notification-settings__intro h3{color:var(--text);font-size:15px;line-height:1.25}.notification-settings__intro p{color:var(--muted);margin-top:3px;font-size:13px;line-height:1.35}.notification-preference-list{gap:8px;display:grid}.notification-preference-row{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;padding:12px;display:grid}.notification-preference-row__icon{width:36px;height:36px;color:var(--primary-dark);background:var(--primary-soft);border-radius:8px;place-items:center;display:grid}.notification-preference-row__copy{gap:3px;min-width:0;display:grid}.notification-preference-row__copy strong{color:var(--text);font-size:14px;line-height:1.3}.notification-preference-row__copy span{color:var(--muted);font-size:12px;line-height:1.35}.notification-preference-row input{width:22px;height:22px;accent-color:var(--primary)}.notification-settings__actions{gap:8px;display:grid}.reminder-preview{gap:12px;display:grid}.reminder-preview__metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.reminder-preview__metrics span{min-height:54px;color:var(--primary-dark);background:var(--primary-soft);text-align:center;border:1px solid #25f4ee3d;border-radius:8px;place-items:center;padding:9px;font-size:12px;font-weight:800;line-height:1.25;display:grid}.reminder-message-preview{color:var(--primary-dark);background:#f7fbfa;border:1px solid #25f4ee3d;border-radius:8px;grid-template-columns:auto minmax(0,1fr);gap:9px;padding:12px;display:grid}.reminder-message-preview p{color:var(--text);overflow-wrap:anywhere;font-size:13px;line-height:1.45}.reminder-recipient-list{gap:8px;display:grid}.reminder-recipient-row{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px;display:grid}.reminder-recipient-row__main{gap:4px;min-width:0;display:grid}.reminder-recipient-row__main strong,.reminder-recipient-row__main span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.reminder-recipient-row__main strong{color:var(--text);font-size:14px;line-height:1.25}.reminder-recipient-row__main span{color:var(--muted);align-items:center;gap:5px;font-size:12px;line-height:1.35;display:flex}.reminder-preview__warning,.reminder-preview__ready{border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.reminder-preview__warning{color:var(--amber);background:#9a620014;border:1px solid #9a62002e}.reminder-preview__ready{color:var(--green);background:#17724514;border:1px solid #1772452e}.broadcast-create{gap:12px;display:grid}.broadcast-target-picker{grid-template-columns:repeat(3,minmax(0,1fr))}.broadcast-target-picker button{gap:3px;min-width:0;display:grid}.broadcast-target-picker span,.broadcast-target-picker strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.broadcast-target-picker span{font-size:11px}.broadcast-target-picker strong{color:inherit;font-size:14px}.broadcast-create__preview{color:var(--primary-dark);background:#f7fbfa;border:1px solid #25f4ee3d;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:12px;display:grid}.broadcast-create__preview strong,.broadcast-create__preview span{min-width:0;line-height:1.35;display:block}.broadcast-create__preview strong{color:var(--text);font-size:14px;font-weight:800}.broadcast-create__preview span{color:var(--muted);font-size:12px}.broadcast-create__actions{grid-template-columns:minmax(0,1fr);gap:8px;display:grid}.search-box{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;align-items:center;gap:10px;padding:0 12px;display:flex}.search-box input{box-shadow:none;border:0;padding-inline:0}.resident-grid{gap:12px;display:grid}.resident-card{gap:12px;padding:14px;display:grid}.resident-card__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.address{color:var(--text)}.resident-meta{flex-wrap:wrap;gap:8px;display:flex}.resident-meta span{min-height:26px;color:var(--muted);background:#f3f4f6;border-radius:999px;align-items:center;gap:5px;padding:3px 8px;font-size:12px;font-weight:700;display:inline-flex}.household-list__summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.household-list__summary div{background:var(--surface);border:1px solid var(--line);border-radius:8px;align-content:center;gap:6px;min-height:72px;padding:12px;display:grid}.household-list__summary span{color:var(--muted);font-size:12px;font-weight:700}.household-list__summary strong{color:var(--text);font-size:22px;line-height:1}.household-toolbar{gap:10px;display:grid}.household-search{min-height:48px}.household-status-filter{grid-template-columns:repeat(3,minmax(0,1fr))}.household-status-filter button{flex-direction:column;gap:2px;line-height:1.1;display:inline-flex}.household-status-filter strong{color:inherit;font-size:12px}.household-card{min-height:166px}.household-address{align-items:flex-start;gap:7px;display:flex}.household-address svg{color:var(--primary);flex:none;margin-top:1px}.household-pagination{justify-content:center;align-items:center;gap:12px;min-height:44px;display:flex}.household-pagination span{color:var(--muted);font-size:13px;font-weight:750}.household-detail__header{flex-wrap:wrap;justify-content:space-between;gap:10px;display:flex}.household-detail__hero{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px;display:flex}.household-detail__hero h2{color:var(--text);font-size:24px;line-height:1.15}.household-detail__hero p:last-child{color:var(--muted);margin-top:4px;font-size:13px;font-weight:700}.household-detail__summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.household-detail__summary div{background:var(--surface);border:1px solid var(--line);border-radius:8px;gap:6px;min-height:88px;padding:12px;display:grid}.household-detail__summary svg{color:var(--primary)}.household-detail__summary span{color:var(--muted);font-size:12px;font-weight:700}.household-detail__summary strong{color:var(--text);font-size:15px;line-height:1.2}.detail-list{gap:12px;margin:0;display:grid}.detail-list div{gap:4px;display:grid}.detail-list dt{color:var(--muted);font-size:12px;font-weight:750}.detail-list dd{color:var(--text);align-items:flex-start;gap:7px;margin:0;font-size:14px;line-height:1.4;display:flex}.detail-list dd svg{color:var(--primary);flex:none;margin-top:2px}.resident-member-list,.household-history-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.resident-member-list li,.household-history-list li{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;gap:10px;padding:12px;display:grid}.resident-member-list li{grid-template-columns:auto minmax(0,1fr)}.resident-member-list__avatar,.household-history-list__icon{width:34px;height:34px;color:var(--primary-dark);background:var(--primary-soft);border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.resident-member-list strong,.household-history-list strong{color:var(--text);font-size:14px;line-height:1.25;display:block}.resident-member-list span,.household-history-list span{color:var(--muted);font-size:12px;line-height:1.35}.resident-member-list__meta{flex-wrap:wrap;grid-column:2;gap:6px;display:flex}.resident-member-list__meta span{background:#f3f4f6;border-radius:999px;align-items:center;min-height:24px;padding:3px 7px;font-weight:700;display:inline-flex}.household-history-list li{grid-template-columns:auto minmax(0,1fr) auto;align-items:center}.household-history-list__icon.success{color:var(--green);background:#1772451a}.household-history-list__icon.warning{color:var(--amber);background:#9a62001a}.household-history-list__icon.danger{color:var(--red);background:#b423181a}.household-form{gap:16px;display:grid}.household-form__grid,.household-form__members,.resident-form__grid{gap:12px;display:grid}.resident-form{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;gap:12px;min-width:0;margin:0;padding:14px;display:grid;position:relative}.resident-form legend{padding:0 8px 0 0}.resident-form__legend{color:var(--primary-dark);align-items:center;gap:7px;font-size:13px;font-weight:800;display:inline-flex}.resident-form__remove{width:38px;height:38px;position:absolute;top:10px;right:10px}.household-form__actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.household-form__actions .primary-button,.household-form__actions .secondary-button{flex:160px;scroll-margin-bottom:132px}.scan-result{gap:10px;display:grid}.kk-extracted-form{gap:14px;display:grid}.kk-extracted-form__grid,.kk-extracted-form__members,.kk-extracted-member__grid{gap:12px;display:grid}.kk-extracted-field__label{justify-content:space-between;align-items:center;gap:8px;display:flex}.kk-extracted-field__label label{min-width:0}.kk-extracted-member{border:1px solid var(--line);background:var(--surface-elevated);border-radius:8px;gap:12px;min-width:0;margin:0;padding:12px;display:grid}.kk-extracted-member legend{padding:0 8px 0 0}.duplicate-warning{color:var(--amber);background:#9a620014;border:1px solid #9a620033;border-radius:8px;align-items:flex-start;gap:10px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.duplicate-warning strong{color:#754b00;display:block}.duplicate-warning ul{gap:4px;margin:6px 0 0;padding-left:18px;display:grid}.scan-progress{background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;gap:12px;padding:12px;display:grid;box-shadow:0 8px 20px #21312d0f}.scan-progress__header,.scan-progress--failed{align-items:flex-start;gap:10px;display:flex}.scan-progress__icon{width:34px;height:34px;color:var(--primary-dark);background:var(--primary-soft);border:1px solid #25f4ee3d;border-radius:8px;flex:none;place-items:center;display:grid}.scan-progress strong,.scan-progress span{display:block}.scan-progress strong{color:var(--text);font-size:14px;line-height:1.3}.scan-progress span{color:var(--muted);margin-top:2px;font-size:12px;font-weight:650;line-height:1.35}.scan-progress__bar{background:var(--surface-strong);border-radius:999px;height:8px;overflow:hidden}.scan-progress__bar span{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:inherit;height:100%;margin-top:0}.scan-progress--failed{color:var(--red);box-shadow:none;background:#b4231814;border-color:#b423182e}.scan-progress--failed strong{color:var(--red)}.scan-progress--failed span{color:#7b332d}.kk-photo-capture{align-content:start}.kk-photo-capture__actions{gap:10px;display:grid}.kk-photo-preview{gap:12px;display:grid}.kk-photo-preview img,.kk-photo-preview__empty{aspect-ratio:4/3;border:1px solid var(--line);background:linear-gradient(135deg, #25f4ee24, #fe2c5517), var(--surface);border-radius:8px;width:100%}.kk-photo-preview img{object-fit:cover;display:block}.kk-photo-preview__empty{color:var(--primary);place-items:center;display:grid}.kk-photo-preview strong,.kk-photo-preview span{display:block}.kk-photo-preview strong{color:var(--text);font-size:16px;line-height:1.25}.kk-photo-preview span{color:var(--muted);margin-top:4px;font-size:13px;line-height:1.4}.review-field>div{gap:4px;display:grid}.review-field span{color:var(--muted);font-size:12px;font-weight:700}.member-list{gap:8px;display:grid}.member-list div{background:#f3f4f6;border-radius:8px;gap:2px;padding:10px 12px;display:grid}.member-list span{color:var(--muted);font-size:13px}.empty-state{text-align:center;color:var(--muted);justify-items:center;gap:8px;padding:28px 16px;display:grid}.empty-state h3{color:var(--text)}.tenant-settings{gap:16px}.tenant-settings__preview{background:linear-gradient(135deg,#25f4ee21,#fe2c5514);border:1px solid #25f4ee3d;border-radius:8px;align-items:center;gap:12px;padding:12px;display:flex}.tenant-settings__preview strong,.tenant-settings__preview span{display:block}.tenant-settings__preview strong{color:var(--text);line-height:1.25}.tenant-settings__preview span{color:var(--muted);margin-top:3px;font-size:13px;line-height:1.35}.tenant-logo-preview{width:48px;height:48px;color:var(--primary-dark);background:var(--surface);border:1px solid var(--line);border-radius:8px;flex:none;place-items:center;display:grid;overflow:hidden}.tenant-logo-preview img{object-fit:cover;width:100%;height:100%}.tenant-settings__form{gap:16px;display:grid}.settings-group{border-top:1px solid var(--line);gap:12px;padding-top:14px;display:grid}.settings-group__title{color:var(--primary-dark);align-items:center;gap:8px;display:flex}.settings-group__title h3{font-size:15px;line-height:1.25}.settings-grid{gap:12px;display:grid}.tenant-settings__actions{gap:10px;display:grid}.shell-state{text-align:center;min-height:280px;color:var(--muted);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;place-items:center;gap:14px;padding:28px 16px;display:grid}.shell-state h2{color:var(--text);font-size:20px}.skeleton-stack{gap:10px;width:min(280px,100%);display:grid}.skeleton-line{background:linear-gradient(90deg,#e8eeec,#f6f8f7,#e8eeec) 0 0/200% 100%;border-radius:999px;height:14px;animation:1.4s ease-in-out infinite skeleton-pulse}.skeleton-line:nth-child(2){width:82%}.skeleton-line:nth-child(3){width:64%}.ui-dialog-backdrop{z-index:60;background:#0a141170;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.ui-dialog,.ui-sheet{background:var(--surface);border:1px solid var(--line);border-radius:8px;gap:14px;width:min(480px,100%);padding:16px;display:grid;box-shadow:0 18px 60px #0a14113d}.ui-dialog__header,.ui-dialog__actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.ui-dialog__header h2{font-size:18px;line-height:1.25}.ui-dialog__body{color:var(--muted);font-size:14px;line-height:1.5}.ui-dialog__actions{justify-content:flex-end}.ui-sheet.bottom{border-radius:8px 8px 0 0;align-self:end;width:100%;max-width:640px}.ui-sheet.right{border-radius:8px 0 0 8px;justify-self:end;max-width:420px;height:100%}@keyframes skeleton-pulse{to{background-position:-200% 0}}.bottom-nav{left:12px;right:12px;bottom:max(12px, env(safe-area-inset-bottom));z-index:30;border:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;border-radius:18px;flex-wrap:nowrap;gap:6px;padding:6px;display:flex;position:fixed;box-shadow:0 18px 46px #1524202e}.bottom-nav__button{min-width:0;min-height:60px;color:var(--muted);background:0 0;border:0;flex-direction:column;flex:1 1 0;gap:4px;padding:5px 3px;font-size:11px;line-height:1;transition:background .16s,color .16s,transform .16s;position:relative}.bottom-nav__button:hover{color:var(--primary-dark);background:#25f4ee1f}.bottom-nav__button span:last-child{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.bottom-nav__icon{color:currentColor;background:#f3f4f6;border:1px solid #0000;border-radius:12px;place-items:center;width:34px;height:34px;transition:background .16s,border-color .16s,color .16s;display:grid}.bottom-nav__button.active{color:var(--primary-dark);background:var(--primary-soft)}.bottom-nav__button.active .bottom-nav__icon{color:#fff;background:var(--primary);border-color:var(--primary)}.bottom-nav__button.active:after{content:"";background:var(--tiktok-red);border-radius:999px;width:5px;height:5px;position:absolute;top:5px}.toast{z-index:40;color:#fff;min-height:42px;box-shadow:var(--shadow);pointer-events:none;background:#101010;border-radius:8px;align-items:center;padding:10px 12px;font-size:13px;display:grid;position:fixed;bottom:86px;left:16px;right:16px}.login-screen,.license-screen{background:radial-gradient(circle at 18% 10%, #25f4ee2e, transparent 280px), radial-gradient(circle at 86% 4%, #fe2c5524, transparent 260px), var(--bg);place-items:center;min-height:100svh;padding:20px;display:grid}.login-panel{background:var(--surface);border:1px solid var(--line);width:min(440px,100%);box-shadow:var(--shadow);border-radius:8px;gap:18px;padding:20px;display:grid}.license-panel{align-content:start}.license-panel--state{min-height:188px}.license-panel__note,.license-device-id{color:var(--muted);font-size:13px;line-height:1.45}.license-device-id{background:var(--surface-strong);border:1px solid var(--line);overflow-wrap:anywhere;border-radius:8px;padding:10px 12px}.login-brand{border-bottom:1px solid var(--line);padding-bottom:8px}.login-heading{align-items:center;gap:12px;display:flex}.login-heading svg{color:var(--primary);flex:none}.login-heading h1{font-size:22px;line-height:1.15}.brand{align-items:center;gap:12px;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#111,#010101);border-radius:8px;place-items:center;width:44px;height:44px;font-weight:850;display:grid;box-shadow:5px 5px #fe2c558c,-5px -5px #25f4ee8c,0 12px 26px #10101033}.brand strong,.brand span{display:block}.brand strong{line-height:1.1}.brand span{color:var(--muted);font-size:12px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width>=760px){.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.citizen-home__metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.citizen-shortcuts__actions{grid-template-columns:repeat(3,minmax(0,220px))}.dues-summary-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.dues-summary-card.accent{grid-column:auto}.dues-filter-bar{grid-template-columns:minmax(0,1fr) minmax(360px,460px);align-items:end}.reports-filter-grid{grid-template-columns:minmax(140px,.7fr) minmax(150px,.75fr) minmax(130px,.55fr) minmax(260px,1fr);align-items:end}.dues-generation-grid{grid-template-columns:minmax(150px,.9fr) minmax(140px,.8fr) minmax(120px,.6fr);align-items:start}.reports-export-actions{grid-template-columns:repeat(2,minmax(160px,max-content));justify-content:end}.notification-settings__actions{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.resident-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tenant-settings__actions{grid-template-columns:minmax(0,1fr) auto;align-items:center}.tenant-settings__actions .primary-button{justify-self:end}.household-toolbar{grid-template-columns:minmax(0,1fr) minmax(300px,380px);align-items:center}.household-form__grid,.kk-extracted-form__grid,.kk-extracted-member__grid,.resident-form__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.household-form__grid .field:nth-child(3),.kk-extracted-form__grid .field:nth-child(3){grid-column:1/-1}.household-form__actions .primary-button,.household-form__actions .secondary-button{flex:none}}@media (width>=1024px){.app-shell{grid-template-columns:248px minmax(0,1fr);display:grid}.sidebar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-right:1px solid var(--line);background:#ffffffe0;flex-direction:column;gap:24px;height:100svh;padding:22px 14px;display:flex;position:sticky;top:0}.sidebar-nav{gap:8px;display:grid}.nav-button{min-height:58px;color:var(--muted);background:0 0;border-color:#0000;justify-content:flex-start;padding:7px 10px;transition:background .16s,border-color .16s,color .16s,transform .16s;position:relative}.nav-button:hover{color:var(--primary-dark);background:#25f4ee1a}.nav-button__icon{color:currentColor;background:#f3f4f6;border:1px solid #0000;border-radius:8px;flex:none;place-items:center;width:38px;height:38px;display:grid}.nav-button__text{text-align:left;gap:2px;min-width:0;display:grid}.nav-button__label,.nav-button__helper{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nav-button__helper{color:var(--muted);font-size:11px;font-weight:650}.nav-button.active{color:var(--primary-dark);background:var(--primary-soft);box-shadow:inset 3px 0 0 var(--primary);border-color:#25f4ee3d}.nav-button.active .nav-button__icon{color:#fff;background:var(--primary);border-color:var(--primary)}.nav-button.active .nav-button__helper{color:#4b5563}.sidebar-status{min-height:42px;color:var(--primary-dark);background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;align-items:center;gap:8px;margin-top:auto;padding:0 10px;font-size:13px;font-weight:700;display:flex}.topbar{background:#f8f8fae0;padding:24px 28px 16px}.topbar h1{font-size:28px}.content{padding:24px 28px 42px}.two-column{grid-template-columns:minmax(0,1.45fr) minmax(340px,.85fr);align-items:start}.dues-layout{grid-template-columns:minmax(0,1.35fr) minmax(330px,.75fr);align-items:start}.bottom-nav{display:none}.toast{width:min(420px,100vw - 48px);bottom:24px;left:auto;right:24px}}
