:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#18251f;background:#f5f7f3;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}.shell{min-height:100vh;display:grid;grid-template-columns:264px 1fr;transition:grid-template-columns .18s ease}.shell.sidebar-collapsed{grid-template-columns:82px 1fr}.sidebar{background:#163c34;color:#eef8f3;padding:22px 18px;display:flex;flex-direction:column;gap:24px}.brand{display:flex;align-items:center;gap:12px;min-height:48px}.brand-mark{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:#d7a84d;color:#17362e}.brand-mark-logo{overflow:visible;padding:0;background:transparent;box-shadow:none}.brand-mark-logo img{width:100%;height:100%;object-fit:contain;display:block;background:transparent}.brand strong{display:block;font-size:17px}.brand span,.muted{color:#6e7a72;font-size:13px}.brand span{color:#b8cbc2}.brand-text{min-width:0}.sidebar-toggle{margin-top:auto;min-height:42px;width:100%;border:1px solid rgba(255,255,255,.12);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:9px;background:#ffffff0f;color:#eef8f3;font-size:13px;font-weight:900;cursor:pointer}.sidebar-toggle:hover{background:#ffffff1f}.nav{display:grid;gap:6px}.nav-item{border:0;color:inherit;display:flex;align-items:center;gap:10px;border-radius:8px;padding:11px 12px;text-decoration:none;background:transparent;cursor:pointer}.nav-item.router-link-active{background:#23594d}.nav-item:hover{background:#ffffff14}.sidebar-collapsed .sidebar{padding-inline:14px;align-items:center}.sidebar-collapsed .brand{width:100%;justify-content:center}.sidebar-collapsed .brand-text,.sidebar-collapsed .nav-item span,.sidebar-collapsed .sidebar-toggle span{display:none}.sidebar-collapsed .sidebar-toggle{width:42px;padding:0}.sidebar-collapsed .nav{width:100%}.sidebar-collapsed .nav-item{justify-content:center;padding-inline:0}.content{padding:24px 30px 40px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:24px}.topbar h1{margin:4px 0 0;font-size:28px;line-height:1.2;letter-spacing:0}.topbar-user-menu{position:relative;display:flex;align-items:stretch;justify-content:flex-end}.user-chip{min-height:48px;border:1px solid #dfe7df;border-radius:8px 0 0 8px;padding:8px 14px;display:flex;align-items:center;gap:10px;background:#fff;color:#18251f;text-align:right;cursor:pointer}.user-chip:hover{border-color:#c8d8ce;background:#fbfdfc}.user-menu-toggle{width:42px;border:1px solid #dfe7df;border-left:0;border-radius:0 8px 8px 0;display:inline-flex;align-items:center;justify-content:center;background:#fff;color:#617168;cursor:pointer}.user-menu-toggle:hover{border-color:#c8d8ce;background:#fbfdfc}.user-menu-toggle svg{transition:transform .15s ease}.user-menu-toggle svg.rotated{transform:rotate(180deg)}.user-chip-info{display:grid;gap:2px}.user-chip span{color:#617168;font-size:13px}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;z-index:30;min-width:180px;padding:6px;border:1px solid #dfe7df;border-radius:8px;background:#fff;box-shadow:0 16px 34px #122c251f}.user-dropdown button{width:100%;min-height:40px;border:0;border-radius:8px;display:flex;align-items:center;gap:9px;padding:0 10px;background:transparent;color:#17362e;font-size:13px;font-weight:900;cursor:pointer}.user-dropdown button:hover{background:#f6faf7}.user-dropdown button:last-child{color:#a83d2d}.user-dropdown button:last-child:hover{background:#fff7f5}.panel{background:#fff;border:1px solid #dfe7df;border-radius:8px;padding:18px}.grid{display:grid;gap:16px}.metrics{grid-template-columns:repeat(4,minmax(150px,1fr));margin-bottom:16px}.metric{padding:18px;border-radius:8px;background:#fff;border:1px solid #dfe7df}.metric span{color:#68776f;font-size:13px}.metric strong{display:block;margin-top:10px;font-size:30px}.dashboard-page{display:grid;gap:18px}.dashboard-loading{color:#52635a;font-weight:800}.dashboard-hero{position:relative;overflow:hidden;display:flex;align-items:stretch;justify-content:space-between;gap:24px;padding:26px;border-radius:8px;background:linear-gradient(135deg,#17362e,#1f654f 58%,#d7a84d 140%);color:#fff;box-shadow:0 18px 44px #17362e2e}.dashboard-hero:after{content:"";position:absolute;inset:auto -80px -120px auto;width:300px;height:300px;border-radius:50%;background:#ffffff14}.dashboard-scope{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:8px;background:#ffffff1f;color:#f9efd8;font-size:12px;font-weight:900}.dashboard-hero h2{margin:14px 0 8px;font-size:clamp(28px,4vw,42px);line-height:1.05;letter-spacing:0}.dashboard-hero p{max-width:620px;margin:0;color:#d7e7df;font-size:15px;line-height:1.6}.dashboard-hero-metrics{position:relative;z-index:1;min-width:280px;display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:10px;align-self:stretch}.dashboard-hero-metrics div{display:grid;align-content:end;gap:8px;padding:16px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-hero-metrics span{color:#d7e7df;font-size:12px;font-weight:800}.dashboard-hero-metrics strong{font-size:30px;line-height:1}.dashboard-kpis{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:8px}.dashboard-kpi{min-width:0;display:grid;align-content:start;gap:5px;padding:10px 8px;border:1px solid #dfe7df;border-radius:8px;background:#fff;box-shadow:0 10px 28px #122c250d}.dashboard-kpi-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#edf5ef;color:#1f654f}.dashboard-kpi span{min-width:0;color:#5c6d64;font-size:10px;font-weight:900;line-height:1.12;overflow-wrap:anywhere}.dashboard-kpi strong{color:#172b24;font-size:clamp(16px,2.2vw,23px);line-height:1}.dashboard-kpi em{min-height:15px;color:#718078;font-size:10px;line-height:1.15;font-style:normal;font-weight:700;overflow-wrap:anywhere}.dashboard-kpi.tone-gold .dashboard-kpi-icon{background:#fff6df;color:#8a5b07}.dashboard-kpi.tone-blue .dashboard-kpi-icon{background:#e8f3fb;color:#2f6e99}.dashboard-kpi.tone-purple .dashboard-kpi-icon{background:#f0eafa;color:#7442a8}.dashboard-kpi.tone-red .dashboard-kpi-icon{background:#fff0ed;color:#b34737}.dashboard-insight-grid{display:grid;grid-template-columns:minmax(320px,410px) minmax(0,1fr);gap:14px;align-items:stretch}.dashboard-insight-grid.recent-only{grid-template-columns:1fr}.dashboard-chart-stack{display:grid;grid-template-columns:1fr;grid-template-rows:auto auto;gap:8px;min-width:0;align-content:start}.dashboard-card{min-width:0;display:grid;gap:16px;padding:18px;border:1px solid #dde7e1;border-radius:8px;background:linear-gradient(180deg,#fff,#fbfdfc);box-shadow:0 14px 34px #122c2512}.compact-chart-card{gap:7px;padding:10px 12px}.compact-chart-card .dashboard-card-header h3{font-size:15px}.compact-chart-card .dashboard-card-header p{margin-top:2px;font-size:11px}.dashboard-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.dashboard-card-header h3{margin:0;color:#172b24;font-size:17px;letter-spacing:0}.dashboard-card-header p{margin:4px 0 0;color:#6b7a72;font-size:12px;font-weight:700}.dashboard-card-header svg{color:#1f654f}.dashboard-distribution-card,.dashboard-ward-card{align-content:start}.pie-chart-block{display:grid;grid-template-columns:1fr;gap:7px;align-items:start;justify-items:center}.pie-chart-block.wide{grid-template-columns:1fr}.dashboard-pie{width:min(70px,100%);aspect-ratio:1;display:grid;place-items:center;border:3px solid #f6faf8;border-radius:50%;box-shadow:inset 0 0 0 1px #17362e14,0 6px 12px #122c2514}.pie-chart-block.wide .dashboard-pie{width:min(70px,100%)}.dashboard-pie span{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#fffffff5;color:#172b24;font-size:11px;font-weight:900;box-shadow:0 0 0 1px #17362e14,0 4px 8px #122c250f}.distribution-legend{width:100%;display:grid;gap:4px}.distribution-legend div{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px;align-items:center;padding:3px 0;border-bottom:1px solid #eef3ef}.distribution-legend div:last-child{border-bottom:0}.distribution-legend i{width:9px;height:9px;border-radius:3px;box-shadow:0 0 0 2px #ffffffe6,0 2px 6px #122c251f}.distribution-legend span{display:grid;gap:2px;min-width:0}.distribution-legend span strong{color:#172b24;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.distribution-legend span small{color:#6b7a72;font-size:11px;font-weight:800}.dashboard-recent-card{height:100%;grid-template-rows:auto minmax(0,1fr);align-content:stretch}.dashboard-recent-card .table-wrap{height:100%}.dashboard-table{min-width:1180px}.dashboard-table td:last-child{max-width:360px;color:#52635a}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.toolbar h2{margin:0;font-size:18px}.search{width:min(360px,100%);border:1px solid #cedbd1;border-radius:8px;padding:10px 12px;background:#fff}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:760px}th{text-align:left;color:#586961;font-size:12px;text-transform:uppercase;letter-spacing:.04em;background:#f7faf7}td,th{border-bottom:1px solid #e5ece5;padding:12px 10px}td{font-size:14px}tbody tr:nth-child(odd){background:#fff}tbody tr:nth-child(2n){background:#f8fbf9}tbody tr:hover{background:#eef6f1}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f6faf7}.clickable-row:focus-visible{outline:3px solid rgba(215,168,77,.35);outline-offset:-3px}.resident-status-row.resident-status-active:nth-child(odd){background:#f3fbf5}.resident-status-row.resident-status-active:nth-child(2n){background:#eaf7ee}.resident-status-row.resident-status-active:hover{background:#dff2e5}.resident-status-row.resident-status-absent:nth-child(odd){background:#fff7e8}.resident-status-row.resident-status-absent:nth-child(2n){background:#fff1d5}.resident-status-row.resident-status-absent:hover{background:#ffedc2}.resident-status-row.resident-status-deleted:nth-child(odd){background:#fff1ee}.resident-status-row.resident-status-deleted:nth-child(2n){background:#ffe6e0}.resident-status-row.resident-status-deleted:hover{background:#ffdcd5}.resident-status-row.resident-status-expired:nth-child(odd){background:#f6f8f7}.resident-status-row.resident-status-expired:nth-child(2n){background:#eef3ef}.resident-status-row.resident-status-expired:hover{background:#e4ece6}.resident-status-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:800;white-space:nowrap;border:1px solid transparent}.resident-status-badge.active{color:#17663d;background:#dff4e6;border-color:#a8dec0}.resident-status-badge.absent{color:#8b5400;background:#ffe5ad;border-color:#f3c96e}.resident-status-badge.deleted{color:#9a321f;background:#ffd7ce;border-color:#eba292}.resident-status-badge.moved-out,.resident-status-badge.expired{color:#52635a;background:#eef3ef;border-color:#cddbd2}.status{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700;background:#edf5ef;color:#23734f}.status.inactive{background:#f4e8e6;color:#9a321f}.nationality-badge{display:inline-flex;align-items:center;gap:7px;min-height:28px;color:#17362e;font-size:13px;font-weight:700;white-space:nowrap}.nationality-badge.foreign,.nationality-badge.local{background:transparent;border:0}.nationality-badge svg{flex:0 0 auto}.country-flag{display:inline-flex;align-items:center;justify-content:center;width:18px;font-size:16px;line-height:1}.form-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#163c34,#224f45 45%,#f5f7f3 45%)}.login-page{position:relative;overflow:hidden;background:linear-gradient(135deg,#092b25,#114938 46%,#7f151b 46%,#9d1a20 66%,#f4ead2 66%,#fff9ea)}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0 28%,rgba(231,190,79,.2) 28% 28.35%,transparent 28.35% 100%),linear-gradient(120deg,transparent 0 64%,rgba(255,255,255,.3) 64% 64.25%,transparent 64.25% 100%);pointer-events:none}.login-shell{position:relative;z-index:1;width:min(960px,100%);min-height:550px;display:grid;grid-template-columns:minmax(320px,.92fr) minmax(340px,430px);overflow:hidden;border:1px solid rgba(255,255,255,.72);border-radius:8px;background:#fffffff5;box-shadow:0 30px 90px #08201b52}.login-visual{display:grid;align-content:center;justify-items:center;gap:18px;padding:42px;background:linear-gradient(180deg,#fffffff0,#fffaeae6);color:#17362e;text-align:center;border-right:1px solid #eadfbf}.login-visual-badge{width:min(500px,96%);display:grid;place-items:center;padding:0;border-radius:0;background:transparent;box-shadow:none}.login-visual-badge img{width:100%;height:auto;object-fit:contain;display:block}.login-visual h1{margin:0;max-width:none;color:#17362e;font-size:clamp(30px,3.4vw,40px);line-height:1.05;letter-spacing:0;white-space:nowrap}.login-visual p{margin:8px 0 0;color:#6b4a09;font-size:16px;font-weight:800}.login-card{width:100%;align-self:center;background:#fff;border-radius:0;padding:38px 36px;border:0;box-shadow:none}.login-card h2{margin:0 0 8px;color:#132c25;font-size:30px;line-height:1.15;letter-spacing:0}.login-card .muted{color:#6b7a72;font-size:14px}.field{display:grid;gap:7px;margin-top:16px}.field label{font-size:13px;color:#52635a;font-weight:700}.field input{border:1px solid #cedbd1;border-radius:8px;padding:12px}.login-card .field input{min-height:48px;background:#fbfdfc;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.login-card .field input:focus{outline:0;border-color:#0f6b52;background:#fff;box-shadow:0 0 0 3px #0f6b5224}.field select{border:1px solid #cedbd1;border-radius:8px;padding:12px;background:#fff}.primary{width:100%;margin-top:20px;border:0;border-radius:8px;padding:12px 14px;background:#d7a84d;color:#17362e;font-weight:800;cursor:pointer}.login-card .primary{min-height:50px;background:linear-gradient(135deg,#0f6b52,#17825f);color:#fff;box-shadow:0 14px 30px #0f6b5247;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.login-card .primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 36px #0f6b5257;filter:brightness(1.03)}.login-card .primary:disabled{opacity:.65;cursor:progress;box-shadow:none}.login-card .error{margin-top:14px;padding:12px 14px;border:1px solid #e6a39a;border-radius:8px;background:#fff0ed;color:#9a321f;font-size:14px;font-weight:900;line-height:1.4;box-shadow:0 10px 22px #9a321f14}.inline-form{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr)) auto;gap:10px;align-items:end;margin-bottom:16px}.inline-form.user-form{grid-template-columns:repeat(4,minmax(160px,1fr))}.inline-form input,.inline-form select{border:1px solid #cedbd1;border-radius:8px;padding:10px 12px;min-width:0;background:#fff}.inline-form select:disabled{background:#f2f5f2;color:#6a756e}.inline-form button{border:0;border-radius:8px;padding:10px 14px;background:#d7a84d;color:#17362e;font-weight:800;cursor:pointer;white-space:nowrap}.inline-form .cancel{background:#eef3ef;color:#31443b}.row-actions{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}.compact-actions{justify-content:flex-end;gap:6px}.actions-cell{width:92px;text-align:right}.action-button{min-height:34px;border:1px solid #cfe0d6;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 10px;background:#f6faf7;color:#1f654f;cursor:pointer;font-size:13px;font-weight:800;line-height:1;white-space:nowrap;transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease}.action-button.icon-only{width:34px;height:34px;min-height:34px;padding:0}.action-button:hover{border-color:#8fbba9;background:#e9f4ee;box-shadow:0 6px 14px #1f654f1f;transform:translateY(-1px)}.action-button:focus-visible{outline:3px solid rgba(215,168,77,.35);outline-offset:2px}.action-button.danger{border-color:#efd0c8;background:#fff7f5;color:#a83d2d}.action-button.danger:hover{border-color:#d99687;background:#fbe8e4;box-shadow:0 6px 14px #a83d2d1f}.action-button.warning{border-color:#f0dfb8;background:#fffaf0;color:#8a5b07}.action-button.warning:hover{border-color:#d8b865;background:#fff3d8;box-shadow:0 6px 14px #8a5b071f}.switch-control{width:46px;height:26px;border:0;border-radius:999px;padding:3px;display:inline-flex;align-items:center;justify-content:flex-end;background:#23734f;cursor:pointer;transition:background .15s ease,box-shadow .15s ease}.switch-control span{width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #10201b38;transition:transform .15s ease}.switch-control.off{justify-content:flex-start;background:#a83d2d}.switch-control:hover{box-shadow:0 6px 14px #1f654f24}.switch-control:focus-visible{outline:3px solid rgba(215,168,77,.35);outline-offset:2px}.switch-control:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.error{color:#a83d2d;font-size:14px;margin-top:12px}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;border-bottom:1px solid #dfe7df}.tabs button{border:0;border-bottom:3px solid transparent;background:transparent;color:#56665d;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-weight:800;padding:11px 14px 10px}.tabs button:hover{color:#17362e;background:#f6faf7}.tabs button.active{color:#17362e;border-bottom-color:#d7a84d}.tab-count{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:8px;background:#edf5ef;color:#1f654f;font-size:12px;font-weight:800;white-space:nowrap}.tabs button.active .tab-count{background:#fff6df;color:#73510b}.filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:0 0 14px}.household-resident-filterbar{align-items:flex-start}.household-resident-actions{flex:0 0 100%;display:flex;justify-content:flex-end;gap:10px;align-items:center}.filterbar .search{width:min(320px,100%)}.filter-action{border:0;border-radius:8px;padding:10px 16px;background:#1f654f;color:#fff;font-weight:800;cursor:pointer;box-shadow:0 8px 18px #1f654f2e;white-space:nowrap}.filter-action:hover{background:#174d3e}.filter-action.danger-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:#b3261e;box-shadow:0 8px 18px #b3261e2e}.filter-action.danger-action:hover{background:#8f1d17}.filter-action:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.filter-action.danger-action:disabled:hover{background:#b3261e}.filter-action.secondary-action{background:#eef3ef;color:#31443b;box-shadow:none}.filter-action.secondary-action:hover{background:#dfe7df}.resident-filterbar{display:grid;gap:14px;margin:0 0 16px;padding:14px;background:#fff;border:1px solid #dfe7df;border-radius:8px;box-shadow:0 10px 28px #122c250f}.resident-filterbar-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.resident-filterbar-title{display:inline-flex;align-items:center;gap:8px;color:#17362e;font-size:14px;font-weight:900}.resident-filterbar-title svg{color:#1f654f}.resident-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;align-items:end}.filter-field{display:grid;gap:6px;min-width:0}.filter-field span{color:#52635a;font-size:12px;font-weight:800;line-height:1.2}.filter-field-wide{grid-column:span 2}.resident-filterbar .search{width:100%;min-height:42px;border-color:#d6e2da;background:#fbfdfb;color:#17362e;box-shadow:inset 0 1px #ffffffbf;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.resident-filterbar .search:hover{border-color:#b7cbbf;background:#fff}.resident-filterbar .search:focus{outline:0;border-color:#1f654f;background:#fff;box-shadow:0 0 0 3px #1f654f1f}.resident-filter-reset{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 12px}.add-ward-button{margin-left:auto}.paginationbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;color:#52635a;font-size:14px}.paginationbar.top-pagination{margin:0 0 14px}.paginationbar div{display:flex;gap:8px}.paginationbar button{border:1px solid #cedbd1;border-radius:8px;padding:8px 12px;background:#fff;color:#17362e;font-weight:800;cursor:pointer}.paginationbar button.active{border-color:#d7a84d;background:#fff6df;color:#17362e}.paginationbar button.ellipsis{min-width:38px;background:#f7faf7;color:#6e7a72}.paginationbar button:disabled{opacity:.45;cursor:not-allowed}.page-size-select{border:1px solid #cedbd1;border-radius:8px;padding:8px 10px;background:#fff;color:#17362e;font-weight:800}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:20px;background:#10201b7a}.modal-card{width:min(680px,100%);max-height:min(760px,calc(100vh - 40px));overflow:auto;background:#fff;border:1px solid #dfe7df;border-radius:8px;box-shadow:0 24px 80px #0e27223d}.household-modal-card{width:min(1360px,100%);max-height:min(920px,calc(100vh - 24px))}.resident-modal-card{width:min(1180px,100%);max-height:min(900px,calc(100vh - 24px))}.resident-lookup-modal-card{width:min(900px,100%);max-height:min(760px,calc(100vh - 32px))}.resident-dashboard-edit-modal{width:min(1120px,100%);max-height:min(900px,calc(100vh - 24px))}.resident-dashboard-form{grid-template-columns:1fr;gap:16px}.modal-header{position:sticky;top:0;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;background:#fff;border-bottom:1px solid #e5ece5}.modal-header h3{margin:0;font-size:18px;letter-spacing:0}.modal-subtitle{margin:5px 0 0;color:#617168;font-size:13px}.lookup-required-note{width:fit-content;max-width:100%;display:flex;align-items:flex-start;gap:7px;margin-top:8px;padding:8px 10px;border:1px solid #efb2a5;border-radius:8px;background:#fff2f0;color:#b3261e;font-weight:900;line-height:1.45}.lookup-required-note svg{flex:0 0 auto;margin-top:1px;color:#b3261e}.lookup-required-note strong{color:#8f1d17;font-weight:1000}.modal-close{width:34px;height:34px;border:0;border-radius:8px;background:#eef3ef;color:#31443b;cursor:pointer;font-size:24px;line-height:1}.modal-body{padding:18px 20px 20px}.modal-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:18px 20px 20px}.household-modal-form{grid-template-columns:minmax(340px,420px) minmax(520px,1fr);align-items:start}.resident-modal-form{grid-template-columns:1fr;gap:16px}.household-residents-card{width:min(1080px,100%)}.household-form-fields{display:grid;grid-template-columns:1fr;gap:14px;min-width:0}.household-map-panel{display:grid;gap:7px;min-width:0}.map-panel-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.map-panel-title span{color:#52635a;font-size:13px;font-weight:700}.map-panel-title em{color:#a83d2d;font-size:13px;font-weight:700}.coordinate-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.modal-form label{display:grid;gap:7px;min-width:0}.modal-form label span{color:#52635a;font-size:13px;font-weight:700}.required-label:after{content:" *";color:#c6281c;font-weight:900}.modal-form input,.modal-form select,.modal-form textarea{width:100%;border:1px solid #cedbd1;border-radius:8px;padding:10px 12px;background:#fff;min-width:0}.password-field{position:relative;display:flex;align-items:center;min-width:0}.password-field input{padding-right:44px}.password-toggle{position:absolute;right:6px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:8px;background:transparent;color:#52635a;cursor:pointer}.password-toggle:hover{background:#eef3ef;color:#17362e}.modal-form input.invalid{border-color:#d99687;background:#fff7f5;box-shadow:0 0 0 3px #a83d2d1a}.modal-form input.valid{border-color:#8fbba9;background:#fbfffd;box-shadow:0 0 0 3px #1f654f14}.modal-form input:disabled,.modal-form select:disabled{background:#f2f5f2;color:#6a756e;cursor:not-allowed}.modal-form textarea{resize:vertical;min-height:88px}.modal-form .full-row{grid-column:1 / -1}.resident-lookup-card{display:grid;grid-template-columns:minmax(180px,.55fr) minmax(320px,1fr);gap:14px;align-items:center;padding:14px;border:1px solid #d8e4db;border-radius:8px;background:linear-gradient(135deg,#f7faf7,#fff);box-shadow:inset 0 1px #fffc}.quick-update-card{grid-template-columns:1fr;align-items:stretch;gap:12px;background:#fffdf9}.quick-update-card .resident-lookup-copy{grid-column:auto;padding-bottom:2px;border-bottom:1px solid #f0dfb8}.resident-lookup-copy{display:grid;gap:3px;min-width:0}.resident-lookup-title{display:flex;align-items:center;gap:9px;min-width:0}.resident-lookup-title svg{flex:0 0 auto;color:#1f654f}.resident-lookup-copy h4{margin:0;color:#17362e;font-size:15px;letter-spacing:0}.resident-lookup-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;min-width:0}.resident-lookup-controls.foreigner-lookup-controls{grid-template-columns:minmax(180px,.45fr) minmax(260px,1fr) auto}.resident-lookup-field{display:grid;gap:6px;min-width:0}.resident-lookup-field span{color:#52635a;font-size:12px;font-weight:900;text-transform:uppercase}.resident-lookup-controls input,.resident-lookup-controls select{width:100%;min-height:42px;border:1px solid #cbd9d0;border-radius:8px;padding:10px 12px;background:#fff;color:#17362e;font-weight:800;letter-spacing:0}.resident-lookup-controls input:focus,.resident-lookup-controls select:focus{outline:0;border-color:#1f654f;box-shadow:0 0 0 3px #1f654f1f}.resident-lookup-controls button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:8px;padding:10px 18px;background:#1f654f;color:#fff;font-weight:900;cursor:pointer;box-shadow:0 8px 18px #1f654f29;transition:background .15s ease,box-shadow .15s ease,transform .15s ease;white-space:nowrap}.resident-lookup-controls button svg{flex:0 0 auto}.resident-lookup-controls button:hover{background:#174d3e;box-shadow:0 10px 22px #1f654f33;transform:translateY(-1px)}.resident-lookup-controls button:disabled{opacity:.62;cursor:progress;transform:none}.resident-lookup-message{grid-column:1 / -1;margin:0;padding:10px 12px;border:1px solid #f0dfb8;border-radius:8px;background:#fffaf0;color:#7a5510;font-size:13px;font-weight:800;line-height:1.45}.resident-lookup-message.success{border-color:#b8d7c8;background:#eef8f2;color:#1f654f}.resident-document-lookup-panel{grid-column:1 / -1;display:grid;gap:11px;min-width:0;padding:13px;border:1px solid #cfe0d6;border-radius:8px;background:#f4faf6}.lookup-modal-panel{padding:14px;background:#fbfdfb}.resident-document-lookup-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.resident-document-lookup-title{display:flex;align-items:center;gap:8px;min-width:0;color:#17362e;font-size:14px;font-weight:900}.resident-document-lookup-title svg{flex:0 0 auto;color:#1f654f}.resident-document-lookup-panel .resident-lookup-controls button{align-self:end;min-width:96px;min-height:43px}.resident-household-link-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid #cfe0d6;border-radius:8px;background:#f4faf6}.resident-household-link-copy{display:grid;gap:6px;min-width:0}.resident-household-link-copy span{color:#52635a;font-size:12px;font-weight:900;text-transform:uppercase}.resident-household-link-copy strong{display:flex;align-items:flex-start;gap:8px;min-width:0;color:#17362e;font-size:15px;line-height:1.4;overflow-wrap:anywhere}.resident-household-link-copy svg{flex:0 0 auto;margin-top:1px;color:#1f654f}.resident-household-link-action{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;padding:10px 14px;background:#1f654f;color:#fff;font-weight:900;cursor:pointer;white-space:nowrap;box-shadow:0 8px 18px #1f654f29;transition:background .15s ease,box-shadow .15s ease,transform .15s ease}.resident-household-link-action:hover{background:#174d3e;box-shadow:0 10px 22px #1f654f33;transform:translateY(-1px)}.residence-history-card{display:grid;gap:13px;padding:14px;border:1px solid #d8e4db;border-radius:8px;background:#fbfdfb}.residence-history-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.residence-history-header>span{color:#617168;font-size:12px;font-weight:900;text-transform:uppercase}.residence-history-list{position:relative;display:grid;gap:10px}.residence-history-list:before{content:"";position:absolute;left:19px;top:12px;bottom:12px;width:2px;background:#dbe7df}.residence-history-item{position:relative;display:grid;grid-template-columns:40px minmax(0,1fr);gap:12px;align-items:start;padding:12px;border:1px solid #e2ebe4;border-radius:8px;background:#fff;box-shadow:0 8px 18px #17362e0a}.residence-history-icon{position:relative;z-index:1;width:40px;height:40px;display:grid;place-items:center;border:1px solid #cddbd2;border-radius:8px;background:#eef3ef;color:#52635a}.residence-history-icon.active{color:#17663d;background:#dff4e6;border-color:#a8dec0}.residence-history-icon.absent{color:#8b5400;background:#ffe5ad;border-color:#f3c96e}.residence-history-icon.deleted{color:#9a321f;background:#ffd7ce;border-color:#eba292}.residence-history-icon.moved-out,.residence-history-icon.expired{color:#52635a;background:#eef3ef;border-color:#cddbd2}.residence-history-main{display:grid;gap:9px;min-width:0}.residence-history-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.residence-history-title-row strong{min-width:0;color:#17362e;font-size:15px;line-height:1.35;overflow-wrap:anywhere}.residence-history-location-grid{display:grid;grid-template-columns:minmax(180px,.45fr) minmax(0,1fr);gap:8px}.residence-history-info-line{display:grid;grid-template-columns:18px auto minmax(0,1fr);gap:7px;align-items:start;min-width:0;padding:9px 10px;border:1px solid #dce9e0;border-radius:8px;background:#f8fbf9;color:#52635a;font-size:13px;line-height:1.4;overflow-wrap:anywhere}.residence-history-info-line svg{flex:0 0 auto;margin-top:1px;color:#1f654f}.residence-history-info-line span{color:#617168;font-weight:900;white-space:nowrap}.residence-history-info-line strong{min-width:0;color:#17362e;font-weight:900;overflow-wrap:anywhere}.residence-history-reason{display:flex;align-items:flex-start;gap:7px;min-width:0;color:#52635a;font-size:13px;font-weight:800;line-height:1.4;overflow-wrap:anywhere}.residence-history-reason{padding:9px 10px;border:1px solid #f0dfb8;border-radius:8px;background:#fffaf0;color:#7a5510}.residence-history-reason svg{flex:0 0 auto;margin-top:1px;color:#a06a08}.residence-history-details{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0}.residence-history-details div{display:grid;gap:4px;min-width:0;padding:9px 10px;border:1px solid #e6eee8;border-radius:8px;background:#f7faf7}.residence-history-details dt{color:#617168;font-size:11px;font-weight:900;text-transform:uppercase}.residence-history-details dd{margin:0;color:#17362e;font-size:13px;font-weight:900;overflow-wrap:anywhere}.quick-status-panel{display:grid;grid-template-columns:minmax(150px,.35fr) minmax(0,1fr) auto;gap:10px;align-items:center;min-width:0;padding:12px;border:1px solid #efc7bc;border-radius:8px;background:#fff7f4;box-shadow:inset 0 1px #fffc}.quick-status-panel input,.quick-status-panel select{width:100%;min-height:42px;border:1px solid #d99687;border-radius:8px;padding:10px 12px;background:#fff;color:#17362e;font-weight:800}.status-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:42px;padding:0 14px;border:1px solid #d99687;border-radius:8px;background:#b84b3a;color:#fff;font-weight:900;white-space:nowrap;cursor:pointer}.status-action:hover{background:#973928;box-shadow:0 8px 18px #a83d2d2e}.resident-type-toggle{display:inline-flex;align-items:center;justify-content:space-between;gap:14px;width:min(340px,100%);padding:12px 14px;border:1px solid #cfe0d6;border-radius:8px;background:#f6faf7;color:#17362e;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.resident-type-toggle:hover{border-color:#8fbba9;background:#eef8f2;box-shadow:0 8px 18px #1f654f1a}.resident-type-toggle.active{border-color:#1f654f;background:#e9f4ee}.section-resident-type-toggle{width:max-content;min-width:0;min-height:40px;display:inline-grid;grid-template-columns:auto max-content;justify-content:start;align-items:center;gap:10px;margin:0;padding:6px 10px;white-space:nowrap}.section-resident-type-toggle .toggle-switch{width:42px;height:24px}.section-resident-type-toggle .toggle-switch:after{top:3px;left:3px;width:18px;height:18px}.section-resident-type-toggle.active .toggle-switch:after{transform:translate(18px)}.section-resident-type-toggle .toggle-copy{display:block;white-space:nowrap}.lookup-resident-type-toggle{width:max-content;min-width:0;padding:7px 11px}.lookup-resident-type-toggle .toggle-switch{width:42px;height:24px}.lookup-resident-type-toggle .toggle-switch:after{top:3px;left:3px;width:18px;height:18px}.lookup-resident-type-toggle.active .toggle-switch:after{transform:translate(18px)}.lookup-resident-type-toggle .toggle-copy{display:block;white-space:nowrap}.resident-type-toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-copy{display:grid;gap:2px;color:inherit;font-size:13px}.toggle-copy strong{font-size:14px;line-height:1.2}.toggle-switch{position:relative;flex:0 0 auto;width:48px;height:28px;border-radius:999px;background:#b9c9bf;transition:background .15s ease}.toggle-switch:after{content:"";position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #10201b38;transition:transform .15s ease}.resident-type-toggle.active .toggle-switch{background:#1f654f}.resident-type-toggle.active .toggle-switch:after{transform:translate(20px)}.removal-toggle{width:100%}.form-section{display:grid;gap:12px;min-width:0;padding:14px;border:1px solid #e5ece5;border-radius:8px;background:#fbfdfb}.form-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.form-section h4{margin:0;color:#17362e;font-size:15px;letter-spacing:0}.form-section-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:start}.origin-registration-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid-placeholder{min-height:1px}.form-section-grid .full-width-field{grid-column:1 / -1}.form-section-grid .wide-field{grid-column:span 2}.notes-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.map-url-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.map-url-row button{border:0;border-radius:8px;padding:10px 12px;background:#1f654f;color:#fff;font-weight:800;cursor:pointer;white-space:nowrap}.map-url-row button:disabled{opacity:.5;cursor:not-allowed}.field-error{color:#a83d2d;font-size:12px;font-weight:700}.field-ok{color:#1f654f;font-size:12px;font-weight:800}.field-hint{color:#617168;font-size:12px;font-weight:700}.field-placeholder{visibility:hidden;font-size:12px;line-height:1.35}.success-message{padding:12px 14px;border:1px solid #b9d8c8;border-radius:8px;background:#edf8f2;color:#1f654f;font-size:14px;font-weight:800}.profile-modal-card{width:min(860px,100%);max-height:min(820px,calc(100vh - 40px))}.profile-form{grid-template-columns:1fr;gap:14px;padding:18px 20px 20px}.profile-form-section{display:grid;gap:12px;padding:14px;border:1px solid #e5ece5;border-radius:8px;background:#fbfdfb}.profile-form-section h4{margin:0;color:#17362e;font-size:15px;letter-spacing:0}.profile-field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;align-items:start}.profile-field-grid label{display:grid;grid-template-rows:auto 42px minmax(17px,auto);gap:7px;min-width:0}.profile-field-grid label>span{color:#52635a;font-size:13px;font-weight:700}.profile-field-grid input,.profile-field-grid .password-field{height:42px}.profile-readonly-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.profile-readonly{display:grid;gap:7px;min-width:0;padding:12px;border:1px solid #e5ece5;border-radius:8px;background:#f7faf7}.profile-readonly-wide{grid-column:1 / -1}.profile-readonly span{color:#52635a;font-size:13px;font-weight:700}.profile-readonly strong{color:#17362e;font-size:15px;line-height:1.35;overflow-wrap:anywhere}.resident-quick-modal{width:min(920px,100%);max-height:min(860px,calc(100vh - 40px))}.resident-quick-body,.resident-lookup-modal-body{display:grid;gap:14px;padding:18px 20px 20px}.lookup-modal-actions{padding:0}.resident-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.resident-quick-grid div{display:grid;gap:6px;min-width:0;padding:11px 12px;border:1px solid #e5ece5;border-radius:8px;background:#f7faf7}.resident-quick-grid span{color:#52635a;font-size:12px;font-weight:900;text-transform:uppercase}.resident-quick-grid strong{min-width:0;color:#17362e;font-size:14px;line-height:1.35;overflow-wrap:anywhere}.resident-quick-grid .resident-quick-wide{grid-column:1 / -1}.resident-quick-note{margin:0;color:#31443b;font-size:14px;line-height:1.55}.map-picker{position:relative;min-height:460px;border:1px solid #cedbd1;border-radius:8px;overflow:hidden;background:#eef3ef}.map-picker-canvas{width:100%;height:460px;border:0;display:block}.country-modal-form{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:10px;padding-top:10px;border-top:1px solid #e5ece5}.modal-actions button{min-height:40px;border:0;border-radius:8px;padding:10px 16px;font-weight:800;cursor:pointer;white-space:nowrap;transition:background .15s ease,box-shadow .15s ease,transform .15s ease}.modal-actions button:hover{transform:translateY(-1px)}.modal-actions button:disabled{opacity:.48;cursor:not-allowed;transform:none;box-shadow:none}.modal-actions .cancel{background:#eef3ef;color:#31443b}.modal-actions .cancel:hover{background:#dfe9e2}.modal-actions .primary-action{background:#1f654f;color:#fff;box-shadow:0 8px 18px #1f654f2e}.modal-actions .primary-action:hover{background:#174d3e;box-shadow:0 10px 22px #1f654f38}.duplicate-move-backdrop{z-index:80;padding:18px;background:#0a1b169e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.duplicate-move-modal{width:min(840px,100%);max-height:min(860px,calc(100vh - 36px));overflow:auto;border-color:#d9c078;box-shadow:0 30px 90px #0a1b1657}.duplicate-move-header{display:grid;grid-template-columns:auto minmax(0,1fr);gap:16px;align-items:center;padding:24px 26px 20px;background:linear-gradient(135deg,#fff8e7,#fff 58%,#eef8f2);border-bottom:1px solid #ead9a9}.duplicate-move-header.danger-header{background:linear-gradient(135deg,#fff2f0,#fff 58%,#fff8f6);border-bottom-color:#efb2a5}.duplicate-move-icon{width:58px;height:58px;border-radius:8px;display:grid;place-items:center;background:#fff1c8;color:#94650b;border:1px solid #e8c46b;box-shadow:0 10px 22px #94650b24}.duplicate-move-icon.danger-icon{background:#ffe4df;color:#b3261e;border-color:#efb2a5;box-shadow:0 10px 22px #b3261e1f}.duplicate-move-header h3{margin:0;color:#17362e;font-size:26px;line-height:1.16;letter-spacing:0}.duplicate-move-header p{margin:7px 0 0;color:#52635a;font-size:15px;line-height:1.45}.duplicate-move-header p strong{color:#17362e;font-weight:900}.duplicate-person-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:20px 26px 0}.duplicate-person-summary div{display:grid;gap:5px;padding:14px;border:1px solid #e5ece5;border-radius:8px;background:#fbfdfb}.duplicate-person-summary span,.duplicate-address-panel span{color:#617168;font-size:12px;font-weight:900;line-height:1.2;text-transform:uppercase}.duplicate-person-summary strong{min-width:0;overflow-wrap:anywhere;color:#17362e;font-size:17px;line-height:1.25}.duplicate-move-route{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:14px;align-items:stretch;padding:18px 26px}.duplicate-address-panel{display:grid;align-content:start;gap:10px;min-width:0;padding:16px;border:1px solid #dfe7df;border-radius:8px;background:#f7faf7}.duplicate-address-panel.target{border-color:#a9c9ba;background:#edf8f2;box-shadow:inset 0 0 0 1px #1f654f0f}.duplicate-residence-segments{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.duplicate-residence-segments span,.duplicate-residence-segments button{min-height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #d8e4db;border-radius:8px;background:#fff;color:#6a756e;font-size:13px;font-weight:900;line-height:1}.duplicate-residence-segments button{cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease}.duplicate-residence-segments button:hover{border-color:#8fbba9;background:#f6faf7;transform:translateY(-1px)}.duplicate-residence-segments span.active,.duplicate-residence-segments button.active{border-color:#d7a84d;background:#fff6df;color:#17362e;box-shadow:inset 0 0 0 1px #d7a84d2e}.duplicate-residence-segments.target button.active{border-color:#1f654f;background:#1f654f;color:#fff;box-shadow:0 8px 18px #1f654f29}.duplicate-residence-badge{min-height:34px;width:max-content;max-width:100%;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:1px solid #d7a84d;border-radius:8px;background:#fff6df;color:#17362e;font-size:13px;font-weight:900;line-height:1}.duplicate-residence-badge.temporary{border-color:#86b6dc;background:#eef7ff;color:#164f7c}.duplicate-address-panel strong{display:flex;align-items:flex-start;gap:8px;min-width:0;color:#17362e;font-size:15px;line-height:1.45;overflow-wrap:anywhere}.duplicate-address-panel svg{flex:0 0 auto;margin-top:1px;color:#1f654f}.duplicate-route-arrow{align-self:center;width:44px;height:44px;border-radius:8px;display:grid;place-items:center;background:#17362e;color:#fff;box-shadow:0 10px 22px #17362e2e}.duplicate-move-note{margin:0 26px 20px;padding:13px 14px;border:1px solid #f0dfb8;border-radius:8px;background:#fffaf0;color:#6c4c10;font-size:14px;font-weight:800;line-height:1.45}.duplicate-move-note.danger-note{border-color:#efb2a5;background:#fff2f0;color:#8f1d17}.duplicate-move-actions{padding:16px 26px 22px}.duplicate-move-actions button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;font-size:14px}.duplicate-move-actions .primary-action{padding-inline:18px}.duplicate-move-actions .danger-confirm-action{background:#b3261e;box-shadow:0 8px 18px #b3261e2e}.duplicate-move-actions .danger-confirm-action:hover{background:#8f1d17;box-shadow:0 10px 22px #b3261e38}.household-sold-modal{width:min(760px,100%)}.household-sold-body{display:grid;padding:18px 26px}.head-replacement-modal{width:min(760px,100%)}.head-replacement-body{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(260px,.9fr);gap:14px;align-items:stretch;padding:18px 26px}.head-replacement-field{display:grid;gap:8px;min-width:0;padding:16px;border:1px solid #dfe7df;border-radius:8px;background:#fbfdfb}.head-replacement-field>span{color:#31443b;font-size:13px;font-weight:900}.head-replacement-field select{width:100%;min-height:42px;border:1px solid #cedbd1;border-radius:8px;padding:9px 12px;background:#fff;color:#17362e;font:inherit;font-weight:800}.head-replacement-field textarea{width:100%;min-height:112px;border:1px solid #cedbd1;border-radius:8px;padding:10px 12px;background:#fff;color:#17362e;font:inherit;font-weight:800;resize:vertical}@media(max-width:1200px){.origin-registration-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:860px){.login-page{padding:16px;background:linear-gradient(180deg,#0c332c,#14513f 34%,#8b1820 34%,#f7efd9 58%,#fffaf0)}.login-shell{min-height:0;grid-template-columns:1fr}.login-visual{min-height:280px;padding:24px;border-right:0;border-bottom:1px solid #eadfbf}.login-visual-badge{width:min(280px,84%)}.login-visual h1{font-size:30px}.login-visual p{font-size:15px}.login-card{padding:26px 22px 24px}.login-card h2{font-size:25px}.shell,.shell.sidebar-collapsed{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:10;flex-direction:row;align-items:center;overflow-x:auto;padding:12px}.sidebar-collapsed .sidebar{padding:12px;align-items:center}.sidebar-collapsed .brand{width:auto}.brand-text,.nav-item span,.sidebar-toggle span{display:none}.sidebar-toggle{margin-top:0;width:42px;flex:0 0 42px;padding:0}.nav{display:flex}.content{padding:18px 14px 30px}.topbar{align-items:flex-start;flex-direction:column}.topbar-user-menu{width:100%;justify-content:flex-start}.user-chip{text-align:left}.user-dropdown{left:0;right:auto}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero{flex-direction:column;padding:20px}.dashboard-hero-metrics{min-width:0}.dashboard-kpis{grid-template-columns:repeat(6,minmax(0,1fr));gap:4px}.dashboard-kpi{padding:8px 4px;gap:3px}.dashboard-kpi-icon{width:22px;height:22px}.dashboard-kpi span{font-size:9px}.dashboard-kpi strong{font-size:15px}.dashboard-kpi em{display:none}.dashboard-insight-grid{grid-template-columns:1fr}.pie-chart-block,.pie-chart-block.wide{grid-template-columns:1fr;justify-items:start}.inline-form{grid-template-columns:1fr}.tabs{overflow-x:auto;flex-wrap:nowrap}.tabs button{white-space:nowrap}.filterbar{display:grid;grid-template-columns:1fr}.filterbar .search,.filter-action{width:100%}.resident-filterbar{padding:12px}.resident-filterbar-header{align-items:stretch;flex-direction:column}.resident-filter-grid{grid-template-columns:1fr}.filter-field-wide{grid-column:auto}.resident-filter-reset{width:100%}.form-section-header{align-items:stretch;flex-direction:column}.section-resident-type-toggle{width:100%;justify-content:space-between}.resident-document-lookup-header{align-items:stretch;flex-direction:column}.lookup-resident-type-toggle{width:100%;justify-content:space-between;margin-left:0}.paginationbar{align-items:stretch;flex-direction:column}.paginationbar div{display:grid;grid-template-columns:1fr 1fr}.modal-form,.country-modal-form,.household-modal-form,.resident-modal-form,.form-section-grid,.notes-grid{grid-template-columns:1fr}.form-section-grid .full-width-field,.form-section-grid .wide-field{grid-column:auto}.profile-field-grid,.profile-readonly-grid{grid-template-columns:1fr}.profile-readonly-wide{grid-column:auto}.resident-quick-grid{grid-template-columns:1fr}.resident-quick-grid .resident-quick-wide{grid-column:auto}.resident-lookup-card,.quick-update-card,.resident-lookup-controls,.resident-lookup-controls.foreigner-lookup-controls,.quick-status-panel,.resident-household-link-card,.residence-history-location-grid,.residence-history-details{grid-template-columns:1fr}.residence-history-title-row{align-items:flex-start;flex-direction:column}.resident-household-link-action,.resident-lookup-controls button{width:100%}.map-picker{min-height:340px}.map-picker-canvas{height:340px}.modal-actions{justify-content:stretch}.modal-actions button{flex:1}.duplicate-move-header{grid-template-columns:1fr;padding:20px}.duplicate-move-header h3{font-size:22px}.duplicate-person-summary,.duplicate-move-route{grid-template-columns:1fr;padding-inline:20px}.head-replacement-body{grid-template-columns:1fr;padding:16px 20px}.duplicate-route-arrow{justify-self:center;transform:rotate(90deg)}.duplicate-move-note{margin-inline:20px}.duplicate-move-actions{padding-inline:20px}}@media(max-width:560px){.resident-modal-card{max-height:calc(100dvh - 16px)}.resident-modal-form{gap:12px;padding:14px}.resident-lookup-card{gap:12px;padding:12px;border-color:#b8d7c8;background:#fbfffc;box-shadow:0 8px 22px #1f654f14}.resident-lookup-title{align-items:flex-start}.resident-lookup-title svg{margin-top:1px}.resident-lookup-copy h4{font-size:14px;line-height:1.3}.resident-lookup-controls{gap:8px}.resident-lookup-field{gap:5px}.field-error,.field-ok{line-height:1.35}.resident-lookup-controls input,.resident-lookup-controls select,.resident-lookup-controls button{min-height:46px;font-size:14px}.resident-lookup-message{padding:9px 10px;font-size:12.5px;line-height:1.45}.duplicate-move-backdrop{align-items:end;justify-items:center;padding:10px 10px 0}.duplicate-move-modal{width:100%;max-height:calc(100dvh - 10px);border-radius:8px 8px 0 0;box-shadow:0 -18px 50px #0a1b1652}.duplicate-move-header{grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:start;padding:15px 14px 13px}.duplicate-move-icon{width:44px;height:44px}.duplicate-move-icon svg{width:24px;height:24px}.duplicate-move-header h3{font-size:20px;line-height:1.2}.duplicate-move-header p{margin-top:5px;font-size:13px;line-height:1.45}.duplicate-person-summary{gap:8px;padding:12px 14px 0}.duplicate-person-summary div{padding:11px 12px}.duplicate-person-summary span,.duplicate-address-panel span{font-size:11px}.duplicate-person-summary strong{font-size:15px;line-height:1.3}.duplicate-move-route{gap:9px;padding:12px 14px}.duplicate-address-panel{gap:8px;padding:12px}.duplicate-address-panel strong{font-size:13.5px;line-height:1.45}.duplicate-residence-segments{gap:6px}.duplicate-residence-segments span,.duplicate-residence-segments button{min-height:40px;font-size:12.5px}.duplicate-route-arrow{width:34px;height:34px}.duplicate-route-arrow svg{width:18px;height:18px}.duplicate-move-note{margin:0 14px 12px;padding:10px 11px;font-size:12.5px;line-height:1.45}.duplicate-move-actions{flex-direction:column-reverse;gap:8px;padding:12px 14px 14px}.duplicate-move-actions button{flex:none;width:100%;min-height:48px;font-size:13.5px}}
