:root{--color-primary:#1a7ad6;--color-primary-hover:#166ac5;--color-primary-light:#eff6ff;--color-primary-border:#bfdbfe;--color-primary-muted:#dbeafe;--color-surface:#fff;--color-bg:#f8f9fa;--color-border:#e5e7eb;--color-border-light:#f3f4f6;--color-hover-bg:#f3f4f6;--color-surface-alt:#f9fafb;--color-text:#111827;--color-text-secondary:#374151;--color-text-muted:#6b7280;--color-text-faint:#9ca3af;--color-success-bg:#f0fdf4;--color-success-text:#166534;--color-success-border:#bbf7d0;--color-warning-bg:#fff7ed;--color-warning-text:#92400e;--color-warning-border:#fed7aa;--color-danger:#ef4444;--color-danger-dark:#dc2626;--color-danger-bg:#fef2f2;--color-danger-border:#fecaca;--sidebar-width:240px}@supports (-webkit-touch-callout:none){input,select,textarea{font-size:16px!important}}.app-layout{background-color:var(--color-bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}@media (width>=768px){.app-layout{flex-direction:row}}.sidebar{width:var(--sidebar-width);background-color:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:none}@media (width>=768px){.sidebar{display:flex}}.sidebar__logo{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:20px;display:flex}.sidebar__logo-icon{border-radius:8px;flex-shrink:0;width:32px;height:32px;overflow:hidden}.sidebar__brand-name{letter-spacing:-.01em;color:var(--color-primary);font-size:14px;font-weight:600}.sidebar__building-name{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:11px;overflow:hidden}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.sidebar__nav-link{color:var(--color-text-secondary);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background-color .15s;display:flex}.sidebar__nav-link svg{stroke:var(--color-text-muted);flex-shrink:0}.sidebar__nav-link:hover{background-color:var(--color-hover-bg)}.sidebar__nav-link--active{background-color:var(--color-primary-light);color:var(--color-primary)}.sidebar__nav-link--active svg{stroke:var(--color-primary)}.sidebar__nav-link--active:hover{background-color:var(--color-primary-light)}.sidebar__footer{border-top:1px solid var(--color-border);padding:16px}.sidebar__user{align-items:center;gap:12px;margin-bottom:12px;display:flex}.sidebar__avatar{color:#fff;background-color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex;overflow:hidden}.sidebar__avatar-img{object-fit:cover;width:100%;height:100%;display:block}.sidebar__user-info{min-width:0}.sidebar__user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sidebar__user-role{color:var(--color-text-muted);font-size:11px}.sidebar__user--link{cursor:pointer;border-radius:8px;align-items:center;gap:12px;margin:-6px -4px 6px;padding:6px 4px;text-decoration:none;transition:background-color .15s;display:flex}.sidebar__user--link:hover{background-color:var(--color-hover-bg)}.sidebar__action-btn{width:100%;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;margin-bottom:4px;padding:8px 12px;font-size:13px;transition:background-color .15s,color .15s;display:flex}.sidebar__action-btn:hover{background-color:var(--color-hover-bg)}.sidebar__action-btn--logout{color:var(--color-text-muted);margin-bottom:0}.sidebar__action-btn--logout:hover{background-color:var(--color-danger-bg);color:var(--color-danger-dark)}.main-content{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.page-content{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:20px 16px;overflow:hidden auto}@media (width>=768px){.page-content{padding:32px}}.topbar{padding:16px;padding-top:calc(16px + env(safe-area-inset-top));background-color:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}@media (width>=768px){.topbar{display:none}}.topbar__logo{align-items:center;gap:10px;display:flex}.topbar__logo-icon{border-radius:6px;flex-shrink:0;width:28px;height:28px;overflow:hidden}.topbar__brand-name{color:var(--color-primary);font-size:13px;font-weight:600}.topbar__building-name{color:var(--color-text-muted);font-size:11px;line-height:1}.topbar__avatar-btn{color:#fff;background-color:var(--color-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:11px;font-weight:600;display:flex;overflow:hidden}.topbar__avatar-img{object-fit:cover;width:100%;height:100%;display:block}.mobile-dropdown{background-color:var(--color-surface);border:1px solid var(--color-border);z-index:50;border-radius:12px;width:224px;padding:4px 0;position:absolute;top:40px;right:0;box-shadow:0 10px 25px #0000001a}.mobile-dropdown--fixed{right:16px;top:calc(env(safe-area-inset-top,0px) + 64px);z-index:200;position:fixed}.mobile-dropdown__header{border-bottom:1px solid var(--color-border-light);padding:12px 16px}.mobile-dropdown__user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.mobile-dropdown__user-role{color:var(--color-text-muted);margin-top:2px;font-size:11px}.mobile-dropdown__item{text-align:left;width:100%;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:12px 16px;font-size:13px;transition:background-color .15s;display:flex}.mobile-dropdown__item:hover{background-color:var(--color-hover-bg)}.mobile-dropdown__item--danger{color:var(--color-danger)}.mobile-dropdown__item--danger:hover{background-color:var(--color-danger-bg)}.mobile-backdrop{z-index:40;position:fixed;inset:0}@media (width>=768px){.mobile-backdrop{display:none}}.bottom-nav{background-color:var(--color-surface);border-top:1px solid var(--color-border);z-index:40;padding-bottom:env(safe-area-inset-bottom);flex-shrink:0;display:flex;position:sticky;bottom:0}@media (width>=768px){.bottom-nav{display:none}}.bottom-nav__link{color:var(--color-text-faint);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:12px 0;text-decoration:none;display:flex}.bottom-nav__link span{font-size:10px;font-weight:500}.bottom-nav__link--active{color:var(--color-primary)}.switch-modal-overlay{z-index:60;background:#00000059;justify-content:center;align-items:center;padding:0 16px;display:flex;position:fixed;inset:0}.switch-modal{background-color:var(--color-surface);border-radius:16px;width:100%;max-width:448px;box-shadow:0 20px 60px #00000026}.switch-modal__header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.switch-modal__title{color:var(--color-text);font-size:16px;font-weight:600}.switch-modal__subtitle{color:var(--color-text-muted);margin-top:2px;font-size:13px}.switch-modal__close-btn{width:32px;height:32px;color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.switch-modal__close-btn:hover{background-color:var(--color-hover-bg)}.switch-modal__error{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-dark);border-radius:8px;margin:16px 24px 0;padding:12px 16px;font-size:13px}.switch-modal__list{flex-direction:column;gap:8px;padding:16px;display:flex}.building-card{text-align:left;background-color:var(--color-surface-alt);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;align-items:center;gap:16px;width:100%;padding:14px 16px;transition:border-color .15s;display:flex}.building-card:hover:not(:disabled){border-color:var(--color-primary)}.building-card--active{background-color:var(--color-primary-light);border-color:var(--color-primary-border)}.building-card--active:hover{border-color:var(--color-primary-border)}.building-card:disabled{opacity:.6}.building-card__icon{width:36px;height:36px;color:var(--color-text-muted);background-color:var(--color-border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.building-card--active .building-card__icon{color:var(--color-primary);background-color:var(--color-primary-muted)}.building-card__body{flex:1;min-width:0}.building-card__name{color:var(--color-text);font-size:14px;font-weight:500}.building-card--active .building-card__name{color:var(--color-primary)}.building-card__address{white-space:nowrap;text-overflow:ellipsis;color:var(--color-text-muted);margin-top:2px;font-size:12px;overflow:hidden}.building-card__meta{color:var(--color-primary);flex-shrink:0;align-items:center;gap:8px;display:flex}.role-badge{background-color:var(--color-hover-bg);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:9999px;padding:2px 8px;font-size:11px;font-weight:500}.role-badge--active{background-color:var(--color-primary-muted);color:var(--color-primary);border-color:var(--color-primary-border)}.role-badge--manager{background-color:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary-border)}.role-badge--member{background-color:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success-border)}.role-badge--security{background-color:var(--color-warning-bg);color:var(--color-warning-text);border-color:var(--color-warning-border)}.auth-layout{min-height:100vh;display:flex}.auth-panel{background-color:var(--color-primary);flex-direction:column;justify-content:space-between;padding:48px;display:none}@media (width>=1024px){.auth-panel{width:50%;display:flex}}.auth-panel__logo{align-items:center;gap:12px;display:flex}.auth-panel__logo-icon{border-radius:8px;flex-shrink:0;width:36px;height:36px;overflow:hidden}.auth-panel__brand-name{color:#fff;letter-spacing:-.01em;font-size:15px;font-weight:500}.auth-panel__tagline{color:#fff;margin-bottom:16px;font-size:30px;font-weight:500;line-height:1.3}.auth-panel__description{color:#fff9;font-size:15px;line-height:1.6}.auth-panel__copyright{color:#ffffff59;font-size:13px}.auth-form-section{background-color:var(--color-surface);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.auth-mobile-logo{align-items:center;gap:12px;margin-bottom:40px;display:flex}@media (width>=1024px){.auth-mobile-logo{display:none}}.auth-mobile-logo__icon{border-radius:8px;flex-shrink:0;width:36px;height:36px;overflow:hidden}.auth-mobile-logo__name{letter-spacing:-.01em;color:var(--color-primary);font-size:15px;font-weight:500}.auth-form-wrap{width:100%;max-width:384px}.auth-form__heading{margin-bottom:32px}.auth-form__title{color:var(--color-text);margin-bottom:4px;font-size:22px;font-weight:500}.auth-form__subtitle{color:var(--color-text-muted);font-size:14px}.alert{border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:13px}.alert--error{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:#b91c1c}.alert--success{background-color:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success-text)}.form-field{flex-direction:column;gap:6px;display:flex}.form-field__label{color:#374151;font-size:13px;font-weight:500}.form-field__label-row{justify-content:space-between;align-items:center;display:flex}.form-field__forgot{color:var(--color-primary);font-size:13px;font-weight:500;text-decoration:none;transition:color .15s}.form-field__forgot:hover{color:var(--color-primary-hover)}.form-field__input-wrap{position:relative}.form-field__input{width:100%;color:var(--color-text);border:1px solid var(--color-border);background-color:var(--color-surface-alt);border-radius:8px;outline:none;padding:10px 12px;font-size:15px;transition:border-color .15s,background-color .15s}.form-field__input::placeholder{color:var(--color-text-faint)}.form-field__input:focus{border-color:var(--color-primary);background-color:var(--color-surface)}.form-field__input--with-icon{padding-right:40px}.form-field__toggle-btn{color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;align-items:center;transition:color .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.form-field__toggle-btn:hover{color:var(--color-text-muted)}.form-field__error{color:var(--color-danger);margin-top:4px;font-size:12px}.form-field__input--error{border-color:var(--color-danger)!important}.activate-success{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:48px 0;display:flex}.activate-success__icon{background-color:var(--color-success-bg);border:2px solid var(--color-success-border);width:64px;height:64px;color:var(--color-success-text);border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-primary{color:#fff;cursor:pointer;background-color:var(--color-primary);border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:15px;font-weight:500;transition:background-color .15s;display:flex}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.auth-form__back-link{text-align:center;color:var(--color-text-muted);margin-top:16px;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s;display:block}.auth-form__back-link:hover{color:var(--color-primary)}.download-app-wrap{text-align:center;flex-direction:column;align-items:center;display:flex}.download-app__icon-wrap{background-color:var(--color-primary);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:28px;display:flex;box-shadow:0 8px 24px #1a7ad64d}.download-app__heading{margin-bottom:32px}.download-app__heading .auth-form__subtitle{max-width:320px;margin:0 auto;line-height:1.6}.store-badges{flex-direction:column;gap:12px;width:100%;max-width:240px;margin-bottom:32px;display:flex}.store-badge{color:#fff;background-color:#0f172a;border-radius:12px;align-items:center;gap:14px;padding:12px 20px;text-decoration:none;transition:background-color .15s,transform .1s;display:flex}.store-badge:hover{background-color:#1e293b;transform:translateY(-1px)}.store-badge:active{transform:translateY(0)}.store-badge svg{flex-shrink:0}.store-badge__text{text-align:left;flex-direction:column;display:flex}.store-badge__label{color:#ffffffb3;text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:400;line-height:1.2}.store-badge__name{font-size:15px;font-weight:600;line-height:1.3}.selector-layout{background-color:var(--color-surface);flex-direction:column;min-height:100vh;display:flex}.selector-header{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:20px 24px;display:flex}.selector-header__logo-icon{border-radius:8px;flex-shrink:0;width:32px;height:32px;overflow:hidden}.selector-header__brand-name{letter-spacing:-.01em;color:var(--color-primary);font-size:15px;font-weight:500}.selector-main{flex-direction:column;flex:1;align-items:center;padding:48px 24px;display:flex}.selector-content{width:100%;max-width:512px}.selector-heading{margin-bottom:32px}.selector-title{color:var(--color-text);margin-bottom:4px;font-size:22px;font-weight:500}.selector-subtitle{color:var(--color-text-muted);font-size:14px}.selector-subtitle__name{color:var(--color-text-secondary);font-weight:500}.building-item{text-align:left;background-color:var(--color-surface-alt);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:16px 20px;transition:border-color .15s,background-color .15s;display:flex}.building-item:hover:not(:disabled){border-color:var(--color-primary);background-color:var(--color-surface)}.building-item:disabled{opacity:.6}.building-item__info{align-items:center;gap:16px;display:flex}.building-item__icon{background-color:var(--color-primary-light);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.building-item__name{color:var(--color-text);font-size:15px;font-weight:500}.building-item__address{color:var(--color-text-muted);margin-top:2px;font-size:13px;line-height:1.3}.building-item__actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.building-item__chevron{color:var(--color-text-faint)}.dash-welcome{margin-bottom:32px}.dash-welcome__title{color:var(--color-text);font-size:22px;font-weight:600}.dash-welcome__building{color:var(--color-text-muted);margin-top:4px;font-size:14px}.info-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;align-items:flex-start;gap:16px;margin-bottom:24px;padding:20px;display:flex}.info-card__icon{background-color:var(--color-primary-light);width:48px;height:48px;color:var(--color-primary);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.info-card__body{flex:1;min-width:0}.info-card__header{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.info-card__name{color:var(--color-text);font-size:16px;font-weight:600}.info-card__address{color:var(--color-text-muted);margin-top:2px;font-size:13px}.push-banner{background:var(--color-primary-light);border:1px solid var(--color-primary-border);border-radius:12px;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-bottom:20px;padding:16px 18px;display:flex}@media (width>=640px){.push-banner{flex-wrap:nowrap;align-items:center}}.push-banner__icon{background-color:var(--color-primary);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.push-banner__body{flex:1;min-width:0}.push-banner__title{color:var(--color-primary);margin-bottom:2px;font-size:14px;font-weight:600}.push-banner__desc{color:var(--color-text-secondary);font-size:13px;line-height:1.5}.push-banner__actions{flex-shrink:0;align-items:center;gap:8px;width:100%;display:flex}@media (width>=640px){.push-banner__actions{width:auto}}.push-banner__btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.push-banner__btn:disabled{opacity:.6;cursor:not-allowed}.push-banner__btn--allow{background-color:var(--color-primary);color:#fff;flex:1;justify-content:center}@media (width>=640px){.push-banner__btn--allow{flex:none}}.push-banner__btn--allow:hover:not(:disabled){opacity:.85}.push-banner__btn--dismiss{color:var(--color-text-muted);white-space:nowrap;background:0 0}.push-banner__btn--dismiss:hover{color:var(--color-text)}.module-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=640px){.module-grid{grid-template-columns:repeat(3,1fr);gap:16px}}.module-tile{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;align-items:center;gap:16px;padding:20px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}@media (width>=640px){.module-tile{flex-direction:column;align-items:flex-start;gap:14px}}.module-tile:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #1e3a5f14}.module-tile__icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.module-tile__icon--primary{background-color:var(--color-primary-light);color:var(--color-primary)}.module-tile__icon--success{background-color:var(--color-success-bg);color:var(--color-success-text)}.module-tile__icon--warning{background-color:var(--color-warning-bg);color:var(--color-warning-text)}.module-tile__body{flex:1;min-width:0}.module-tile__title{color:var(--color-text);margin-bottom:3px;font-size:15px;font-weight:600}.module-tile__desc{color:var(--color-text-muted);font-size:12px;line-height:1.4}.module-tile__arrow{color:var(--color-text-faint);flex-shrink:0;transition:color .15s,transform .15s}.module-tile:hover .module-tile__arrow{color:var(--color-primary);transform:translate(2px)}@media (width>=640px){.module-tile__arrow{display:none}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}@media (width>=768px){.page-header{margin-bottom:24px}}.page-header__left{align-items:center;gap:12px;display:flex}.page-header__title{color:var(--color-text);font-size:20px;font-weight:600}.page-header__subtitle{color:var(--color-text-faint);margin-top:2px;font-size:12px}.btn-back{color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-size:13px;font-weight:500;transition:background-color .15s;display:flex}.btn-back:hover{background-color:var(--color-hover-bg)}.btn-add{color:#fff;background-color:var(--color-primary);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.btn-add:hover{opacity:.85}.btn-cancel{color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:background-color .15s}.btn-cancel:hover{background-color:var(--color-hover-bg)}.btn-save{color:#fff;background-color:var(--color-primary);cursor:pointer;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:opacity .15s}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-delete-confirm{color:#fff;background-color:var(--color-danger);cursor:pointer;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:opacity .15s}.btn-delete-confirm:disabled{opacity:.6;cursor:not-allowed}.filter-bar{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.filter-control{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:8px;outline:none;padding:8px 12px;font-size:13px;transition:border-color .15s}.filter-control:focus{border-color:var(--color-primary)}.filter-control--tower{width:128px}.filter-control--search{flex:1;width:100%;min-width:0}@media (width>=640px){.filter-control--search{max-width:320px}}.table-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.table-loading{color:var(--color-primary);justify-content:center;align-items:center;padding:48px 24px;display:flex}.table-empty{flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.table-empty__icon{background-color:var(--color-hover-bg);width:48px;height:48px;color:var(--color-text-faint);border-radius:12px;justify-content:center;align-items:center;display:flex}.table-empty__text{color:var(--color-text-muted);font-size:14px}.table-empty__btn{color:#fff;background-color:var(--color-primary);cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500}.data-table{border-collapse:collapse;width:100%}.data-table__th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:600}@media (width>=640px){.data-table__th{padding:14px 20px}}.data-table__row{border-bottom:1px solid var(--color-border-light);transition:background-color .1s}.data-table__row:hover{background-color:#fafafa}.data-table__td{color:var(--color-text-muted);padding:10px 12px;font-size:13px}@media (width>=640px){.data-table__td{padding:14px 20px}}.data-table__td--number{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;font-weight:500;overflow:hidden}@media (width>=640px){.data-table__td--number{max-width:280px;font-size:13.5px}}.data-table__td--center{text-align:center}.data-table__td--actions{text-align:right;white-space:nowrap}.status-badge{border-radius:9999px;align-items:center;padding:2px 10px;font-size:11px;font-weight:500;display:inline-flex}.status-badge--occupied{background-color:var(--color-warning-bg);color:var(--color-warning-text);border:1px solid var(--color-warning-border)}.status-badge--vacant{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.row-actions{justify-content:flex-end;align-items:center;gap:4px;display:flex}.row-action-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .15s;display:flex}.row-action-btn--members{color:var(--color-text-secondary)}.row-action-btn--members:hover{color:var(--color-primary);background-color:var(--color-primary-light)}.row-action-btn--edit{color:var(--color-primary)}.row-action-btn--edit:hover{background-color:var(--color-primary-light)}.row-action-btn--delete{color:var(--color-danger)}.row-action-btn--delete:hover{background-color:var(--color-danger-bg)}.pagination{border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.pagination__info{color:var(--color-text-faint);font-size:12px}.pagination__controls{gap:8px;display:flex}.pagination__btn{color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:500;transition:background-color .15s}.pagination__btn:hover:not(:disabled){background-color:var(--color-hover-bg)}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{z-index:50;background:#0006;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=640px){.modal-overlay{align-items:center;padding:0 16px}}.modal{background-color:var(--color-surface);border-radius:20px 20px 0 0;width:100%;max-width:448px;max-height:92vh;overflow-y:auto;box-shadow:0 -4px 40px #0000001f}@media (width>=640px){.modal{border-radius:16px;box-shadow:0 20px 60px #00000026}}.modal__header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.modal__title{color:var(--color-text);font-size:16px;font-weight:600}.modal__close-btn{width:32px;height:32px;color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.modal__close-btn:hover{background-color:var(--color-hover-bg)}.modal__error{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-dark);border-radius:8px;margin:16px 24px 0;padding:12px 16px;font-size:13px}.modal__form{flex-direction:column;gap:16px;padding:20px 24px;display:flex}.modal__actions{gap:12px;padding-top:4px;display:flex}.modal-field{flex-direction:column;gap:6px;display:flex}.modal-field__label{color:#374151;font-size:12px;font-weight:500}.modal-field__required{color:var(--color-danger)}.modal-field__input,.modal-field__select{border:1px solid var(--color-border);width:100%;color:var(--color-text);background-color:var(--color-surface);border-radius:8px;outline:none;padding:10px 12px;font-size:13px;transition:border-color .15s}.modal-field__input:focus,.modal-field__select:focus{border-color:var(--color-primary)}.modal-field__grid{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=640px){.modal-field__grid{grid-template-columns:repeat(2,1fr)}}.modal-field__checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.modal-field__checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.modal-field__checkbox span{color:var(--color-text-secondary);font-size:13px;font-weight:500}.modal-field__hint{color:var(--color-text-faint);margin-top:2px;font-size:11px}.modal-field__hint--warning{color:var(--color-warning-text);font-size:12px;font-weight:500}.delete-modal{background-color:var(--color-surface);border-radius:20px 20px 0 0;width:100%;max-width:384px;padding:24px;box-shadow:0 -4px 40px #0000001f}@media (width>=640px){.delete-modal{border-radius:16px;box-shadow:0 20px 60px #00000026}}.delete-modal__body{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.delete-modal__icon{background-color:var(--color-danger-bg);width:40px;height:40px;color:var(--color-danger);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.delete-modal__title{color:var(--color-text);font-size:15px;font-weight:600}.delete-modal__message{color:var(--color-text-muted);margin-top:4px;font-size:13px}.delete-modal__actions{gap:12px;display:flex}.resident-name-cell{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.resident-name{color:var(--color-text);font-size:13.5px;font-weight:500}.account-badge{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border);border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.member-account-info{background-color:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success-text);border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.resident-name__text{color:var(--color-text);font-size:13.5px;font-weight:500}.primary-badge{background-color:var(--color-primary-light);color:var(--color-primary);border:1px solid var(--color-primary-border);text-transform:uppercase;letter-spacing:.03em;border-radius:9999px;flex-shrink:0;align-items:center;padding:2px 6px;font-size:10px;font-weight:600;display:inline-flex}.primary-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.primary-toggle--disabled{cursor:not-allowed;opacity:.5}.primary-toggle__input{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.primary-toggle__label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.resource-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=540px){.resource-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}}.resource-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;transition:box-shadow .15s;display:flex;overflow:hidden}.resource-card:hover{box-shadow:0 4px 16px #00000012}.resource-card--inactive{opacity:.6}.resource-card__header{border-bottom:1px solid var(--color-border-light);padding:16px 18px 12px}.resource-card__title-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.resource-card__name-group{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.resource-card__thumb{border:1px solid var(--color-border);background:var(--color-hover-bg);border-radius:8px;flex-shrink:0;width:40px;height:40px;overflow:hidden}.resource-card__thumb img{object-fit:contain;width:100%;height:100%;display:block}.resource-card__thumb--empty{color:var(--color-text-faint);justify-content:center;align-items:center;display:flex}.resource-card__name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:15px;font-weight:600;overflow:hidden}.resource-card__description{color:var(--color-text-muted);margin-top:2px;font-size:12.5px}.resource-card__body{flex-direction:column;flex:1;gap:10px;padding:14px 18px;display:flex}.resource-card__footer{border-top:1px solid var(--color-border-light);background-color:var(--color-hover-bg);gap:8px;padding:10px 18px;display:flex}.resource-card__footer .row-action-btn{border-radius:6px;align-items:center;gap:5px;width:auto;height:30px;padding:0 10px;font-size:12px;font-weight:500;display:flex}.resource-info-row{flex-wrap:wrap;gap:6px;display:flex}.resource-info-row--secondary{color:var(--color-text-faint)}.resource-tag{border-radius:9999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.resource-tag--schedule{background-color:var(--color-primary-light);color:var(--color-primary);border:1px solid #1e3a5f26}.resource-tag--days{background-color:var(--color-hover-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.resource-tag--free{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.resource-meta{color:var(--color-text-muted);align-items:center;gap:4px;font-size:12px;display:inline-flex}.resource-rules-list{flex-direction:column;gap:4px;margin-top:2px;list-style:none;display:flex}.resource-rules-list__item{color:var(--color-text-muted);align-items:flex-start;gap:6px;font-size:12px;display:flex}.resource-rules-list__item svg{color:var(--color-success-text);flex-shrink:0;margin-top:2px}.modal--wide{max-width:100%;max-height:92vh;overflow-y:auto}@media (width>=640px){.modal--wide{max-width:560px}}.modal-section{background-color:var(--color-hover-bg);border:1px solid var(--color-border-light);border-radius:10px;flex-direction:column;gap:12px;padding:16px;display:flex}.modal-section__title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);font-size:12px;font-weight:600}.day-picker{flex-wrap:wrap;gap:6px;display:flex}.day-picker__btn{border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;border-radius:8px;font-size:12px;font-weight:600;transition:all .15s}.day-picker__btn--active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.day-picker__btn:not(.day-picker__btn--active):hover{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.modal-rules-list{flex-direction:column;gap:6px;list-style:none;display:flex}.modal-rules-list__item{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.modal-rules-list__remove{cursor:pointer;width:24px;height:24px;color:var(--color-text-faint);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-rules-list__remove:hover{background-color:var(--color-danger-bg);color:var(--color-danger)}.modal-rules-add{gap:8px;display:flex}.modal-rules-add .modal-field__input{flex:1}.btn-add-rule{color:var(--color-primary);background:var(--color-primary-light);cursor:pointer;white-space:nowrap;border:1px solid #1e3a5f33;border-radius:8px;flex-shrink:0;padding:10px 14px;font-size:13px;font-weight:500;transition:opacity .15s}.btn-add-rule:hover{opacity:.8}.news-header__right{align-items:center;gap:8px;width:100%;display:flex}@media (width>=640px){.news-header__right{width:auto}}.news-header__search{border:1px solid var(--color-border);background:var(--color-surface);min-width:0;color:var(--color-text);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:border-color .15s}@media (width>=640px){.news-header__search{flex:none;width:220px}}.news-header__search:focus{border-color:var(--color-primary)}.news-header__search::placeholder{color:var(--color-text-muted)}.post-thumb{background:var(--color-hover-bg);border:1px solid var(--color-border);border-radius:6px;flex-shrink:0;width:52px;height:36px;overflow:hidden}.post-thumb__img{object-fit:cover;width:100%;height:100%;display:block}.post-thumb--empty{color:var(--color-text-faint);justify-content:center;align-items:center;display:flex}.data-table__td--id{color:var(--color-text-faint);font-variant-numeric:tabular-nums;width:40px;font-size:12px}.news-feed{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=640px){.news-feed{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.news-feed{grid-template-columns:repeat(3,1fr)}}.post-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.post-card--clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.post-card--clickable:hover{border-color:var(--color-primary);box-shadow:0 2px 12px #1e3a5f12}.post-card__image{aspect-ratio:16/9;object-fit:contain;background-color:var(--color-hover-bg);width:100%;display:block}.post-card__body{padding:20px 20px 16px}.post-card__title{color:var(--color-text);letter-spacing:-.2px;margin-bottom:8px;font-size:17px;font-weight:700;line-height:1.35}.post-card__content{color:var(--color-text-secondary);white-space:pre-wrap;font-size:14px;line-height:1.7}.post-card__content--preview{-webkit-line-clamp:3;white-space:normal;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.post-card__footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:8px;padding:10px 16px;display:flex}.post-card__meta{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.post-card__author{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.post-card__date{color:var(--color-text-muted);font-size:11px}.post-card__actions{align-items:center;gap:8px;display:flex}.like-btn{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.like-btn svg{transition:transform .15s}.like-btn:hover{color:#e11d48;border-color:#e11d48}.like-btn.like-btn--liked{color:#e11d48;background:#fff1f2;border-color:#fecdd3}.like-btn.like-btn--liked svg{fill:#e11d48;stroke:#e11d48}.post-card__edit-btn,.post-card__delete-btn{cursor:pointer;width:30px;height:30px;color:var(--color-text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.post-card__edit-btn:hover,.post-card__delete-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.post-card__delete-btn:hover{color:var(--color-danger);background:#fff1f2}.news-image-preview{border-radius:8px;margin-top:8px;position:relative;overflow:hidden}.news-image-preview img{aspect-ratio:16/7;object-fit:cover;width:100%;display:block}.news-image-preview__actions{gap:6px;display:flex;position:absolute;top:8px;right:8px}.news-image-preview__btn{cursor:pointer;color:#fff;background:#0009;border:none;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;transition:background-color .15s}.news-image-preview__btn:hover{background:#000c}.news-image-upload{border:1px dashed var(--color-border);cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);border-radius:8px;align-items:center;gap:12px;margin-top:8px;padding:12px 16px;font-size:14px;transition:border-color .15s;display:flex}.news-image-upload:hover{border-color:var(--color-primary);color:var(--color-primary)}.news-content-field{resize:vertical;min-height:120px}.feed-sentinel{min-height:56px;color:var(--color-primary);grid-column:1/-1;justify-content:center;align-items:center;padding:24px 0 8px;display:flex}.post-sheet{background-color:var(--color-surface);border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-height:92vh;display:flex;position:relative;box-shadow:0 -4px 40px #0000001f}@media (width>=640px){.post-sheet{border-radius:16px;max-width:640px;max-height:85vh;box-shadow:0 20px 60px #00000026}}.post-sheet__scrollable{flex:1;min-height:0;overflow-y:auto}.post-sheet__handle{background-color:var(--color-border);border-radius:9999px;width:36px;height:4px;margin:12px auto 0}@media (width>=640px){.post-sheet__handle{display:none}}.post-sheet__close-btn{color:#fff;cursor:pointer;z-index:1;background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .15s;display:flex;position:absolute;top:14px;right:16px}.post-sheet__close-btn:hover{background:#000000a6}.post-sheet__image{aspect-ratio:16/9;object-fit:contain;background-color:var(--color-hover-bg);width:100%;display:block}.post-sheet__body{padding:20px 20px 4px}.post-sheet__title{color:var(--color-text);letter-spacing:-.3px;margin-bottom:10px;font-size:20px;font-weight:700;line-height:1.3}.post-sheet__meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.post-sheet__author{color:var(--color-text-secondary);font-size:13px;font-weight:500}.post-sheet__date{color:var(--color-text-faint);font-size:12px}.post-sheet__date:before{content:"·";color:var(--color-border);margin-right:10px}.post-sheet__content{color:var(--color-text-secondary);white-space:pre-wrap;padding-bottom:16px;font-size:15px;line-height:1.75}.post-sheet__footer{border-top:1px solid var(--color-border);background-color:var(--color-surface);flex-shrink:0;align-items:center;padding:14px 20px;display:flex}.data-table__row--clickable{cursor:pointer}.data-table__row--clickable:hover{background-color:var(--color-primary-light)!important}.reservation-card--clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.reservation-card--clickable:hover{border-color:var(--color-primary);box-shadow:0 2px 12px #1e3a5f12}.reservation-detail__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.reservation-detail__grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:8px;display:grid}.reservation-detail__item{flex-direction:column;gap:4px;display:flex}.reservation-detail__item--full{grid-column:1/-1}.reservation-detail__label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);font-size:11px;font-weight:600}.reservation-detail__value{color:var(--color-text);font-size:14px;font-weight:500}.reservation-detail__value--danger{color:var(--color-danger);font-weight:400}.reservation-detail__actions{border-top:1px solid var(--color-border);gap:12px;margin-top:24px;padding-top:16px;display:flex}.status-badge--pending{background-color:var(--color-warning-bg);color:var(--color-warning-text);border:1px solid var(--color-warning-border)}.status-badge--approved{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.status-badge--rejected{background-color:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.resource-book-btn{color:#fff;background-color:var(--color-primary);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.resource-book-btn:hover{opacity:.85}.member-search,.member-search__input-wrap{position:relative}.member-search__clear{cursor:pointer;width:20px;height:20px;color:var(--color-text-faint);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.member-search__clear:hover{color:var(--color-text-muted);background:var(--color-hover-bg)}.member-search__dropdown{background:var(--color-surface);border:1px solid var(--color-border);z-index:10;border-radius:10px;max-height:220px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.member-search__option{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;gap:2px;width:100%;padding:10px 14px;transition:background-color .1s;display:flex}.member-search__option:hover{background:var(--color-hover-bg)}.member-search__option:not(:last-child){border-bottom:1px solid var(--color-border-light)}.member-search__name{color:var(--color-text);font-size:13px;font-weight:500}.member-search__unit{color:var(--color-text-muted);font-size:12px}.member-search__no-account{color:var(--color-text-faint)}.member-search__empty{color:var(--color-text-faint);text-align:center;padding:12px 14px;font-size:13px}.reservation-list{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=640px){.reservation-list{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.reservation-list{grid-template-columns:repeat(3,1fr)}}.reservation-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.reservation-card__header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;gap:8px;padding:14px 16px 10px;display:flex}.reservation-card__name-group{min-width:0;color:var(--color-text-muted);align-items:center;gap:8px;display:flex}.reservation-card__resource{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.reservation-card__body{flex-direction:column;gap:6px;padding:12px 16px;display:flex}.reservation-card__detail{color:var(--color-text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.reservation-card__detail svg{color:var(--color-text-faint);flex-shrink:0}.reservation-card__reason{color:var(--color-danger);background:var(--color-danger-bg);border-top:1px solid var(--color-danger-border);padding:10px 16px;font-size:12px}.profile-page{max-width:680px}.profile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:16px;padding:24px}.profile-card__title{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:20px;font-size:14px;font-weight:600}.profile-form{flex-direction:column;gap:16px;display:flex}.profile-submit-btn{justify-content:center;align-self:flex-start;align-items:center;gap:8px;width:auto;min-width:140px;padding:10px 20px;display:flex}.profile-photo-row{align-items:center;gap:20px;display:flex}.profile-avatar-wrap{flex-shrink:0}.profile-avatar{object-fit:cover;border:2px solid var(--color-border);background:var(--color-hover-bg);border-radius:50%;width:72px;height:72px;display:block}.profile-avatar--initials{color:#fff;background-color:var(--color-primary);justify-content:center;align-items:center;font-size:26px;font-weight:600;display:flex}.profile-photo-actions{flex-direction:column;gap:8px;display:flex}.profile-photo-btn{cursor:pointer;background:var(--color-hover-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:8px;align-items:center;width:fit-content;padding:6px 14px;font-size:13px;font-weight:500;transition:background-color .15s;display:inline-flex}.profile-photo-btn:hover{background:var(--color-border)}.profile-photo-btn--remove{color:var(--color-danger);background:var(--color-danger-bg);border-color:var(--color-danger-border)}.profile-photo-btn--remove:hover{background:#fecaca}.profile-photo-hint{color:var(--color-text-faint);font-size:11px}.profile-info-grid{grid-template-columns:1fr;gap:14px;display:grid}@media (width>=640px){.profile-info-grid{grid-template-columns:repeat(2,1fr)}}.profile-info-item{flex-direction:column;gap:4px;display:flex}.profile-info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);font-size:11px;font-weight:600}.profile-info-value{color:var(--color-text);font-size:14px;font-weight:500}.profile-card__title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.profile-members-empty{color:var(--color-text-faint);padding:8px 0;font-size:14px}.profile-members-list{flex-direction:column;gap:0;display:flex}.profile-member-row{border-bottom:1px solid var(--color-border-light);align-items:center;gap:12px;padding:12px 0;display:flex}.profile-member-row:last-child{border-bottom:none}.profile-member-avatar{background-color:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:600;display:flex;overflow:hidden}.profile-member-avatar--photo{background:var(--color-hover-bg)}.profile-member-avatar img{object-fit:cover;width:100%;height:100%;display:block}.profile-member-info{flex:1;min-width:0}.profile-member-name{color:var(--color-text);flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.profile-member-sub{color:var(--color-text-muted);margin-top:2px;font-size:12px}.profile-member-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.qr-scanner-page{padding-bottom:24px}.qr-viewfinder{aspect-ratio:1;background:#000;border-radius:16px;width:100%;max-width:400px;margin:0 auto 24px;position:relative;overflow:hidden}.qr-viewfinder__video{object-fit:cover;width:100%;height:100%;display:block}.qr-viewfinder__canvas{display:none}.qr-viewfinder__frame{pointer-events:none;border:3px solid #fffc;border-radius:12px;position:absolute;inset:20%;box-shadow:0 0 0 9999px #00000073}.qr-viewfinder__hint{text-align:center;color:#fff;text-shadow:0 1px 3px #0009;padding:0 16px;font-size:13px;position:absolute;bottom:16px;left:0;right:0}.qr-viewfinder__error{color:#fff;text-align:center;background:#000000b3;justify-content:center;align-items:center;padding:24px;font-size:14px;display:flex;position:absolute;inset:0}.qr-result{background:var(--color-surface,#f8f9fa);border:1px solid var(--color-border,#e5e7eb);border-radius:16px;max-width:400px;margin:0 auto;padding:24px}.qr-result--loading{justify-content:center;align-items:center;min-height:160px;display:flex}.qr-result--success{background:#f0fdf4;border-color:#16a34a}.qr-result--upcoming{background:#eff6ff;border-color:#2563eb}.qr-result--expired{background:#f9fafb;border-color:#9ca3af}.qr-result--full{background:#fffbeb;border-color:#d97706}.qr-result--invalid{background:#fef2f2;border-color:#dc2626}.qr-result__header{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.qr-result__icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.qr-result--success .qr-result__icon{color:#fff;background:#16a34a}.qr-result--upcoming .qr-result__icon{color:#fff;background:#2563eb}.qr-result--expired .qr-result__icon{color:#fff;background:#9ca3af}.qr-result--full .qr-result__icon{color:#fff;background:#d97706}.qr-result--invalid .qr-result__icon{color:#fff;background:#dc2626}.qr-result__status-label{margin-bottom:4px;font-size:16px;font-weight:700}.qr-result__status-desc{color:var(--color-text-secondary,#6b7280);font-size:13px}.qr-result__info{border-top:1px solid var(--color-border,#e5e7eb);gap:8px;margin-top:8px;padding-top:16px;display:grid}.qr-result__info-row{justify-content:space-between;font-size:13px;display:flex}.qr-result__info-row dt{color:var(--color-text-secondary,#6b7280)}.qr-result__info-row dd{font-weight:500}.admin-layout{background:var(--color-bg);min-height:100dvh;display:flex}.admin-sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;height:100dvh;padding:1.5rem 0;display:flex;position:sticky;top:0}.admin-sidebar__brand{border-bottom:1px solid var(--color-border);align-items:center;gap:.625rem;padding:0 1.25rem 1.5rem;display:flex}.admin-sidebar__logo{border-radius:8px;width:32px;height:32px}.admin-sidebar__name{color:var(--color-text);font-size:.9375rem;font-weight:700}.admin-sidebar__badge{text-transform:uppercase;letter-spacing:.05em;background:var(--color-primary);color:#fff;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:.625rem;font-weight:700}.admin-sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:1rem .75rem;display:flex}.admin-sidebar__footer{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex}.admin-sidebar__user{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:500;overflow:hidden}.admin-sidebar__logout{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:.8125rem;transition:color .15s;display:flex}.admin-sidebar__logout:hover{color:var(--color-danger)}.admin-nav-item{color:var(--color-text-secondary);border-radius:8px;align-items:center;gap:.625rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.admin-nav-item:hover{background:var(--color-hover-bg);color:var(--color-text)}.admin-nav-item.router-link-active{background:var(--color-primary-light);color:var(--color-primary)}.admin-main{flex:1;padding:2rem;overflow-y:auto}.status-badge--active{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.status-badge--inactive{background-color:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.modal-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-faint);border-bottom:1px solid var(--color-border-light);margin-bottom:-4px;padding-bottom:4px;font-size:11px;font-weight:600}@media (width>=640px){.modal--wide{max-width:560px}}.row-action-btn--toggle-on{color:var(--color-success-text)}.row-action-btn--toggle-on:hover{background-color:var(--color-danger-bg);color:var(--color-danger)}.row-action-btn--toggle-off{color:var(--color-text-faint)}.row-action-btn--toggle-off:hover{background-color:var(--color-success-bg);color:var(--color-success-text)}.modal-managers{flex-direction:column;gap:8px;display:flex}.modal-managers__item{border:1px solid var(--color-border);background-color:var(--color-bg);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.modal-managers__info{flex-direction:column;gap:2px;min-width:0;display:flex}.modal-managers__name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.modal-managers__email{color:var(--color-text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.modal-managers__remove{color:var(--color-danger);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex-shrink:0;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:500;transition:background-color .15s,border-color .15s;display:flex}.modal-managers__remove:hover{background-color:var(--color-danger-bg);border-color:var(--color-danger-border)}.modal-managers__remove:disabled{opacity:.5;cursor:not-allowed}.btn-add-manager{width:100%;color:var(--color-primary);border:1px dashed var(--color-border);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;transition:background-color .15s,border-color .15s;display:flex}.btn-add-manager:hover{background-color:var(--color-primary-light);border-color:var(--color-primary)}.modal-add-manager{border:1px dashed var(--color-border);background-color:var(--color-bg);border-radius:8px;flex-direction:column;gap:10px;padding:12px;display:flex}.modal-add-manager__error{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-dark);border-radius:6px;padding:8px 12px;font-size:12px}.modal-add-manager__actions{justify-content:flex-end;gap:8px;display:flex}.modal-add-manager__btn-cancel,.modal-add-manager__btn-save{flex:none;padding:7px 14px;font-size:12px}.modal-field__input--error{border-color:var(--color-danger)!important}
