:root{
    --bg:#f4f6fb;
    --panel:#ffffff;
    --text:#1f2937;
    --muted:#6b7280;
    --primary:#4457ff;
    --primary2:#6d79ff;
    --dark:#111827;
    --line:#e5e7eb;
    --shadow:0 18px 45px rgba(15,23,42,.08);
    --radius:22px;
}
*{box-sizing:border-box}
body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif}
a{text-decoration:none}.text-muted{color:var(--muted)!important}
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background:radial-gradient(circle at top left,#eef2ff 0,#f8fafc 42%,#eef2ff 100%)}
.auth-card{width:100%;max-width:470px;background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow);border-radius:28px;padding:34px}.auth-card h1{font-size:30px;font-weight:800;margin:22px 0 8px}.auth-logo{display:flex;align-items:center;gap:12px}.auth-logo span,.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:15px;background:linear-gradient(135deg,var(--primary),#7c3aed);color:white;font-weight:800;box-shadow:0 10px 25px rgba(68,87,255,.25)}.auth-logo small,.brand small{display:block;color:var(--muted);font-size:12px}.form-control,.form-select{border-radius:14px;border-color:#d9deea;padding:.72rem .9rem}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .22rem rgba(68,87,255,.13);border-color:var(--primary2)}.btn{border-radius:13px;font-weight:700}.btn-primary{background:linear-gradient(135deg,var(--primary),#6d5dfc);border:0;box-shadow:0 10px 22px rgba(68,87,255,.18)}.btn-dark{background:#111827;border:0}.btn-light{background:#fff;border-color:#eef2ff}
.app-shell{display:flex;min-height:100vh}.app-sidebar{position:sticky;top:0;width:286px;min-width:286px;height:100vh;background:#0f172a;color:white;padding:22px 18px;overflow:auto}.brand{display:flex;align-items:center;gap:12px;color:white;margin-bottom:24px}.brand:hover{color:white}.brand strong{display:block;line-height:1.05}.side-nav{display:flex;flex-direction:column;gap:6px}.side-nav .nav-link{display:flex;align-items:center;gap:10px;color:#cbd5e1;border-radius:16px;padding:11px 13px;font-weight:650}.side-nav .nav-link:hover{background:rgba(255,255,255,.08);color:white}.side-nav .nav-link.active{background:linear-gradient(135deg,#4655ff,#7c3aed);color:white;box-shadow:0 12px 24px rgba(68,87,255,.22)}.nav-ico{display:inline-flex;align-items:center;justify-content:center;width:24px;opacity:.9}.app-main{flex:1;padding:24px 28px 38px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;background:rgba(255,255,255,.82);backdrop-filter:blur(12px);border:1px solid #fff;border-radius:24px;padding:18px 20px;box-shadow:0 12px 36px rgba(15,23,42,.06)}.topbar h1{font-size:26px;font-weight:850;margin:0}.topbar p{margin:3px 0 0;color:var(--muted)}.topbar-actions{display:flex;gap:8px;align-items:center}.clean-card,.card.border-0.shadow-sm{border:0!important;border-radius:var(--radius)!important;box-shadow:var(--shadow)!important;background:var(--panel)}.clean-card .card-body,.card.border-0.shadow-sm .card-body{padding:22px}.clean-card h3,.card h3{font-size:20px;font-weight:820;margin-bottom:14px}.hero-card{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#111827,#28354f);color:white;border-radius:28px;padding:26px 28px;box-shadow:var(--shadow);overflow:hidden;position:relative}.hero-card:after{content:"";position:absolute;right:-60px;top:-90px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.12)}.hero-card h2{font-size:28px;font-weight:850;margin:0 0 8px}.hero-card p{margin:0;color:#dbeafe}.hero-actions{display:flex;gap:10px;z-index:1}.metric-card{height:100%;background:white;border-radius:22px;padding:18px 18px;box-shadow:var(--shadow);border:1px solid #fff}.metric-card span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#eef2ff;color:var(--primary);font-size:20px;margin-bottom:14px}.metric-card small{display:block;color:var(--muted);font-weight:650}.metric-card strong{display:block;font-size:28px;line-height:1.1;margin-top:4px}.dorm-tile{border:1px solid var(--line);border-radius:18px;padding:18px;height:100%;background:linear-gradient(180deg,#fff,#f8fafc)}.dorm-tile h4{font-size:18px;font-weight:800}.dorm-tile p{min-height:38px;color:var(--muted);margin-bottom:6px}.timeline-item,.audit-item{padding:12px 0;border-bottom:1px solid var(--line)}.timeline-item:last-child,.audit-item:last-child{border-bottom:0}.timeline-item small,.audit-item small{display:block;color:var(--muted);margin-bottom:3px}.content-narrow{max-width:820px}.profile-panel{background:linear-gradient(135deg,#4457ff,#7c3aed);color:white;border-radius:28px;padding:28px;box-shadow:var(--shadow)}.profile-panel h2{font-weight:850;margin:0}.profile-panel p{color:#e0e7ff}.resident-room{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:16px}.resident-room small,.resident-room span{display:block;color:#dbeafe}.resident-room strong{display:block;font-size:19px}.quick-card{display:block;height:100%;background:white;border-radius:22px;padding:22px;box-shadow:var(--shadow);color:var(--text);border:1px solid #fff}.quick-card:hover{transform:translateY(-2px);color:var(--text)}.quick-card span{display:grid;place-items:center;width:44px;height:44px;border-radius:16px;background:#eef2ff;color:var(--primary);font-size:22px;margin-bottom:14px}.quick-card strong{display:block;font-size:19px}.quick-card small{color:var(--muted)}.list-line{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line)}.list-line:last-child{border-bottom:0}.list-line small{display:block;color:var(--muted)}.notice{border:1px solid var(--line);border-radius:18px;padding:15px;margin-bottom:12px;background:#fff}.notice.unread{border-color:#a5b4fc;background:#f5f7ff}.notice p{margin:8px 0;color:#374151}.table{--bs-table-bg:transparent}.table thead th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line)}.table td{border-color:#edf0f5}.badge.text-bg-purple{background:#7c3aed;color:#fff}.floor-map-wrap{position:relative;width:100%;border-radius:22px;overflow:hidden;background:#f8fafc;border:1px solid var(--line)}.floor-plan-img{display:block;width:100%;height:auto}.floor-map-svg{position:absolute;inset:0;width:100%;height:100%}.map-room{fill:rgba(34,197,94,.35);stroke:rgba(21,128,61,.95);stroke-width:.004;transition:.15s}.map-room:hover{fill:rgba(68,87,255,.42);stroke:#1d4ed8}.map-room-success{fill:rgba(34,197,94,.36);stroke:#16a34a}.map-room-warning{fill:rgba(245,158,11,.42);stroke:#d97706}.map-room-primary{fill:rgba(68,87,255,.36);stroke:#3947d7}.map-room-danger{fill:rgba(239,68,68,.36);stroke:#dc2626}.map-room-secondary{fill:rgba(107,114,128,.34);stroke:#4b5563}.map-room-purple{fill:rgba(124,58,237,.35);stroke:#7c3aed}.map-label{font-size:.034px;font-weight:800;fill:#111827;paint-order:stroke;stroke:#fff;stroke-width:.006px;pointer-events:none}.legend{display:grid;gap:8px}.legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px}.map-editor-toolbar{position:sticky;top:16px;z-index:2}.rect-preview{fill:rgba(68,87,255,.25);stroke:#4457ff;stroke-width:.004}.progress{height:10px;border-radius:999px;background:#edf2f7}.progress-bar{background:linear-gradient(135deg,var(--primary),#7c3aed)}.install-bg{background:radial-gradient(circle at top left,#eef2ff 0,#f8fafc 46%,#eef2ff 100%)}
@media (max-width:991px){.app-sidebar{display:none}.app-main{padding:16px}.topbar{align-items:flex-start}.topbar-actions{margin-left:auto}.hero-card{display:block}.hero-actions{margin-top:16px}.metric-card strong{font-size:23px}}
@media (max-width:575px){.topbar{flex-wrap:wrap}.topbar h1{font-size:22px}.hero-actions{flex-direction:column}.auth-card{padding:24px}.table{font-size:14px}}
.map-preview{fill:rgba(68,87,255,.25);stroke:#4457ff;stroke-width:.004;stroke-dasharray:.01 .008}
.text-bg-primary{background:#4457ff!important;color:#fff!important}.text-bg-secondary{background:#64748b!important;color:#fff!important}.text-bg-success{background:#16a34a!important;color:#fff!important}.text-bg-danger{background:#dc2626!important;color:#fff!important}.text-bg-warning{background:#f59e0b!important;color:#111827!important}.text-bg-info{background:#0ea5e9!important;color:#fff!important}.text-bg-light{background:#f8fafc!important;color:#111827!important}.text-bg-dark{background:#111827!important;color:#fff!important}
.brand-logo{width:44px;height:44px;object-fit:contain;border-radius:12px;background:#fff;padding:4px}.bell-btn{position:relative}.bell-count{position:absolute;top:-7px;right:-7px;min-width:19px;height:19px;border-radius:999px;background:#dc2626;color:#fff;font-size:11px;display:grid;place-items:center;padding:0 5px}.notification-menu{min-width:280px;border:0;border-radius:18px;box-shadow:var(--shadow)}.mini-notice{border-bottom:1px solid var(--line);padding:8px 0}.mini-notice small{color:var(--muted)}.floor-map-scroll{overflow:auto;border-radius:22px;background:#e5e7eb;padding:10px;max-height:75vh}.zoomable-map{min-width:720px;transition:width .15s}.map-toolbar{display:flex;align-items:center;gap:10px}.map-zoom-range{max-width:260px}.map-room{fill-opacity:.82!important;stroke-width:.006!important;cursor:pointer;mix-blend-mode:normal}.map-room-success{fill:rgba(22,163,74,.82)!important;stroke:#065f46!important}.map-room-warning{fill:rgba(245,158,11,.86)!important;stroke:#92400e!important}.map-room-primary{fill:rgba(37,99,235,.82)!important;stroke:#1e3a8a!important}.map-room-danger{fill:rgba(220,38,38,.82)!important;stroke:#7f1d1d!important}.map-room-secondary{fill:rgba(75,85,99,.78)!important;stroke:#111827!important}.map-room-purple{fill:rgba(124,58,237,.82)!important;stroke:#4c1d95!important}.map-label{font-size:.04px;stroke-width:.009px}.room-popover{display:none;position:absolute;z-index:5;min-width:230px;max-width:310px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 45px rgba(15,23,42,.18);padding:14px}.room-popover.show{display:block}.room-popover p{margin:5px 0 12px;color:var(--muted)}.file-preview-body{min-height:300px;display:grid;place-items:center}.pdf-preview{width:100%;height:72vh;border:0;border-radius:12px;background:#f8fafc}.file-icon{font-size:22px;display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:12px;background:#f1f5f9;margin-right:8px}.password-strength{height:8px;border-radius:999px;background:#e5e7eb;overflow:hidden}.password-strength div{height:100%;width:0;transition:.2s}.password-strength .weak{background:#dc2626}.password-strength .medium{background:#f59e0b}.password-strength .strong{background:#16a34a}.filter-card{background:#fff;border-radius:18px;padding:16px;box-shadow:var(--shadow);margin-bottom:16px}.announcement-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff;margin-bottom:12px}.announcement-card.public{border-color:#bfdbfe;background:#eff6ff}.pagination .page-link{border-radius:10px;margin:0 2px;border-color:#e5e7eb;color:var(--primary)}.pagination .active .page-link{background:var(--primary);border-color:var(--primary)}

.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}
.nav-group{margin-top:4px}.nav-group-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:transparent;border:0;color:#94a3b8;padding:10px 12px 6px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.nav-group-items{display:flex;flex-direction:column;gap:5px}.mobile-sidebar{background:#0f172a;color:#fff}.mobile-sidebar .offcanvas-header{border-bottom:1px solid rgba(255,255,255,.08)}.mobile-sidebar .side-nav .nav-link,.side-nav.mobile .nav-link{color:#e5e7eb}.mobile-sidebar .nav-group-toggle{color:#cbd5e1}.mobile-sidebar .btn-close{filter:none}.floor-map-scroll{cursor:grab;touch-action:none;user-select:none}.floor-map-scroll.dragging{cursor:grabbing}.floor-map-scroll.is-zoomed{box-shadow:inset 0 0 0 2px rgba(68,87,255,.12)}.map-room{fill-opacity:1!important;stroke-width:.008!important;filter:drop-shadow(0 2px 2px rgba(0,0,0,.22))}.map-room-success{fill:#16a34a!important}.map-room-warning{fill:#f59e0b!important}.map-room-primary{fill:#2563eb!important}.map-room-danger{fill:#dc2626!important}.map-room-secondary{fill:#4b5563!important}.map-room-purple{fill:#7c3aed!important}.map-label{fill:#fff!important;stroke:#111827!important;stroke-width:.012px!important}.room-popover{pointer-events:auto}.badge.text-bg-purple{background:#7c3aed!important;color:#fff!important}
@media (max-width:991px){.offcanvas.mobile-sidebar{width:310px}.side-nav.mobile{gap:8px}.side-nav.mobile .nav-link{background:rgba(255,255,255,.06);color:#fff!important}.side-nav.mobile .nav-link.active{background:linear-gradient(135deg,#4655ff,#7c3aed)}.floor-map-scroll{max-height:68vh}.zoomable-map{min-width:920px}.topbar-actions{width:100%;justify-content:flex-end}.topbar{gap:10px}}
@media print{.app-sidebar,.topbar,.btn,.pagination,.filter-card{display:none!important}.app-main{padding:0}.card{box-shadow:none!important}}


/* V4.1 fixes: notification dropdown visibility and collapsed sidebar groups */
.topbar{position:relative;z-index:1200;overflow:visible!important}
.topbar .dropdown{position:relative;z-index:1300}
.notification-menu{z-index:2000!important;position:absolute!important}
.app-main,.app-shell{overflow:visible}
.nav-group-items{display:none!important;flex-direction:column;gap:5px}
.nav-group.open .nav-group-items{display:flex!important}
.nav-group-toggle{cursor:pointer;border-radius:12px}
.nav-group-toggle:hover{background:rgba(68,87,255,.08);color:#e2e8f0}
.app-sidebar .nav-group-toggle:hover{background:rgba(255,255,255,.06)}
.nav-group-toggle span{display:inline-block;transition:transform .18s ease}
.nav-group.open .nav-group-toggle span{transform:rotate(180deg)}
.mobile-sidebar{z-index:1800}
.mobile-sidebar .offcanvas-body{overflow-y:auto}
.mobile-sidebar .nav-group-toggle:hover{background:rgba(255,255,255,.08);color:#fff}
@media (max-width:991px){.topbar{position:relative;z-index:1200}.notification-menu{min-width:min(320px, calc(100vw - 32px))}}

/* V5 interface stabilization */
.breadcrumb-strip{display:flex;align-items:center;gap:8px;margin:-8px 0 18px;color:var(--muted);font-size:14px}.breadcrumb-strip a{color:var(--muted)}.breadcrumb-strip span:last-child{color:var(--text);font-weight:700}.actions-bar{display:flex;gap:8px;flex-wrap:wrap}.empty-state{border:1px dashed #cbd5e1;border-radius:18px;padding:24px;text-align:center;color:var(--muted);background:#f8fafc}.btn-group.flex-wrap>.btn{margin-bottom:4px}.card-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.quick-actions{display:flex;gap:8px;flex-wrap:wrap}
.map-toolbar .btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.map-editor .floor-map-svg{cursor:crosshair}.floor-map-scroll[data-map-mode="pan"] .floor-map-svg{cursor:grab}.floor-map-scroll[data-map-mode="pan"].dragging .floor-map-svg{cursor:grabbing}.map-preview{fill:rgba(68,87,255,.35);stroke:#111827;stroke-width:.006;stroke-dasharray:.012 .008}.map-preview-polygon{fill:rgba(68,87,255,.25);stroke:#111827;stroke-width:.006;stroke-dasharray:.012 .008}.map-area-service{fill:#64748b!important;stroke:#111827!important}.map-area-kitchen{fill:#06b6d4!important;stroke:#075985!important}.map-area-bathroom{fill:#0ea5e9!important;stroke:#075985!important}.map-area-other{fill:#a855f7!important;stroke:#581c87!important}.map-hidden{display:none!important}.map-highlight .map-room{filter:drop-shadow(0 0 8px rgba(250,204,21,.95)) drop-shadow(0 2px 2px rgba(0,0,0,.22));stroke:#facc15!important;stroke-width:.012!important}.map-label{pointer-events:none}.map-layer-panel{display:grid;gap:8px}.map-layer-panel .form-check{margin:0}.floor-map-scroll.editing{outline:2px solid rgba(68,87,255,.18)}
.map-room-success{fill:var(--map-success,#16a34a)!important}.map-room-warning{fill:var(--map-warning,#f59e0b)!important}.map-room-primary{fill:var(--map-primary,#2563eb)!important}.map-room-danger{fill:var(--map-danger,#dc2626)!important}.map-room-secondary{fill:var(--map-secondary,#4b5563)!important}.map-room-purple{fill:var(--map-purple,#7c3aed)!important}
@media (max-width:575px){.table-responsive.table-card-mobile{overflow:visible}.table-responsive.table-card-mobile table,.table-responsive.table-card-mobile thead,.table-responsive.table-card-mobile tbody,.table-responsive.table-card-mobile th,.table-responsive.table-card-mobile td,.table-responsive.table-card-mobile tr{display:block}.table-responsive.table-card-mobile thead{display:none}.table-responsive.table-card-mobile tr{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:10px;padding:10px;box-shadow:0 8px 20px rgba(15,23,42,.05)}.table-responsive.table-card-mobile td{border:0!important;display:flex;justify-content:space-between;gap:12px;padding:7px 2px}.table-responsive.table-card-mobile td:before{content:attr(data-label);font-weight:800;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.table-responsive.table-card-mobile td.text-end{text-align:left!important}.topbar .btn{white-space:nowrap}.actions-bar .btn{width:100%}}

/* V6 autocomplete */
.resident-search,.place-search{position:relative}.resident-search-results,.place-search-results{display:none;position:absolute;z-index:2100;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 45px rgba(15,23,42,.18);overflow:hidden;max-height:280px;overflow-y:auto}.resident-search-results.show,.place-search-results.show{display:block}.resident-search-item,.place-search-item{display:block;width:100%;text-align:left;background:#fff;border:0;border-bottom:1px solid var(--line);padding:10px 12px}.resident-search-item:hover,.place-search-item:hover{background:#f8fafc}.resident-search-item small,.place-search-item small{display:block;color:var(--muted)}.resident-search-empty{padding:12px;color:var(--muted)}
.help-article h3{font-size:18px;margin-bottom:4px}.help-body{line-height:1.6;color:#374151}.help-role-list{max-height:220px;overflow:auto;background:#f8fafc}.map-label{font-size:.033px!important;font-weight:900!important;letter-spacing:0!important}

/* V6.2: room popup on floor scheme */
.floor-room-popover{
  position:fixed!important;
  z-index:2500!important;
  display:none;
  width:min(360px, calc(100vw - 28px));
  max-width:360px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  box-shadow:0 24px 70px rgba(15,23,42,.28);
  padding:16px;
  backdrop-filter:blur(14px);
}
.floor-room-popover.show{display:block;animation:popoverIn .12s ease-out}
@keyframes popoverIn{from{opacity:.4;transform:translateY(4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.room-popover-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.room-popover-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:800;color:var(--muted);margin-bottom:3px}
.floor-room-popover .room-title{display:block;font-size:18px;line-height:1.15;color:#0f172a}
.room-popover-status{display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap;background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:10px 12px;margin-bottom:12px}
.status-pill{display:inline-flex;align-items:center;border-radius:999px;background:#eef2ff;color:#3947d7;font-weight:800;font-size:12px;padding:4px 9px;white-space:nowrap}
.room-body{color:#475569;font-size:13px;line-height:1.35;padding-top:3px}
.room-popover-residents{border-top:1px solid var(--line);padding-top:12px}
.resident-list{display:flex;flex-direction:column;gap:6px;max-height:170px;overflow:auto;padding-right:2px}
.resident-chip{border-radius:12px;background:#f1f5f9;color:#0f172a;padding:7px 9px;font-size:13px;font-weight:650}
.map-room-group{outline:none}.map-room-group:focus .map-room{stroke:#fff!important;filter:drop-shadow(0 0 10px rgba(37,99,235,.9)) drop-shadow(0 2px 2px rgba(0,0,0,.22))}
@media (max-width: 575.98px){.floor-room-popover{left:14px!important;right:14px!important;top:auto!important;bottom:14px!important;width:auto;max-width:none}.resident-list{max-height:130px}}

/* V7 fixes and stabilization */
.floor-map-svg{z-index:2;pointer-events:auto}.floor-plan-img{position:relative;z-index:1}.map-room-group{cursor:pointer;pointer-events:all}.map-room-group .map-room{pointer-events:all}.floor-map-scroll[data-map-mode="draw"]{cursor:crosshair}.floor-map-scroll[data-map-mode="pan"]{cursor:grab}.floor-map-scroll[data-map-mode="pan"].dragging{cursor:grabbing}.map-legend-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;display:grid;gap:8px}.settle-step{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff;margin-bottom:12px}.print-only{display:none}.import-preview-table tr.duplicate td{background:#fff7ed}.import-preview-table tr.ready td{background:#f0fdf4}.payment-debt-row td{background:#fff7ed}.payment-overdue-row td{background:#fee2e2}.audit-mini{font-size:13px;border-left:3px solid #e5e7eb;padding:8px 0 8px 10px;margin-bottom:8px}.toolbar-sticky{position:sticky;top:10px;z-index:4}
@media print{.print-only{display:block}.no-print,.actions-bar,.breadcrumb-strip,.alert,.filter-card,.room-popover,.floor-room-popover{display:none!important}a[href]:after{content:""}.table{font-size:12px}.clean-card,.card{box-shadow:none!important;border:1px solid #ddd!important}}

/* V7.2: compact active-filter chip for room based resident list */
.filter-chip{display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(37,99,235,.18);background:rgba(37,99,235,.08);color:#1d4ed8;border-radius:999px;padding:.35rem .7rem;font-size:.875rem}
.filter-chip a{font-weight:600;color:#1d4ed8;text-decoration:none}
.filter-chip a:hover{text-decoration:underline}

/* V7.4 finance and inventory refinements */
.stat-card{background:#f8fafc;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:14px 16px;min-height:84px;display:flex;flex-direction:column;justify-content:center}
.stat-card span{font-size:.78rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em}
.stat-card strong{font-size:1.35rem;color:#0f172a}
.receipt-chip{display:flex;align-items:center;gap:6px;max-width:260px;margin:3px 0;padding:4px 8px;border:1px solid rgba(15,23,42,.08);border-radius:999px;background:#f8fafc;font-size:.82rem}
.receipt-chip .btn{padding:.12rem .45rem;font-size:.72rem;border-radius:999px}
.payments-filter .form-check{min-height:auto}
@media (max-width: 768px){.receipt-chip{max-width:100%}.stat-card strong{font-size:1.1rem}}

/* V7.5: large-recipient lists and inventory performance UI */
.bounded-select-wrap{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;max-height:260px}
.bounded-multi-select{border:0!important;border-radius:0!important;min-height:230px;max-height:260px;overflow-y:auto!important;background:#fff}
.bounded-multi-select:focus{box-shadow:none!important}
.compact-help{max-height:46px;overflow:auto;padding-right:4px}
.inventory-performance-note{font-size:.78rem;color:#64748b}
@media (max-width: 768px){.bounded-select-wrap{max-height:210px}.bounded-multi-select{min-height:180px;max-height:210px}.compact-help{max-height:60px}}


/* V8.1 QA polish */
.filter-form .btn{white-space:nowrap}
.filter-form .form-label{font-weight:700}
.table-responsive{border-radius:14px}
.bounded-select-wrap{overflow-y:auto!important}
.bounded-multi-select{height:230px!important}
@media (max-width:575px){.topbar-actions{overflow-x:auto;max-width:100%;padding-bottom:2px}.filter-form .btn{width:100%}.filter-form .d-flex{width:100%}}

/* V8.7: стабильный бренд в сайдбаре, меньше мигания логотипа при переходах */
.brand{min-height:44px;contain:layout paint}
.brand > span:last-child{min-width:0;overflow:hidden}
.brand strong,.brand small{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:190px}
.brand-logo{display:block;flex:0 0 44px;min-width:44px;max-width:44px;aspect-ratio:1/1;backface-visibility:hidden;transform:translateZ(0)}
.brand-mark{flex:0 0 44px}
.auth-logo strong,.auth-logo small{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:330px}


/* V8.8: stable sidebar logo without image flicker */
.brand-logo-box{
  display:block;
  flex:0 0 44px;
  width:44px;
  height:44px;
  min-width:44px;
  border-radius:14px;
  background-color:#ffffff;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  box-shadow:0 10px 25px rgba(15,23,42,.18);
  border:1px solid rgba(255,255,255,.7);
  contain:strict;
  transform:translateZ(0);
  backface-visibility:hidden;
}
.brand-logo{display:none!important}

.announcement-card{position:relative;overflow:hidden}.announcement-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:#2563eb}.announcement-kind-info{border-color:#bfdbfe;background:linear-gradient(90deg,#eff6ff 0,#fff 38%)}.announcement-kind-info::before{background:#2563eb}.announcement-kind-important{border-color:#fecaca;background:linear-gradient(90deg,#fef2f2 0,#fff 38%)}.announcement-kind-important::before{background:#dc2626}.announcement-kind-warning{border-color:#fde68a;background:linear-gradient(90deg,#fffbeb 0,#fff 38%)}.announcement-kind-warning::before{background:#f59e0b}.announcement-kind-success{border-color:#bbf7d0;background:linear-gradient(90deg,#f0fdf4 0,#fff 38%)}.announcement-kind-success::before{background:#16a34a}.announcement-kind-neutral{border-color:#e5e7eb;background:#fff}.announcement-kind-neutral::before{background:#64748b}.announcement-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.announcement-actions{display:flex;gap:8px;flex-wrap:wrap}.announcement-form-sticky{position:sticky;top:16px}@media(max-width:1199px){.announcement-form-sticky{position:static}}
