body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100%}button,input,select,textarea{background:none;border:none;font-family:inherit;font-size:inherit;line-height:inherit;margin:0;padding:0}a{color:inherit;text-decoration:none}ol,ul{list-style:none}#root{height:100%}.dashboard-wrapper{padding:0 20px 40px}.auth-container{align-items:center;background:#4a90e2;display:flex;justify-content:center;min-height:100vh;padding:0 20px}.auth-card{animation:slideUp .4s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;max-width:420px;padding:40px;width:100%}.auth-header{margin-bottom:24px;text-align:center}.auth-header h2{align-items:center;color:#1a202c;display:flex;font-size:28px;font-weight:700;gap:10px;justify-content:center;margin-bottom:8px}.login-logo-icon{height:32px;width:32px}.auth-header p{color:#718096;font-size:14px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group label{color:#2d3748}.form-group input{border:2px solid #e2e8f0;border-radius:8px;outline:none;padding:12px 16px;transition:all .2s}.form-group input:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.form-group input::placeholder{color:#a0aec0}.save-email-box{margin-bottom:8px}.checkbox-label{align-items:center;color:#2d3748;cursor:pointer;display:flex;font-size:14px;gap:8px;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:#4a90e2;cursor:pointer;height:16px;width:16px}.checkbox-label span{font-weight:500}.message-box{animation:fadeIn .3s ease-out;border-radius:8px;font-size:14px;margin-top:15px;padding:8px 16px;text-align:center}.message-box.success{background-color:#c6f6d5;border:1px solid #9ae6b4;color:#22543d}.message-box.error{background-color:#fed7d7;border:1px solid #fc8181;color:#742a2a}.auth-buttons{display:flex;flex-direction:column;gap:10px;margin-top:4px}.btn{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;outline:none;padding:12px 20px;transition:all .2s}.btn-primary{background:#4a90e2;box-shadow:0 4px 12px #4a90e266;color:#fff}.btn-primary:hover:not(:disabled){background:#3a7bc8;box-shadow:0 6px 16px #4a90e280;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#fff;border:2px solid #4a90e2;color:#4a90e2}.btn-secondary:hover:not(:disabled){background:#f7fafc}.btn:disabled{cursor:not-allowed;opacity:.6}.btn.loading{color:#0000;position:relative}.btn.loading:after{animation:spin .6s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.auth-footer{border-top:1px solid #e2e8f0;color:#718096;font-size:14px;margin-top:24px;padding-top:24px;text-align:center}.auth-footer a{color:#4a90e2;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}@media (max-width:480px){.auth-card{padding:28px 24px}.auth-header h2{font-size:24px}}.create-house-modal{max-width:450px}.create-house-modal .form-group{margin-bottom:20px}.create-house-modal .form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.create-house-modal .form-group input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;width:100%}.create-house-modal .form-group input:focus{border-color:#1976d2;outline:none}.error-message{background-color:#ffebee;border:1px solid #ef9a9a;border-radius:4px;color:#c62828;font-size:14px;margin-bottom:20px;padding:12px}.cancel-button{transition:background-color .2s}.cancel-button:hover:not(:disabled){background-color:#f5f5f5}.submit-button{transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#1565c0}.cancel-button:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6}.modal-overlay{animation:fadeIn .2s ease-in}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:90%}.form-modal .modal-content,.modal-content{max-width:500px}.modal-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2,.modal-header h3{color:#333;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-body{flex:1 1;max-height:65vh;overflow-y:auto;padding:20px 24px}.modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;padding:14px 24px}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-group label{font-weight:600;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:14px;padding:8px 12px;transition:all .2s;width:100%}.form-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23666' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;cursor:pointer;padding-right:32px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1976d2;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group textarea{min-height:60px;resize:vertical}.form-hint{color:#999;font-size:12px;margin-top:6px}.type-selector{display:flex;gap:10px;margin-bottom:16px}.type-option{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;flex:1 1;gap:10px;padding:10px 14px;transition:all .2s}.type-option:hover{background:#f5f5f5;border-color:#1976d2}.type-option.active{background:#e3f2fd;border-color:#1976d2}.type-option-icon{flex-shrink:0;font-size:20px}.type-option-label{color:#333;font-size:13px;font-weight:600}.cancel-btn,.cancel-button{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.cancel-btn:hover:not(:disabled),.cancel-button:hover:not(:disabled){background:#f5f5f5}.submit-btn,.submit-button{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.submit-btn:hover:not(:disabled),.submit-button:hover:not(:disabled){background:#1565c0}.cancel-btn:disabled,.cancel-button:disabled,.submit-btn:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6}.error-box{border-radius:6px;margin-bottom:16px;padding:12px}.loading-box{color:#666;padding:40px}@media (max-width:768px){.modal-content{max-height:95vh;width:95%}.modal-header{padding:16px 20px}.modal-header h2,.modal-header h3{font-size:18px}.modal-body{padding:20px}.modal-footer{flex-direction:column-reverse;padding:12px 20px}.cancel-btn,.cancel-button,.submit-btn,.submit-button{width:100%}}.member-modal{max-height:80vh;max-width:600px}.member-modal .modal-body{max-height:500px;overflow-y:auto}.member-list{display:flex;flex-direction:column;gap:12px}.member-card{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:16px;padding:16px;transition:all .2s}.member-card:hover{border-color:#1976d2;box-shadow:0 2px 8px #0000001a}.member-icon{flex-shrink:0;font-size:32px;width:40px}.member-info{flex:1 1;min-width:0}.member-name{align-items:center;color:#333;display:flex;font-size:16px;font-weight:600;gap:8px;margin-bottom:4px}.role-badge{border-radius:4px;font-weight:600;padding:2px 8px}.role-badge.admin{background-color:#1976d2;color:#fff}.role-badge.member{background-color:#e0e0e0}.member-email{color:#666;font-size:14px;margin-bottom:4px}.member-joined{color:#999;font-size:12px}.member-actions{flex-shrink:0}.kick-button{background-color:#fff;border:2px solid #d32f2f;border-radius:6px;color:#d32f2f;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px;transition:all .2s;white-space:nowrap}.kick-button:hover{background-color:#ffebee;transform:translateY(-1px)}.invite-button-modal{background-color:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px;transition:all .2s;width:100%}.invite-button-modal:hover{background-color:#1565c0;box-shadow:0 2px 6px #1976d24d;transform:translateY(-1px)}@media (max-width:768px){.member-modal{margin:10px;max-width:95%}.member-card{align-items:flex-start;flex-direction:column}.kick-button,.member-actions{width:100%}}.invitation-container{margin:0 auto;max-width:1200px}.invitation-section{margin-bottom:40px}.invitation-section:last-child{margin-bottom:0}.section-title{align-items:center;color:#333;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 16px}.section-count{color:#1976d2;font-size:16px;font-weight:600}.invitation-list{display:flex;flex-direction:column;gap:16px}.empty-invitation{background-color:#fafafa;border:1px dashed #ddd;border-radius:8px;padding:60px 20px;text-align:center}.empty-invitation p{color:#999;font-size:16px;margin:0}.invitation-card{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:16px;padding:20px;transition:all .2s}.invitation-card:hover{border-color:#1976d2;box-shadow:0 2px 8px #0000001a}.invitation-icon{flex-shrink:0;font-size:32px}.invitation-content{flex:1 1}.invitation-text{color:#333;font-size:15px;line-height:1.5;margin:0}.invitation-text strong{color:#1976d2;font-weight:600}.invitation-email{color:#999;display:inline-block;font-size:13px;margin-left:8px}.invitation-actions{display:flex;flex-shrink:0;gap:10px}.accept-button{background-color:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-width:80px;padding:10px 24px;transition:all .2s}.accept-button:hover{background-color:#1565c0;box-shadow:0 2px 6px #1976d24d;transform:translateY(-1px)}.reject-button{background-color:#ef5350;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-width:80px;padding:10px 24px;transition:all .2s}.reject-button:hover{background-color:#e53935;transform:translateY(-1px)}.cancel-button-inv{background-color:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-width:80px;padding:10px 24px;transition:all .2s}.cancel-button-inv:hover{background-color:#f57c00;transform:translateY(-1px)}@media (max-width:768px){.invitation-card{align-items:flex-start;flex-direction:column}.invitation-actions{justify-content:stretch;width:100%}.accept-button,.cancel-button-inv,.reject-button{flex:1 1}}.dashboard-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px}.info-box{margin-bottom:20px}.dashboard-header{display:none}.header-left h2{color:#333;font-size:24px;font-weight:600;margin:0 0 8px}.header-left p{color:#666;font-size:14px;margin:0}.header-buttons{display:flex;gap:10px}.create-button{background-color:#4a90e2;border:none;border-radius:8px;box-shadow:0 2px 6px #4a90e24d;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.create-button:hover{background-color:#3a7bc8;box-shadow:0 4px 10px #4a90e266;transform:translateY(-1px)}.tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:4px;margin-bottom:30px}.tab,.tabs{position:relative}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.tab:hover{background-color:#f5f5f5;color:#1976d2}.tab.active{border-bottom-color:#1976d2;color:#1976d2}.tab-badge{background-color:#d32f2f;border-radius:10px;color:#fff;display:inline-block;font-size:12px;font-weight:600;margin-left:6px;min-width:20px;padding:2px 8px;text-align:center}.tab-content{animation:fadeIn .3s ease-in}.houses-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr}.empty-state{background-color:#fff;border:2px dashed #e0e0e0;border-radius:8px;color:#999;font-size:14px;padding:60px 20px;text-align:center}.empty-state p{margin:0}.house-card{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:16px;padding:20px;transition:all .3s ease}.house-card:hover{border-color:#1976d2;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.house-card-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding-bottom:12px}.house-title{align-items:center;display:flex;gap:8px}.house-title h3{color:#333;font-size:18px;font-weight:600;margin:0}.role-badge{border-radius:12px;font-size:12px;font-weight:500;padding:4px 12px}.role-badge.admin{background-color:#e3f2fd;color:#1976d2}.role-badge.member{background-color:#f5f5f5;color:#666}.house-card-info{display:flex;flex-direction:column;gap:10px}.info-row{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.info-row.clickable{border-radius:4px;cursor:pointer;margin:0 -12px;padding:8px 12px;transition:background-color .2s}.info-row.clickable:hover{background-color:#f5f5f5}.info-label{color:#666}.info-label,.info-value{font-size:14px;font-weight:500}.info-value{color:#333}.info-value.members{align-items:center;color:#1976d2;display:flex}.house-card-actions{border-top:1px solid #f0f0f0;display:flex;gap:10px;padding-top:12px}.card-delete-btn,.card-view-btn{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s}.card-view-btn{background-color:#4a90e2;color:#fff}.card-view-btn:hover{background-color:#3a7bc8;box-shadow:0 4px 10px #4a90e266;transform:translateY(-1px)}.card-delete-btn{background-color:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.card-delete-btn:hover{background-color:#e5e7eb;border-color:#9ca3af;transform:translateY(-1px)}.loading-box{padding:60px}.error-box{background-color:#ffebee;font-size:14px;margin-bottom:20px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background-color:#fff;border-radius:4px;max-width:90%;padding:30px;width:400px}.modal-title{color:#333;font-size:20px;font-weight:600;margin:0 0 24px}.form-group{margin-bottom:24px}.form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus{border-color:#1976d2;outline:none}.modal-buttons{display:flex;gap:8px;justify-content:flex-end}.cancel-button{background-color:#fff;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:14px;padding:10px 20px}.cancel-button:hover{background-color:#f5f5f5}.submit-button{background-color:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.submit-button:hover{background-color:#1565c0}@media (min-width:768px){.houses-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.houses-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:767px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:16px;margin-bottom:20px;padding-bottom:16px}.header-left h2{font-size:20px;margin-bottom:4px}.header-left p{font-size:13px}.header-buttons{width:100%}.create-button{display:none}.profile-card{align-items:flex-start;flex-direction:column;gap:16px;padding:16px}.profile-info{align-self:flex-start;gap:12px}.profile-avatar{font-size:18px;height:40px;width:40px}.profile-text h3{font-size:16px;margin-bottom:2px}.profile-text p{font-size:13px}.logout-btn{padding:10px 16px;width:100%}.tabs{background:#fff;margin-bottom:0;position:-webkit-sticky;position:sticky;top:0;z-index:10}.tab{font-size:14px;padding:10px 20px}.tab-content{margin-bottom:20px;padding-top:20px}.house-card{padding:16px}.house-card-header{padding-bottom:10px}.house-title h3{font-size:16px}.role-badge{font-size:11px;padding:3px 10px}.info-row{padding:6px 0}.info-label,.info-value{font-size:13px}.card-delete-btn,.card-view-btn{font-size:13px;padding:10px 14px}}.info-box{align-items:center;background-color:#e3f2fd;border-left:4px solid #1976d2;border-radius:4px;display:flex;gap:8px;margin:24px auto 20px;max-width:1200px;padding:16px}.info-box .pin-icon{color:#1976d2;font-size:16px}.info-box p{color:#333;font-size:14px;margin:0}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;height:60px;margin:0;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:100}.app-header-inner{align-items:center;display:flex;gap:24px;height:100%;margin:0 auto;max-width:1200px;padding:0 24px}.app-header.full-width .app-header-inner{justify-content:space-between;max-width:none}.header-left-section{gap:16px}.app-logo,.header-left-section{align-items:center;display:flex}.app-logo{color:#1f2937;font-size:20px;font-weight:700;gap:10px}.logo-icon{display:block;height:28px;width:28px}.logo-text{color:#1f2937}.header-actions{align-items:center;display:flex;gap:12px;margin-left:auto}.create-house-btn{align-items:center;background:#4a90e2;border:none;border-radius:8px;box-shadow:0 2px 8px #4a90e24d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .2s}.create-house-btn .btn-icon{font-size:18px;font-weight:400}.create-house-btn .btn-text{font-size:14px}.create-house-btn:hover{background:#3a7bc8;box-shadow:0 4px 12px #4a90e266;transform:translateY(-1px)}.create-house-btn:active{transform:translateY(0)}.profile-dropdown{position:relative}.profile-btn{align-items:center;background:#f3f4f6;border:2px solid #0000;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:15px;font-weight:600;height:38px;justify-content:center;transition:all .2s;width:38px}.profile-btn:hover{background:#e5e7eb}.profile-btn.active{background:#eff6ff;border-color:#4a90e2;color:#4a90e2}.dropdown-menu{animation:fadeIn .2s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px #0000001a;min-width:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px)}.dropdown-header{background:#fafafa;border-bottom:1px solid #e5e7eb;padding:16px}.dropdown-user-name{color:#1f2937;font-size:15px;font-weight:600;margin-bottom:4px}.dropdown-user-email{color:#9ca3af;font-size:13px}.dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-align:left;transition:background .15s;width:100%}.dropdown-item:hover{background:#f9fafb}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout:hover{background:#fee2e2}.dropdown-icon{filter:brightness(0) saturate(100%) invert(25%) sepia(85%) saturate(3500%) hue-rotate(350deg) brightness(95%) contrast(90%);height:16px;width:16px}.detail-nav-buttons{align-items:center;display:flex;gap:8px}.nav-icon-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.nav-icon-btn:hover{background:#e5e7eb}.nav-icon-btn:active{transform:scale(.95)}.add-icon-btn{align-items:center;background:#4a90e2;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:600;height:36px;justify-content:center;transition:all .2s;width:36px}.add-icon-btn:hover{background:#3a7bc8;transform:translateY(-1px)}.add-icon-btn:active{transform:scale(.95)}.tool-icon-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.tool-icon-btn:hover{background:#e5e7eb}.tool-icon-btn:active{transform:scale(.95)}.temp-badge-btn{align-items:center;background:#fff3e0;border:1px solid #ffb74d;border-radius:8px;cursor:pointer;display:flex;gap:6px;height:36px;padding:0 12px;transition:all .2s}.temp-badge-btn:hover{background:#ffe0b2;border-color:#ffa726}.temp-badge-btn .temp-count{color:#e65100;font-size:13px;font-weight:600}@media (max-width:768px){.app-header{height:56px}.app-header-inner{padding:0 16px}.app-header.full-width .app-logo{display:none}.logo-text{font-size:18px}.create-house-btn{gap:0;height:36px;padding:0;width:36px}.create-house-btn .btn-text{display:none}.create-house-btn .btn-icon{font-size:20px}.profile-btn{height:36px;width:36px}.dropdown-menu{right:-8px}}.item-card{align-items:center;animation:slideInUp .4s ease-out forwards;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;opacity:0;padding:12px 16px;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none}.item-card:hover{background:#f5f5f5;border-color:#1976d2}.item-card.active{background:#e3f2fd;border-color:#1976d2}.item-icon{flex-shrink:0;font-size:24px}.item-info{flex:1 1;min-width:0}.item-name{color:#333;font-size:15px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-meta{color:#999;display:flex;flex-wrap:wrap;font-size:13px;gap:8px}.item-meta span{white-space:nowrap}.item-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:2px 8px}.item-badge.owner{background:#e3f2fd;color:#1976d2}.item-card-actions{display:none;gap:6px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.item-card:hover .item-card-actions{display:flex}.item-action-btn{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:600;line-height:1;padding:8px 10px;transition:background-color .2s,border-color .2s}.temp-btn{background:#fff3e0;border:1px solid #ff9800;color:#f57c00}.temp-btn:hover{background:#ffe0b2}.container-detail{display:flex;flex-direction:column;height:100%;overflow:hidden}.detail-header{align-items:flex-start;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;padding:20px}.detail-title-section{align-items:flex-start;display:flex;flex:1 1;gap:16px}.detail-icon{flex-shrink:0;font-size:48px}.detail-title-info{flex:1 1;min-width:0}.detail-title{color:#333;font-size:20px;font-weight:600;margin:0 0 8px}.detail-subtitle{color:#999;font-size:13px;margin:0}.detail-actions{display:flex;flex-shrink:0;gap:8px}.action-button{background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.action-button:hover{background:#f5f5f5}.action-button.primary{background:#1976d2;border-color:#1976d2;color:#fff}.action-button.primary:hover{background:#1565c0}.action-button.delete{background:#ef5350;border:none;color:#fff}.action-button.delete:hover{background:#e53935}.detail-tabs{background:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;gap:20px;padding:12px 20px}.detail-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;font-size:13px;font-weight:500;padding:4px 0;position:relative;transition:all .2s}.detail-tab:hover{color:#333}.detail-tab.active{border-bottom-color:#1976d2;color:#1976d2;font-weight:600}.detail-tab-content{background:#fff;flex:1 1;overflow-y:auto}.detail-section{border-bottom:1px solid #e0e0e0;padding:20px}.detail-section:last-child{border-bottom:none}.detail-section-title{color:#666;font-size:14px;font-weight:600;margin-bottom:16px}.detail-field{border-bottom:1px solid #f5f5f5;display:flex;padding:12px 0}.detail-field:last-child{border-bottom:none}.detail-field-label{color:#999;flex-shrink:0;font-size:14px;width:100px}.detail-field-value{color:#333;flex:1 1;font-size:14px}.history-list{padding:0}.history-item{animation:slideInUp .4s ease-out forwards;border-bottom:1px solid #e0e0e0;opacity:0;padding:16px 20px;transition:background .2s}.history-item:hover{background:#f9f9f9}.history-item:last-child{border-bottom:none}.history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.history-action{align-items:center;display:flex;gap:8px}.history-icon{font-size:18px}.history-action-name{color:#333;font-size:14px;font-weight:600}.history-date{color:#999;font-size:12px}.history-detail{color:#666;font-size:13px;line-height:1.5;margin-bottom:6px;white-space:pre-line}.history-user{color:#999;font-size:12px}.history-error,.history-loading{color:#999;padding:40px 20px;text-align:center}.history-error{color:#d32f2f}.history-empty{align-items:center;color:#999;display:flex;height:200px;justify-content:center}.history-empty p{font-size:14px;margin:0}.temp-storage{margin:20px}.temp-storage-actions{display:flex;gap:8px}.temp-clear-all-button{background:#ef5350;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:background .2s}.temp-clear-all-button:hover{background:#e53935}.temp-move-all-button{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:background .2s}.temp-move-all-button:hover{background:#f57c00}.temp-item{transition:background .2s}.temp-item-header{align-items:flex-start;display:flex;justify-content:space-between}.temp-item-info{flex:1 1;min-width:0}.temp-item-name{color:#333;font-weight:600;margin-bottom:4px}.temp-item-location,.temp-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.temp-item-location{color:#666;font-size:12px}.temp-item-meta{color:#999;font-size:12px}.temp-item-actions{align-items:center;display:flex;gap:8px;opacity:0;transition:opacity .2s}.temp-item:hover .temp-item-actions{opacity:1}.temp-move-btn{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:4px 10px;transition:background .2s;white-space:nowrap}.temp-move-btn:hover{background:#1565c0}.temp-remove{color:#d32f2f;cursor:pointer;font-size:16px;font-weight:700;opacity:.6;padding:4px;transition:opacity .2s}.temp-remove:hover{opacity:1}.child-preview-section{animation:fadeIn .3s ease-out}.child-preview-item{animation:slideInUp .4s ease-out forwards;opacity:0}.drill-down-section-mobile{background:#fff;flex-shrink:0;padding:16px 20px 8px}.drill-down-button-mobile{align-items:center;background-color:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;transition:background-color .2s;width:100%}.drill-down-button-mobile:hover{background-color:#1565c0}.drill-down-button-mobile:active{background-color:#0d47a1}.detail-actions-mobile{background:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;gap:12px;padding:8px 20px 16px}.action-button-mobile{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:15px;font-weight:600;justify-content:center;padding:12px 20px;transition:all .2s}.action-button-mobile.edit{background:#fff;border:1px solid #ddd;color:#666}.action-button-mobile.edit:hover{background:#f5f5f5}.action-button-mobile.edit:active{background:#e0e0e0}.action-button-mobile.delete{background:#ef5350;border:none;color:#fff}.action-button-mobile.delete:hover{background:#e53935}.action-button-mobile.delete:active{background:#d32f2f}.mobile-bottom-sheet-overlay{align-items:flex-end;bottom:0;display:flex;left:0;position:fixed;right:0;top:0;z-index:100}.bottom-sheet-backdrop{animation:fadeIn .3s ease;background-color:#00000080;bottom:0;left:0;position:absolute;right:0;top:0}.bottom-sheet-container{animation:slideUp .3s ease;background-color:#fff;border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -4px 20px #00000026;display:flex;flex-direction:column;height:80vh;overflow:hidden;position:relative;width:100%;z-index:101}.bottom-sheet-close-btn{align-items:center;background-color:#f5f5f5;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:background-color .2s;width:32px;z-index:102}.bottom-sheet-close-btn:hover{background-color:#e0e0e0}.bottom-sheet-close-btn:active{background-color:#d0d0d0}.bottom-sheet-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.bottom-sheet-content::-webkit-scrollbar{width:6px}.bottom-sheet-content::-webkit-scrollbar-track{background:#0000}.bottom-sheet-content::-webkit-scrollbar-thumb{background-color:#d0d0d0;border-radius:3px}.bottom-sheet-content::-webkit-scrollbar-thumb:hover{background-color:#b0b0b0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.mobile-bottom-sheet-overlay.closing .bottom-sheet-backdrop{animation:fadeOut .2s ease}.mobile-bottom-sheet-overlay.closing .bottom-sheet-container{animation:slideDown .2s ease}.search-modal-content{max-height:80vh;max-width:600px;position:relative}.search-input-container{margin-bottom:24px}.search-input{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;outline:none;padding:12px 16px;transition:all .2s;width:100%}.search-input:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.search-results{max-height:400px;overflow-y:auto}.search-status{color:#999;font-size:14px;padding:40px 20px;text-align:center}.search-result-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:16px;margin-bottom:12px;padding:16px;transition:all .2s}.search-result-item:hover{border-color:#1976d2;box-shadow:0 2px 8px #0000001a}.search-result-icon{flex-shrink:0;font-size:32px}.search-result-info{flex:1 1;min-width:0}.search-result-name{color:#333;font-size:15px;font-weight:600;margin-bottom:4px}.search-result-path{color:#999;font-size:13px;margin-bottom:4px}.search-result-meta{color:#666;font-size:12px}.goto-button{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:8px 20px;transition:all .2s;white-space:nowrap}.goto-button:hover{background:#1565c0;box-shadow:0 2px 6px #1976d24d;transform:translateY(-1px)}.goto-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.search-loading-overlay{align-items:center;background:#fffffff2;border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1000}.search-loading-content{text-align:center}.search-loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#1976d2;height:50px;margin:0 auto 16px;width:50px}.search-loading-text{color:#333;font-size:16px;font-weight:600}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.temp-storage{background:#fff3e0;border:2px dashed #ff9800;border-radius:8px;margin-top:24px;padding:16px}.temp-storage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.temp-storage-title{color:#f57c00;font-size:14px;font-weight:600}.temp-item{align-items:center;background:#fff;border-radius:4px;display:flex;font-size:13px;justify-content:space-between;margin-bottom:8px;padding:8px 12px}.temp-item:last-child{margin-bottom:0}.temp-item-modal{align-items:center;background:#fff3e0;border:1px solid #ff9800;border-radius:8px;display:flex;gap:12px;margin-bottom:12px;padding:16px}.temp-item-modal:last-child{margin-bottom:0}.temp-item-modal .item-icon{align-items:center;display:flex;flex-shrink:0;font-size:32px;height:48px;justify-content:center;width:48px}.temp-item-modal .temp-item-info{flex:1 1;min-width:0}.temp-item-modal .temp-item-name{color:#333;font-size:16px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.temp-item-modal .temp-item-detail{color:#666;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.temp-item-modal .remove-button{background:#0000;border:none;color:#d32f2f;cursor:pointer;flex-shrink:0;font-size:20px;font-weight:700;opacity:.6;padding:4px 8px;transition:opacity .2s}.temp-item-modal .remove-button:hover{opacity:1}.modal-header-actions{align-items:center;display:flex;gap:8px}.clear-all-button{background:#ef5350;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s}.clear-all-button:hover{background:#e53935}.house-history-modal{max-height:80vh;max-width:800px;position:relative;width:90%}.house-history-modal .modal-body{overflow-y:auto;padding:0}.house-history-modal .history-empty,.house-history-modal .history-error,.house-history-modal .history-loading{color:#666;padding:40px 20px;text-align:center}.house-history-modal .history-list{padding:0}.house-history-modal .history-item{animation:slideInUp .4s ease-out forwards;border-bottom:1px solid #e0e0e0;opacity:0;padding:16px 20px;transition:background .2s}.house-history-modal .history-item.clickable{cursor:pointer}.house-history-modal .history-item.clickable:hover{background:#f0f7ff}.house-history-modal .history-item:not(.clickable):hover{background:#f9f9f9}.house-history-modal .history-item:last-child{border-bottom:none}.house-history-modal .history-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.house-history-modal .history-title{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0}.house-history-modal .history-type-icon{flex-shrink:0;height:18px;opacity:.7;width:18px}.house-history-modal .history-container-name{color:#333;font-size:16px;font-weight:600}.house-history-modal .history-separator{color:#999;flex-shrink:0;font-weight:400;margin:0 2px}.house-history-modal .history-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.house-history-modal .history-action-name{color:#555;flex-shrink:0;font-size:14px;font-weight:500;white-space:nowrap}.house-history-modal .history-detail{color:#666;font-size:14px;margin-bottom:6px}.house-history-modal .history-date{color:#999;flex-shrink:0;font-size:12px}.house-history-modal .history-footer{align-items:center;display:flex;justify-content:space-between}.house-history-modal .history-user{color:#999;font-size:13px}.house-history-modal .history-date-mobile{color:#999;display:none;font-size:12px}.house-history-modal .deleted-badge{color:#999;font-size:11px;font-weight:400;margin-left:4px}.history-loading-overlay{align-items:center;background:#fffffff2;border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1000}.history-loading-content{text-align:center}.history-loading-spinner{animation:historySpinner 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#1976d2;height:50px;margin:0 auto 16px;width:50px}.history-loading-text{color:#333;font-size:16px;font-weight:600}@keyframes historySpinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.house-history-modal .history-date{display:none}.house-history-modal .history-date-mobile{display:block}}.house-detail-view{background:#f5f5f5;display:flex;flex-direction:column;height:calc(100vh - 60px)}.header{background:#fff;padding:5px 24px 0}.breadcrumb-row{margin-top:16px;padding-bottom:20px}.breadcrumb{align-items:center;color:#333;display:flex;font-size:18px;font-weight:600;gap:8px}.breadcrumb-item{cursor:pointer;transition:color .2s}.breadcrumb-item:hover{color:#1976d2}.breadcrumb-separator{color:#999}.breadcrumb-current{color:#1976d2}.header-right{align-items:center;display:flex;gap:12px}.recent-activity-section{border-bottom:1px solid #e0e0e0;margin:0 -24px;min-height:80px;padding:12px 24px;transition:all .2s ease}.recent-activity-header{align-items:center;color:#666;display:flex;font-size:14px;font-weight:600;gap:6px;justify-content:space-between;margin-bottom:12px}.activity-toggle-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px 8px;transition:all .2s ease}.activity-toggle-btn:hover{background:#f0f0f0}.toggle-arrow{color:#999;display:inline-block;font-size:10px;transition:transform .2s ease}.toggle-arrow.expanded{transform:rotate(180deg)}.recent-activity-list{display:flex;flex-direction:column}.recent-activity-empty{color:#999;font-size:13px;padding:20px;text-align:center}.recent-activity-item{align-items:center;background:#fff;border:1px solid #f0f0f0;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:13px;gap:10px;margin-bottom:6px;max-height:100px;opacity:1;overflow:hidden;padding:8px 12px;transition:background .2s,opacity .3s ease,max-height .3s ease,padding .3s ease,margin .3s ease}.recent-activity-item:last-child{margin-bottom:0}.recent-activity-item.initial-load{animation:slideInUp .4s ease-out forwards}.recent-activity-item.hidden{border:none;margin-bottom:0;max-height:0;opacity:0;padding-bottom:0;padding-top:0;pointer-events:none}.recent-activity-item:hover:not(.hidden){background:#f5f5f5;border-color:#e0e0e0}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.activity-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.activity-creator{color:#333;flex-shrink:0;font-weight:600}.activity-content{color:#555;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-name-highlight{align-items:center;display:inline-flex;font-weight:500;gap:4px}.type-icon-inline{height:14px;opacity:.7;width:14px}.activity-detail-text{color:#666}.activity-time{color:#999;flex-shrink:0;font-size:11px}.panel-container{flex:1 1}.panel,.panel-container{display:flex;overflow:hidden}.panel{background:#fff;border-right:1px solid #e0e0e0;flex:1 1;flex-direction:column}.panel.left-panel{flex:1 1;min-width:200px}.panel.center-panel{flex:1 1}.panel.right-panel{flex:1.5 1}.panel:last-child{border-right:none}.panel-header{align-items:center;background:#f5f5f5;border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;color:#666;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:56px;justify-content:space-between;padding:16px 20px}.panel-header span{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel-content{flex:1 1;overflow-y:auto;padding:12px}.add-item-footer{background:#0000;border:2px dashed #0000;border-radius:6px;color:#0000;cursor:pointer;font-size:14px;font-weight:600;margin:8px 0 0;padding:12px 16px;text-align:center;transition:all .2s}.add-item-footer:hover{background:#f5f5f5;border-color:#1976d2;color:#1976d2}.empty-panel{align-items:center;color:#999;display:flex;flex-direction:column;height:100%;justify-content:center}.empty-panel p{font-size:14px;margin:0}.pc-temp-storage-section{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin-bottom:16px;padding:12px}.pc-temp-storage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.pc-temp-storage-header span{color:#f57c00;font-size:14px;font-weight:600}.pc-temp-header-actions{display:flex;gap:8px}.pc-clear-all-button{background:#ef5350;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s}.pc-clear-all-button:hover{background:#e53935}.pc-move-here-button{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s}.pc-move-here-button:hover{background:#f57c00}.pc-temp-storage-items{display:flex;flex-direction:column;gap:8px}.pc-temp-item{align-items:center;background:#fff;border-radius:6px;display:flex;gap:12px;padding:10px 12px}.pc-temp-item-icon{align-items:center;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.pc-temp-item-info{flex:1 1;min-width:0}.pc-temp-item-name{color:#333;font-size:14px;font-weight:600;margin-bottom:2px}.pc-temp-item-location,.pc-temp-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pc-temp-item-location{color:#666;font-size:12px}.pc-temp-remove{background:#0000;border:none;color:#d32f2f;cursor:pointer;flex-shrink:0;font-size:18px;font-weight:700;opacity:.6;padding:4px 8px;transition:opacity .2s}.pc-temp-remove:hover{opacity:1}.loading-box{color:#999;font-size:14px;padding:60px 20px;text-align:center}.error-box{background:#ffebee;border:1px solid #ef5350;border-radius:4px;color:#c62828;margin:16px;padding:16px}@media (min-width:768px){.mobile-layout{display:none}}@media (max-width:767px){.house-detail-view{height:calc(100vh - 56px)}.header{align-items:stretch;flex-direction:column;gap:0;padding:0 16px}.breadcrumb{word-wrap:break-word;border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;color:#666;font-size:14px;line-height:1.5;margin:0 -16px;padding:12px 16px 16px;white-space:normal;word-break:break-word}.recent-activity-section{border-bottom:none;margin:0 -16px;min-height:75px;padding:10px 16px}.activity-content{font-size:12px}.activity-time{font-size:10px}.mobile-layout,.mobile-panel-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.mobile-panel-content{background:#fff}.mobile-panel-list{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:8px}.mobile-temp-storage-section{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin-bottom:16px;padding:12px}.mobile-temp-storage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.mobile-temp-storage-header span{color:#f57c00;font-size:14px;font-weight:600}.mobile-temp-header-actions{display:flex;gap:8px}.mobile-clear-all-button{background:#ef5350;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s}.mobile-clear-all-button:hover{background:#e53935}.mobile-move-here-button{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s}.mobile-move-here-button:hover{background:#f57c00}.mobile-temp-storage-items{display:flex;flex-direction:column;gap:8px}.mobile-temp-item{align-items:center;background:#fff;border-radius:6px;display:flex;gap:12px;padding:10px 12px}.mobile-temp-item-icon{align-items:center;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.mobile-temp-item-info{flex:1 1;min-width:0}.mobile-temp-item-name{color:#333;font-size:14px;font-weight:600;margin-bottom:2px}.mobile-temp-item-location,.mobile-temp-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-temp-item-location{color:#666;font-size:12px}.mobile-temp-remove{background:#0000;border:none;color:#d32f2f;cursor:pointer;flex-shrink:0;font-size:18px;font-weight:700;opacity:.6;padding:4px 8px;transition:opacity .2s}.mobile-temp-remove:hover{opacity:1}.panel-container{display:none}}
/*# sourceMappingURL=main.90e9ee24.css.map*/